命名空间和私有变量如何在程序集中工作?

时间:2011-12-20 18:09:34

标签: c++ assembly namespaces

它是如何工作的?是存储在特殊寄存器或内存中的变量吗?我在视觉中查看寄存器/内存窗口,但我无法理解:(

#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;

3 个答案:

答案 0 :(得分:8)

从机器的角度来看,privatenamespace没有什么不同。这些只是编译器的标识符。也就是说,编译器会强制执行访问规则,这就是为什么在执行不应该执行的操作时会遇到编译器错误的原因。但是,编译器最终生成的二进制代码不会对数据的含义做任何区分。

答案 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名称和方法/类名在编译后具有不同的名称,因此不使用名称空间名称。