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&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...