【问题标题】:Memory allocation in case of static variables静态变量的内存分配
【发布时间】:2010-03-08 17:44:20
【问题描述】:

我总是对静态变量以及它们的内存分配方式感到困惑。

例如:

int a = 1;
const int b = 2;
static const int c = 3;

int foo(int &arg){
  arg++;
  return arg;
}

abc 的内存是如何分配的?

如果我调用foo(a)foo(b)foo(c),有什么区别(在内存方面)?

【问题讨论】:

  • 你不能打电话给foo(b)foo(c)
  • 也许值得知道的是,在 C++ 中,bc 都具有静态链接。在 C 中,b 具有外部链接。

标签: c++ c memory static memory-management


【解决方案1】:

我总是对静态变量感到困惑

在全局范围内,static 仅表示链接时对其他文件不可见。

a、b 和 c 的内存是如何分配的?

它们都将存在于可执行文件中(例如 __DATA 段),该文件将在执行时映射到 RAM。如果编译器不错,bc 将位于只读数据区域(例如 __TEXT 段),甚至在优化中被淘汰。

如果我调用 foo(a)、foo(b) 和 foo(c),有什么区别(在内存方面)?

foo(b)foo(c) 将是编译器错误,因为const int& 无法转换为int&

否则没有区别。引用传递相当于 CPU 意义上的指针传递。所以每个内存的地址都被取出来了,foo被调用了。

【讨论】:

    【解决方案2】:

    为您的三个变量分配相同的内存。不同之处在于编译器如何处理它们。因为bc 是用const 声明的,所以如果你试图修改它们的值,编译器会抱怨你。由于c 定义为static,因此在当前文件之外将无法访问它(ab 都可以使用extern 访问)。

    所有这三个的内存都将在可执行文件中分配,除非进行任何优化(有时编译器可以通过在引用常量的任何地方填写常量的值来消除为常量分配内存的需要)。

    您的函数调用将适用于a,但不适用于bc,无需显式转换(因为您的函数需要指向非constint 的指针)。但是,如果您尝试将 const 值强制转换为非 const 值,您的编译器会抱怨您。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2023-03-02
      • 1970-01-01
      • 2012-11-29
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2014-05-21
      相关资源
      最近更新 更多