2021-09-12
2021/9/12 23:09:07
本文主要是介绍2021-09-12,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
关于进程的地址空间:TEXT,DATA,BSS,HEAP,STACK
现代操作系统对每个进程都分配了完整的虚拟内存地址空间。进程会把整个地址空间分成多个区间来使用。 程序员最为熟悉的两个区间莫过于堆和栈。然而还有其他的内存区间来存储代码、静态、全局变量等等。 本文来总结一下这些内存区间到底存的是哪些东西。先看图:
虚拟内存技术使得每个进程都可以独占整个内存空间,地址从零开始,直到内存上限。 每个进程都将这部分空间(从低地址到高地址)分为六个部分:
TEXT段:整个程序的代码,以及所有的常量。这部分内存是是固定大小的,只读的。
DATA段,又称GVAR:初始化为非零值的全局变量。
BSS段:初始化为0或未初始化的全局变量和静态变量。
HEAP(堆空间):动态内存区域,使用malloc或new申请的内存。
未使用的内存。
STACK(栈空间):局部变量、参数、返回值都存在这里,函数调用开始会参数入栈、局部变量入栈;调用结束依次出栈。
其中堆空间和栈空间的大小是可变的,堆空间从下往上生长,栈空间从上往下生长。
由于常量存储在TEXT段中,所有对常量的赋值都将产生segment fault异常。
可以认为BSS段中的所有字节都是0。因为未初始化的全局变量、静态变量都在BSS段中, 所以它们都会被初始化为0,同时类的成员变量也会被初始化为0,但编译器不保证局部变量的初始化。
上面说栈(STACK)是从上到下(高地址到低地址)分配的,而且我们知道, 函数的局部变量的空间是在进入函数体后才分配的,在栈空间里。
来个例子来看看吧!
int main(){
char a=0, b=0;
int p = (int)&b;
*p = 258;
printf("%d %d", a, b);
return 0;
}
输出是
1 2
a, b属于局部变量,存储在栈空间中,先分配a的地址,再分配b的地址。因为栈是从上往下生长的,所以b的地址比a低一个字节。 然后对b的地址进行赋值258(int是4字节,十六进制表示是0x00 00 01 02)。最后1字节0x02赋值给了b,接下来1字节0x01赋值给了a。
来源于:链接
这篇关于2021-09-12的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-11cursor试用出现:Too many free trial accounts used on this machine 的解决方法
- 2025-01-11百万架构师第十四课:源码分析:Spring 源码分析:深入分析IOC那些鲜为人知的细节|JavaGuide
- 2025-01-11不得不了解的高效AI办公工具API
- 2025-01-102025 蛇年,J 人直播带货内容审核团队必备的办公软件有哪 6 款?
- 2025-01-10高效运营背后的支柱:文档管理优化指南
- 2025-01-10年末压力山大?试试优化你的文档管理
- 2025-01-10跨部门协作中的进度追踪重要性解析
- 2025-01-10总结 JavaScript 中的变体函数调用方式
- 2025-01-10HR团队如何通过数据驱动提升管理效率?6个策略
- 2025-01-10WBS实战指南:如何一步步构建高效项目管理框架?