文章目录
一、C/C++内存分布
说明:
- 栈:又叫堆栈,非静态局部变量/函数参数/返回值等等,栈是向下增长的。
- 内存映射区(共享区):是高效的I/O映射方式,用于装载一个共享的动态内存库。用户可使用系统接口创建共享共享内存,做进程间通信。
- 堆:用于程序运行时动态内存分配,堆是可以上增长的。
- 数据区:存储全局数据和静态数据。
- 代码区:可执行的代码/只读常量。
对于这几个区域,有如下特点:
比如32位操作系统下,其虚拟内存(进程地址空间)只有4G(注:即使物理内存有8G,也是用不完的):
- 堆是很大的,内核空间大概1G,剩余的几个区域共3G,其中大部分都是堆的。
- 栈是很小的,Linux下一般只有8M左右。(所以递归调用太深,会导致栈溢出)
- 数据区和代码区也不是很大,因为。
👉请看下面这道题,理解不同的数据分别存放在内存的哪个区域?
int globalVar = 1;
static int staticGlobalVar = 1;
void Test()
{
static int staticVar = 1;
int localVar = 1;
int num1[10] = {
1, 2, 3, 4 };
char char2[] = "abcd";
char* pChar3 = "abcd";
int* ptr1 = (int*)malloc(sizeof(int) * 4);
int* ptr2 = (int*)calloc(4, sizeof(int));
int* ptr3 = (int*)realloc(ptr2, sizeof(int) * 4);
free(ptr1);
free(ptr3);
}
选项: A.栈 B.堆 C.数据段(静态区) D.代码段(常量区)
globalVar在哪里?C staticGlobalVar在哪里?C
staticVar在哪里?C localVar在哪里?A
num1 在哪里?A
char2在哪里?A *char2在哪里?A
pChar3在哪里?A *pChar3在哪里?D
ptr1在哪里?A *ptr1在哪里?B
二、C++内存管理方式
2.1 C语言 的动态内存管理方式
通过 malloc / calloc / realloc & free 库函数进行动态内存管理。
#include<stdlib>
int main()
{
// malloc开辟一块sizeof(int)个字节的空间
int* p1 = (int*)malloc(sizeof(int));
assert(p1);
free(p1);
p1 = nullptr;
// calloc可以对申请的内存空间的每个字节初始化为0
// calloc 等价于 malloc + memset(0)
int* p2 = (int*)calloc(4, sizeof(int)); // 为4个大小为sizeof(int)的元素开辟一块空间
assert(p2);
// realloc是对malloc和calloc开的空间进行扩容
int* p3 = (int*)realloc(p2, sizeof(int) * 4);
if (p3 != nullptr<