Unix C学习笔记4 虚拟地址空间,内存壁垒,段错误

虚拟地址空间

 

hello.c,a.out都是在磁盘/硬盘上的文件,执行时操作系统内核调度管理,找到磁盘上的a.out二进制文件,复制到内存中,存放地址不一定连续,cpu再从内存中读取数据执行

内存是有限的,如同时运行多个软件,QQ+游戏,内存不够再运行其他程序时,内核会在磁盘中找一块没有被用的空间,将内存中暂时不用的指令和数据(如QQ不使用)存在磁盘中,称为页面的换出。QQ要继续使用时,再将指令和数据拿回内存,称为页面的换入

内存是电介质,磁盘是磁介质,所以用到磁盘充当内存时电脑会变慢

linux下称磁盘中充当内存角色的区域称为交换分区,windows下称为虚拟内存

磁盘随着年数增加,读写速度会下降

 

看到的地址不一定是物理内存的地址

内存映射表记录虚拟地址与物理地址之间的转换

内存映射表在进程进行时才会被操作系统维护,也存储在内存中,进程结束时被释放

虚拟地址没有被分配内存时,内核找不到对应物理地址,就会报错:段错误核心已转储

虚拟地址相当于物理地址的别名

野指针:通过该虚拟地址可以找到对应的物理地址,但这段内存可能属于别的进程

 每个进程都认为自己有4G大小的虚拟地址空间,只是进程自己认为的,实际上在虚拟地址对应的物理内存上可能只占用了一点点,进程实际占了多少内存,就占了多少物理内存

虚拟地址:程序加载到内存后,物理内存对应的虚拟地址

虚拟地址空间:虚拟地址的范围称为虚拟地址空间,32位为0x00000000到0xFFFFFFFF,64位位0x0000000000000000到0xFFFFFFFFFFFFFFFF

虚拟地址空间布局:如上图

内存壁垒

假设a.out与b.out有同样的虚拟地址0x1234,a.out通过0x1234存入一个值,b.out不能通过该地址取出该值。两进程有不同的虚拟地址表,相同的虚拟地址映射不同的物理内存

如一号楼的A单元101与二号楼的A单元101

进程的执行是相互交替的,a.out执行一会,b.out再执行一会

段错误

自己编的虚拟地址,操作系统并没有分配物理内存

物理内存虽然被释放,但指针存储的值是虚拟地址,只是输出该地址

 

free表示该物理内存不再为该进程所使用,进程失去内存所有权,但还能通过指针访问,同时其他进程或者内核的数据有可能被放入该内存,此时进程访问了不属于自己的内存,容易造成问题

(房子已经卖了,还留着把钥匙)

free后要把p置空,防止出现野指针,防止对指针进行误操作,又访问了被释放的存储区

 

 重复释放,报错

 

此时的i为只读内存,会出现段错误

const int i = 0;常局部变量,属于栈区

const static int i = 0;常静态局,属于代码区,只读内存指代码区,又叫只读常量区

*(int*)&i = 1;强转后,变量i的const属性还在,强转时通过i的地址对i访问的时候不带const属性,不以const int*的方式访问,而是以int*的方式访问。强转转的是对i的访问方式,而不是改变i的属性

int i  (char)i,i的类型没有变,只是访问时以char的方式访问,只访问4个字节中的1个字节

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值