c – 为什么在使用命名空间指令时没有命名空间作为函数?

前端之家收集整理的这篇文章主要介绍了c – 为什么在使用命名空间指令时没有命名空间作为函数?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
这个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(){}时,这是一个不合格的名称,它总是在当前命名空间中声明该函数,这是全局命名空间.

猜你在找的C&C++相关文章