一、内存
静态内存:保存局部的static对象、类static数据成员、定义在任何函数之外的变量(全局变量)。static对象在使用之前分配,程序结束时销毁。
栈内存:保存定义在函数内的非static对象,栈对象程序运行时才存在。(保存局部变量和函数参数等)。
动态内存:堆(或者自由空间)进行动态分配,既程序运行时分配的对象。
常量存储区:存放常量字符串,程序结束后销毁。
动态内存分配:用new/delete(malloc/free)来分配动态内存,或者使用智能指针share_ptr和unique_ptr。
二、堆和栈的区别
- 管理方式不同:栈是由编译器自动申请和释放空间,堆是需要程序员手动申请和释放;
- 空间大小不同:栈的空间是有限的,在32位平台下,VC6下默认为1M,堆最大可以到4G;
- 能否产生碎片:栈和数据结构中的栈原理相同,在弹出一个元素之前,上一个已经弹出了,不会产生碎片,如果不停地调用malloc、free对造成内存碎片很多;
- 生长方向不同:堆生长方向是向上的,也就是向着内存地址增加的方向,栈刚好相反,向着内存减小的方向生长。
- 分配方式不同:堆都是动态分配的,没有静态分配的堆。栈有静态分配和动态分配。静态分配是编译器完成的,比如局部变量的分配。动态分配由 malloc 函数进行分配,但是栈的动态分配和堆是不同的,它的动态分配是由编译器进行释放,无需我们手工实现。
- 分配效率不同:栈的效率比堆高很多。栈是机器系统提供的数据结构,计算机在底层提供栈的支持,分配专门的寄存器来存放栈的地址,压栈出栈都有相应的指令,因此比较快。堆是由库函数提供的,机制很复杂,库函数会按照一定的算法进行搜索内存,因此比较慢。
三、new和malloc的区别
四、动态数组
int *pia = new int[10]; //10个未初始化的int
int *pia2 = new int[10](); //10个值初始化为0的int
int *psa = new string[10]; //10个空string
int *psa2 = new string[10]() //10个空string
delete [] pia; //释放pia