以下代码无法编译,我不知道为什么:
#include <type_traits>
// Base class definition
template<template<typename> class CRTP, typename T> class Base
{
// Friend function declaration
public:
template<template<typename> class CRTP0, typename T0, class>
friend int func(const Base<CRTP0, T0>& rhs);
// Protected test variable
protected:
int n;
};
// Friend function definition
template<template<typename> class CRTP0, typename T0,
class = typename std::enable_if<true>::type>
int func(const Base<CRTP0, T0>& rhs)
{
return rhs.n;
}
// Derived class definition
template<typename T> class Derived : public Base<Derived, T> {};
// Main
int main()
{
Derived<int> x;
func(x);
return 0;
}
GCC 4.6.2(和 LWS 上的 GCC 4.7.1)告诉我:
error: 'int Base<Derived, int>::n' is protected
这意味着基本上没有正确检测到友谊。由于这只是我的代码的摘录,我想将友元函数的定义放在类定义之外,就像这里一样。那么,问题是什么以及如何解决呢?
编辑:我已经修改了代码以尝试隔离问题并使其更具可读性。当前的 enable_if 始终为真,但对于我的真实代码,我将有一个“真实”条件,这里只是为了隔离问题。
EDIT2:liveworkspace 在这里:朋友功能问题