您的位置:首页 > 运维架构 > Linux

【linux】进程存储管理

2015-07-23 20:14 411 查看
看《Linux高级程序设计》的笔记

设有一个hello的可执行文件

①显示该文件的基本信息

ls hello -l




②文件基本情况

file hello




③列出文件的存储区域情况

size hello




text(代码区): 存放代码和有const修饰的变量和字符串常量。

data(静态数据/全局初始化数据区):存放已经被初始化的全局变量和静态变量(有const修饰的除外)。

bss(未初始化数据区):存放未初始化的全局变量和静态变量。

dec(十进制总和)/hex(十六进制总和):总大小

全局变量的声明和使用:

方法① 在头文件中定义了全局变量:其他文件通过引用头文件使用该变量。

方法② 在源文件中定义了全局变量: 其他文件通过extern关键字来访问。

字符串常量:

如果在同一个文件中有char * a = "hello", char * b = "hello", char * c = "hello" 则这三个指针会指向同一个存储区,即只有一个”hello"字符串常量。

如果在文件1中有char * a = "hello", 文件2中有char * b = "hello", 这两个指针指向不同的存储空间,即每个文件都有一个“hello"字符串常量。

栈和堆的区别:

①管理方式不同:栈由操作系统自动管理(也可以用alloca来在栈上显示的分配空间);堆由程序员手工控制

②空间大小不同:栈从高地址向下扩展,是连续的内存区域,最大容量系统预先规定;堆向高地址扩展,是不连续的内存区域,系统用链表来存储空闲内存地址的,链表的遍历方向是由低地址向高地址。

③产生的碎片不同:频繁的malloc/free(new/delete)会造成内存空间的不连续,形成大量的碎片,使程序效率降低。栈一定是连续的内存空间。

④分配效率不同:栈有操作系统底层支持,快;堆靠C函数库提供,机制复杂,慢。

在释放内存后,把指针设为NULL的好处:

①后面对该指针的访问将立即失败

②后面的代码如果出现对指针的二次释放不会造成程序的崩溃,只是free函数失败。

内存动态申请函数

①malloc/free (new/delete)

②realloc 更改已经配置的内存空间 返回新分配的空间地址。

如果当前内存段后面的空间够用,则直接扩展这段内存,返回原地址

如果当前内存段后面空间不够用,则找到第一个能够满足要求的内存块,并将目前数据复制到新的位置,并将原来地址释放(自己不用释放了),返回新地址

如果找不到满足的内存,返回NULL原地址还可以用

故不可以这样写 ptr = realloc(ptr, new_amount),因为如果分配失败会导致原来的空间不可获得

③calloc函数 是malloc的简单包装,把malloc的数据初始化为0

④alloca 在栈上分配空间,不用自己释放,系统自动释放

内存数据管理函数

1.memcpy() 复制内存 bcopy()类似

2.memmove() 复制内存的时候考虑了源地址和目的地址重叠的情况

3.memset() 初始化指定内存单元 bzero()实现类似功能,初始化s起始的n字节为'\0'

4.memchr() 在一段内存空间中查找某个字符第一次出现的位置

5.memcmp() 比较内存单元s1和s2起始位置的前n个字节是否相等
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: