写在前面:小生纯业余选手,开此博仅仅是为了积累,纯当笔记来用。如有看官光临小生博客,请不要相信我的代码就是正确的。如果您发现了错误也恳请耽误您一点时间,请您在下面指出来,不胜感激!
如果发现一些笔记的说法完全是错误的请建议我删除!
内存管理笔记(本次暂且用图片)
内存从物理上来讲:内存就是一堆硬件,存储着若干状态和状态的组合,来唯一的代表一些数据。
从操作系统内核上讲:操作系统是用来管理硬件资源的软件,内核把物理内存与客户(应用程序)隔离开,客户是通过内核来存储数据,而不直接访问物理内存。于是,就有了虚拟地址,然后内核把虚拟地址映射到物理地址。虚拟地址就是一个整型的编号,当客户通过malloc获取内存地址实际上是虚拟地址。当然,能被分配的虚拟地址必须是通过内核映射到物理地址的虚拟地址,否则,该虚拟地址是不能使用的。
从程序上来看就是STL,数据结构,智能指针,malloc,new等等。
*各个独立的程序是不能相互访问他们各自的内存空间的,它们可能拥有相同的虚拟地址,但是虚拟地址所映射到实际物理内存时不一样的!
首先,分析一个程序各部分分配在那些内存区域
如下截图来自/proc/{pid}/maps
由以上程序可以分析得出,代码中不同位置的变量存放在内存的那些区域,当然这里是通过我们已经知道的关于变量存放区域的知识逆向分析出各个地址块到底是代码区(函数,全局常量)还是全局区(全局变量静态全局,静态局部)还是堆区(malloc分配得到)还是栈区(局部变量,局部常量)
*代码区内存的权限比其他内存块要多一个x(可执行)权限,所以很容易判断出代码区。
上面用cout输出的函数地址看不懂,用printf()得到的地址可以看出函数是在代码区。