动态内存
内存一般可分为四个区域
<一> 全局数据区(静态区)
- 全局变量和静态变量存放在此. 里面细分有一个常量区, 字符串常量和其他常量也存放在此. 该区域是在程序结束后由操作系统释放.
<二> 代码区
- 这个区域存放函数体的二进制代码.也是由操作系统进行管理的
<三> 栈区
-
由编译器自动分配释放, 存放函数的参数值,局部变量等.
例如: 参数buf,参数bufsize和size都是存放在栈区.当函数执行完毕的时候,自动释放void recev(char* buf, int bufsize){int size;}
<四> 堆区
-
一般由程序员分配释放(动态内存申请与释放),若程序员不释放,程序结束时可能由操作系统回收
例如:下面的src所指向的内存空间就是在堆区char* src = (char*) malloc(sizeof(buf) * sizeof(10));
动态内存分配
<一> C语言 ( 函 数 )
-
malloc realloc calloc ( 动态分配 )
-
free ( 动态释放 )
注意:C语言和C++的动态内存分配,不可以混合使用。
<二> C++ ( 运算符 )
-
new ( 动态分配 )
-
delete ( 动态释放 )
-
两种用法
单个内存分配:(1) int *p = new int; //在堆区分配4个字节(2) int *p = new int(4); //在堆区分配4个字节,并初始化为4释放:delete p; //释放p所指的堆内存p=null; //将指针p赋空连续内存分配:int *p = new int[4]; //在堆区分配16个字节 初始化:memset(p,0,sizeof(int)*4)//逐字节赋0值释放:delete[] p; //释放p所指的堆内存p=null; //将指针p赋空
-
delete的两种用法
1、释放单个内存,直接delete;2. 释放连续内存 delete [];delete释放时注意:后面必须是堆区内存的首地址,如果堆区是连续内存,也只能是连续内存的首地址
-
二级指针
int **p4 = new int*;//在堆区分配4个字节做为int*类型,把首地址给到一个二级指针int b = 10;*p4 = &b;//对二级指针解一次引用,得到是堆区4字节,并把整数b的首地址放在堆区的4字节中**p4 = 123;//对二级指针解二次引用,得到的是b的首地址,并对这个首地址进行修改delete p4;
<三> 使用动态内存分配时注意事项:
-
1、内存分配未成功,却去使用它
int *pb; *pb = 10; 解决办法:习惯变量初始化;在使用指针之前习惯检查该指针是否为null
-
2、内存分配成功,但没有初始化就引用它
int *pb = new int; printf("%d\n",*pb);解决办法:习惯变量初始化;在使用指针之前习惯检查该指针是否为null
-
3、内存分配成功且也初始化了,但操作越界
int *pb = new int[4]; for(int i = 0; i < 4; ++i) pb[i] = (i + 1); for(int i = 0; i <= 4; ++i)printf("%d\n",pb[i]);解决办法:写代码自己留意,小心操作越界
-
4、忘记释放内存,造成内存泄漏
int *pb = new int[4]; pb出作用域;解决办法:习惯在动态内存分配时立马先写上逻辑的内存释放
-
5、释放了内存,却继续使用它
int *pb = new int; delete pb; printf("%d\n",*pb);