c语言程序内存分配

C语言程序的内存主要分为栈区、堆区、静态区和代码段。栈区存储函数参数、局部变量,由编译器自动分配和释放;堆区由程序员管理,手动分配和释放;静态区包含初始化和未初始化的全局变量、静态变量;代码段则存放程序的机器指令。全局只读变量和常量存储在只读数据段。程序启动时会动态生成未初始化数据段,运行时形成堆和栈。
摘要由CSDN通过智能技术生成

一个由C/C++编译的程序占用的内存分为以下几个部分

1、栈区(stack)—程序运行时由编译器自动分配,存放函数的参数值,函数返回值,局部变量的值等。其操作方式类似于数据结构中的栈。程序结束时由编译器自动释放。

2、堆区(heap) —在内存开辟另一块存储区域。一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收。注意它与数据结构中的堆是两回事。

3、静态区(static)—编译器编译时即分配内存。

  1 初始化数据段:初始化的全局变量和静态变量在一块区域

  2 未初始化数据段:未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。该段中的数据没有经过初始化。因此它只会在目标文件中被标识,而不会真正称为目标文件中的一段,该段将会在运行时产生。未初始化数据段只在运行的初始化阶段才会产生,因此它的大小不会影响目标文件的大小。

  3 只读数据段:字符串就是放在这里的。

  C语言中的只读全局变量,只读局部变量,程序中使用的常量等会在编译时被放入到只读数据区。定义全局变量const char a[100]={"ABCDEFG"};将生成大小为100个字节的只读数据区,并使用“ABCDEFG”初始化。

  4 代码段:代码段由各个函数产生,函数的每一个语句将最终经过编绎和汇编生成二进制机器代码。在执行的过程中CPU的计数器指向代码段的每一条机器代码,开始由处理器依次执行。

  C语言在编译和链接后,将生成代码段(Text)、只读数据段和初始化数据段。在运行时,在程序运行之前,将动态生成未初始化数据段(BSS),在程序的运行时还将动态形成堆(Heap)区域和栈(Stack)区域。

在全局范围中定义的对象(即在所有函数之外定义的对象),它的构造函数在文件中的所有函数(包括main函数)执行之前调用。但如果一个程序中有多个文件,而不同的文件中都定义了全局对象,则这些对象的构造函数的执行顺序是不确定的。当main函数执行完毕或调用exit函数时(此时程序终止),调用析构函数。

class A
{
   public:
             A(int i){a = i; cout << "A"<< a <<endl;}
             ~A(){cout << "GOODBYE"<< a <<endl;}
};
A a(1);
int main()
{
    A (2);
    cout<< "this is main"<< endl;
    return 0;
}
A1
A2
this is main
GOODBYE 2
GOODBYE 1




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值