目前,以下代码无效:
namespace inner
{
struct Test
{
Test() : n(0) { }
friend int ::operator+(const Test& a, const Test& b);
private:
int n;
};
}
int operator+(const inner::Test& a, const inner::Test& b)
{
return a.n + b.n;
}
我得到的错误是
error: 'int operator+(const inner::Test&, const inner::Test&)' should have been declared inside '::'
friend int ::operator+(const Test& a, const Test& b);
^
我认为限定命名空间会解决问题,但事实并非如此。什么是解决方法?
答案 0 :(得分:4)
友元声明只能在紧邻的名称空间中引入名称。
如果你想成为任何其他命名空间中的函数的伙伴,那么你需要在友元声明之前在其命名空间中声明该函数。正如错误消息所示。
在这种情况下,您可能希望运算符位于inner
而不是全局命名空间。依赖于参数的查找仍会在类似test_a + test_b
的表达式中找到它,即使它不在范围内。
答案 1 :(得分:1)
您必须在结构中使用之前声明运算符。