不同命名空间中的朋友操作员

时间:2014-08-26 22:58:35

标签: c++

目前,以下代码无效:

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);

                                                            ^

我认为限定命名空间会解决问题,但事实并非如此。什么是解决方法?

2 个答案:

答案 0 :(得分:4)

友元声明只能在紧邻的名称空间中引入名称。

如果你想成为任何其他命名空间中的函数的伙伴,那么你需要在友元声明之前在其命名空间中声明该函数。正如错误消息所示。

在这种情况下,您可能希望运算符位于inner而不是全局命名空间。依赖于参数的查找仍会在类似test_a + test_b的表达式中找到它,即使它不在范围内。

答案 1 :(得分:1)

您必须在结构中使用之前声明运算符。