C/C++内存分布 数组传参 数组 指针 字符串

C/C++内存分布 数组传参 数组 指针 字符串

最近发现原本以为自己记得很牢靠的知识点也会随着时间的推移而逐渐模糊,所以决定通过博客把一些知识点汇总记录一下,不管是加深印象还是便于翻阅,总归是好事。

C++内存分布

C++内存由高地址到低地址依次是栈区、堆区、静态区、常量区、程序代码区:

栈 stack :
向下增长,用于存放函数内的局部变量,形参和函数返回值。系统会自动管理栈区的内存分配与回收。

堆heap :
主动申请内存,最终也由程序员负责主动释放(向上增长,由程序员主动申请和释放,容易造成内存泄漏)。

全局/静态区 :程序一经编译好,该区域便存在。C++编译器会自动给全局变量静态变量赋初值,在程序的整个生命周期终都占用这片内存。

常量存储区 :
存放不可修改的常量(大家都知道C++可以通过非正当手段修改)。

程序代码区:
用来存放程序二进制代码的区域,不可修改,可执行。

C内存分布

栈 stack :
栈里的数据自动分配释放,不需要程序员额外操作,主要存放局部变量、函数参数,函数结束,栈释放。

堆heap :
用malloc()/calloc()/realloc()分配空间,由free()释放。忘记free会造成内存泄漏。

全局/静态区 :
该区域在程序编译完成后便存在。全局变量和静态变量和未初始化与初始化的放在相邻的两个区域(.bss段和.data段)程序结束时释放。

字符串常量区 :
用来存放字符串常量的地方,程序结束时释放;

程序代码区:
用来存放程序二进制代码的区域,不可修改,可执行。

数组传参 数组类型

数组作为参数传递时会被转化为指针(编译器行为):
void func(char ch[8],int p)
此时ch类型为char
,p的类型为int*,都为指针,并且此时数组大小8并没有意义,写于不写都一样。
数组存放内容类型及其本身所占大小决定了数组类型:
char ch1[2];
char ch2[4];
ch1的类型就是char[2],ch2的类型是char[4]

字符串

字符串作为数组初始值的时候不是常量:
char str[] = “abc123”;
此时定义的时字符数组,且进行了初始化,如果是全局变量则存放在全局区,如果是局部变量则放在栈区。

字符串"abc123"赋值给字符指针时是常量:
char* str = “abc123”;
指针作为变量只是指向一片内存,而此时字符串显然是放在常量区的。

字符串指针:
双引号加到字符串上编译器是会做相应解释的:
1.在常量区申请空间存放字符串
2. 在字符串末尾加’/0’
3.返回地址

发布了5 篇原创文章 · 获赞 1 · 访问量 137

猜你喜欢

转载自blog.csdn.net/weixin_42275611/article/details/102908178