拷贝通常有浅拷贝、深拷贝、写时拷贝,本章就写时拷贝做出详细分析,数据到底是如何存储的
问题引入(写时拷贝原理)
运行结果
由运行结果可知,同一地址但所存储的值却不一样,看来真正存储数据的另有其人!!!!!!
事实上我们所看到表示i地址的是虚拟地址空间,真正存储i值的是物理空间。fork创建子进程后,子进程会对父进程作出浅拷贝,只有真正(修改)写的时候才会在物理内存为自己开辟一块空间来存储自己修改后的值,但虚拟地址并不会改变。这就是写时拷贝,这就解释了同地址不同值得原因。
存储管理方式
由于每一个进程分配的空间是连续的,如果采取的存储管理方式不恰当的话,会产生大量的内存碎片,进而导致内存的利用率过低。例如
物理内存的大小为16M,当再出现一个进程C所需要的空间为8M时,则无法申请到内存,那么如果进程A结束后,尽管进程A的内存回收释放后,进程C仍然无法成功申请,这就导致进程A释放的空间无法有效利用。这就导致了内存碎片。故采取合理的内存管理方式很关键。内存管理方式有分段式、分页式、段页式。
分段式
分段式便于编译器对内存进行管理,通过段号可以直接找到物理段的起始地址,并且加上段内偏移即可找到对应的物理地址
分页式
分页式将虚拟地址空间和物理地址空间分的更小,使得内存的分配更加灵活,实现了数据在内存上的离散存储,提高了内存的利用率。除此之外,页表中还有权限控制位等,提高了内存安全访问控制。
段页式
段页式访问存储结合了分段式和分页式而形成的管理方式,结合了以上两种的管理方式的优点。