前端之家收集整理的这篇文章主要介绍了
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(){}时,这是一个不合格的名称,它总是在当前命名空间中声明该函数,这是全局命名空间.
原文链接:https://www.f2er.com/c/111578.html