18

考虑以下代码段:

void Foo() // 1
{
}

namespace
{
  void Foo() // 2
  {
  }
}

int main()
{
  Foo(); // Ambiguous.
  ::Foo(); // Calls the Foo in the global namespace (Foo #1).

  // I'm trying to call the `Foo` that's defined in the anonymous namespace (Foo #2).
}

在这种情况下,如何引用匿名命名空间内的内容?

4

5 回答 5

19

你不能。该标准包含以下部分(§7.3.1.1,C++03):

未命名的命名空间定义的行为就像它被替换为

  namespace unique { /* empty body */ }
  using namespace unique;
  namespace unique { namespace-body }

其中,翻译单元中所有出现的唯一性都被相同的标识符替换,并且该标识符与整个程序中的所有其他标识符不同。

因此,您无法引用该唯一名称。

但是,您可以在技术上使用类似以下的内容:

int i;

namespace helper {
    namespace {
        int i;
        int j;
    }
}

using namespace helper;

void f() { 
    j++; // works
    i++; // still ambigous
    ::i++; // access to global namespace
    helper::i++; // access to unnamed namespace        
}
于 2010-09-09T02:27:13.777 回答
5

虽然 Georg 给出了符合标准、正确、正确和可敬的答案,但我想提供我的 hacky 答案——在匿名命名空间中使用另一个命名空间

#include <iostream>

using namespace std;

namespace
{
namespace inner
{
    int cout = 42;
}
}

int main()
{
    cout << inner::cout << endl;
    return 0;
}
于 2010-09-09T02:36:37.477 回答
2

我能想到的唯一不修改现有命名空间安排的解决方案是委托main给匿名命名空间中的函数。(main本身必须是一个全局函数(§3.6.1/1),所以它不能在匿名命名空间中。)

void Foo() // 1
{
}

namespace
{
  void Foo() // 2
  {
  }
}

namespace { // re-open same anonymous namespace

    int do_main()
    {
      Foo(); // Calls local, anonymous namespace (Foo #2).
      ::Foo(); // Calls the Foo in the global namespace (Foo #1).

      return 0; // return not optional
    }

}

int main() {
    return do_main();
}
于 2010-09-09T02:37:57.297 回答
0

只需重命名本地命名空间函数。

于 2013-11-27T15:57:13.373 回答
0

唯一真正的方法是将要访问该名称空间的代码放在名称空间本身中。否则无法解析到未命名的命名空间,因为它没有标识符,您可以给它来解决不明确的解析问题。

如果您的代码在 namespace{} 块本身内,则本地名称优先于全局名称,因此 Foo() 将在您的命名空间内调用 Foo(),而 ::Foo() 将在全局调用命名空间范围。

于 2010-09-09T02:32:15.177 回答