存储内存可以是全局变量,可以是栈,也可以是堆.
全局变量特点:编译好地址就明确了
栈的特点:当函数调用时,会在栈里分配空间,当函数调用完了,栈会被恢复.
以上两个都不需要释放内存空间,前者释放不了,后者用完了,就自动释放了.
而在堆中申请的空间得特别留意,当用完后需要告诉操作系统,这段空间不需要了,可以释放了.
在c++中 涉及到堆的函数都是成对的:一个申请 一个释放.
int* pi =(int*)malloc (sizeof(int)*1024);//1024个int. 对应的释放函数free
动态申请的东西,前面一定要用指针指着.
当有多个call 负责分配内存的话 如何分析关键函数call:
先把返回的指针拖到地址那里.然后进去单步跟,执行哪个call后,地址里面的数据变成了返回的内存地址,则说明那个是关键call
int* pi=new int; 创建一块int大小的空间,没有初始化. 对应的释放函数是delete
如果要在队里分配这个int,前面一定要用个指针指向它.在堆里分配的内存,返回来的是指向该内存的地址.
在c++里new的本质就是malloc,因为