它是如何工作的?是存储在特殊寄存器或内存中的变量吗?我在视觉中查看寄存器/内存窗口,但我无法理解:(
#include <iostream>
using namespace std;
namespace first
{
int x = 5;
int y = 10;
}
namespace second
{
double x = 3.1416;
double y = 2.7183;
}
int main () {
using first::x;
using second::y;
cout << x << endl;
cout << y << endl;
cout << first::y << endl;
cout << second::x << endl;
return 0;
}
class CRectangle {
int x, y;
public:
void set_values (int,int);
int area (void);
private:
int param;
} rect;
答案 0 :(得分:8)
从机器的角度来看,private
或namespace
没有什么不同。这些只是编译器的标识符。也就是说,编译器会强制执行访问规则,这就是为什么在执行不应该执行的操作时会遇到编译器错误的原因。但是,编译器最终生成的二进制代码不会对数据的含义做任何区分。
答案 1 :(得分:3)
编译器需要
namespace first
{
int x = 5;
int y = 10;
}
namespace second
{
double x = 3.1416;
double y = 2.7183;
}
并有效地生成汇编代码,其工作方式如下:
_first@@x: dd 5
_first@@y: dd 10
_second@@x: dq 3.1416
_second@@y: dq 2.7183
如果您不熟悉汇编语言,这四个语句每个都保留内存,两个用于32位整数,两个用于浮点值,并为它们分配标签。标签是内存地址。
请注意,命名空间限定每个变量名称。 @
本身没有意义,但是转义命名空间和变量名以隔离异常命名的C++
语言变量。汇编语言标识符通常允许比高级语言更大范围的字符,方便使用,例如此。
答案 2 :(得分:1)
命名空间用作编译器的方向,因为实际的var名称和方法/类名在编译后具有不同的名称,因此不使用名称空间名称。