c – 为什么在使用命名空间指令时没有命名空间作为函数?
发布时间:2020-12-16 03:24:05 所属栏目:百科 来源:网络整理
导读:这个c文件… namespace foo { class C { void m(); }; void f();}using namespace foo;void C::m() {}void f() {} ..使用这些符号与目标文件进行编译: $g++ foo.cpp -c$nm foo.o -C000000000000000a T f()0000000000000000 T foo::C::m() 为什么C :: m()?
这个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(){}时,这是一个不合格的名称,它总是在当前命名空间中声明该函数,这是全局命名空间. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |