这个c
文件…
namespace foo {
class C {
void m();
};
void f();
}
using namespace foo;
void C::m() {}
void f() {}
..使用这些符号与目标文件进行编译:
$g++ foo.cpp -c
$nm foo.o -C
000000000000000a T f()
0000000000000000 T foo::C::m()
为什么C :: m()?获取命名空间,但不是f()?
(我不是使用命名空间foo使用命名空间foo {…},所以这两个名称都有前缀).
在void C :: m(){}中,C :: m是一个限定
名称,而这样的定义总是指先前声明的
内容.编译器查找C,发现C实际上是foo :: C,感谢using-directive,它采用void C :: m(){}作为foo :: C :: m()的定义.
当你写void f(){}时,这是一个不合格的名称,它总是在当前命名空间中声明该函数,这是全局命名空间.