所以我在class
命名空间中有foo
,其中包含friend
函数。现在我希望friend
函数的定义位于不同的名称空间bar
中,因此可以按照下面的方式调用它。我得到的错误是无法访问私有成员val
。
问题:为什么?
#include <iostream>
namespace foo
{
template<typename T>
class myclass
{
private:
T val;
public:
myclass(T v) : val(v) {}
template<class U>
friend void myfun(myclass<U>);
};
namespace bar
{
template<class U>
void myfun(myclass<U> a)
{
std::cout << a.val;
}
} //bar
} //foo
int main()
{
foo::myclass<int> a(5);
foo::bar::myfun(a);
}
答案 0 :(得分:4)
您应该在朋友声明之前声明foo::bar::myfun
并使用适当的命名空间限定(bar::
):
namespace foo
{
template<typename T>
class myclass;
namespace bar
{
template<class U>
void myfun(myclass<U> a);
} //bar
template<typename T>
class myclass
{
private:
T val;
public:
myclass(T v) : val(v) {}
template<class U>
friend void bar::myfun(myclass<U>);
};
} //foo
否则另一个名为myfun
的函数将由朋友声明在foo
命名空间中声明。