内存管理

一、进程空间

  • MMU

蓝色标出了真实使用的内存大小


蓝色标出了真实使用的内存大小

二、栈内存

  • 笔记
  • ulimit -a
    

栈的大小是10M,栈不能存放大量的数据,栈是用来数据交换

2.1 栈溢出

  • 数组开得过大
  • 递归层数过多

2.2 栈的发展方向

  • 高地址往低地址发展

三、堆内存

3.1 堆的申请大小


  • 从低地址到高地址


四、堆内存的申请与释放

  • 在栈和堆中申请空间的对比——
代码

4.1 申请和初始化的最小单位均是字节

  • 数组类型在

所以我们使用memset,最后得到的10个数并不是1,而是一个很大的数字,因为每个数是4个字节,每个字节是01,所以就是十六进制的01010101,也就是十进制的16843009


  • 注意,pa本身是在栈上的,pa申请的东西是在堆上的

4.2 小陷阱


这个程序这样写最后会导致程序崩溃,因为pa最后会偏离原先的位置,那么之前memset分配的40个字节就不再与现在的pa适配,最后就会导致崩溃,所以如果要这样写,提前拷贝一份即可——

4.3 calloc的使用

  • 包装了一个memset,自动初始化

五、realloc的使用

  • 局部变量在栈上这句话是不对的

auto类型修饰的局部变量在栈上,static修饰的局部变量不在栈上

  • 递归会爆栈的原因是会不断调用函数,调用函数就需要开辟新的空间,从函数返回才能释放掉这片空间,但是递归层数太多的时候空间一定不会释放掉,就会导致不断在开辟新的空间

  • malloccalloc调用失败都是返回NULL,区别是calloc会初始化。

5.1 用于扩容的realloc

  • 需要注意的问题,如果扩容的时候,指针ptr指向的位置后面还有多余的空间,那么ptr指向的位置不变,直接在原先空间的后面再扩容即可。但是如果原先位置后面的空间不够扩容,那么ptr将会更换位置,重新指向一片新的空间,然后申请足够的内存来实现扩容——


比如上面的newPa是可能和pa不相等的

  • 当然也可以这么写

5.2 free的使用

  • free的使用不用指定字节数,因为malloc()在使用的时候申请了多少个字节后台是有记录的——


任意+1-1会导致程序崩溃

六、服务器导致的内存泄漏


代码

七、堆内存的使用

7.1 置空很重要


申请内存,判断是否申请成功,strcpy则对应的使用,然后free释放,然后pc = NULL则是置空——
置空的重要性

7.2 谁申请谁释放

  • 不然很容易会double free——


main()函数中申请的就main()函数中释放

7.3 开放的地址空间

  • 对象的地址到不同的作用域,可依据地址修改地址所指向对象的内容,本质是地址空间是开放的

7.4 堆与栈空间的返回

  • 栈上的数值和地址是可以返回的
  • 但是栈上的空间是不可以返回的
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 谨记 人生有两条路,一天需要用心走,叫做梦想;一条需要用脚走,叫做现实。心走的太快,会迷路的;脚走的太快,会摔倒的...
    长风留言阅读 11,154评论 7 16
  • 内存管理 总的来说,包括内存管理和虚拟内存管理。内存管理包括程序装入等概念、交换技术、连续分配管理方式和非连续分配...
    楚_kw阅读 11,992评论 0 5
  • 要了解ios内存管理范围,首先我也应该了解一下内存的几大区域 1、栈区(stack) — 由编译器自动分配释放...
    赵哥窟阅读 2,761评论 0 1
  • 5.1计算机体系结构和内存层次 计算机体系结构 内存层次 操作系统的内存管理 存储管理要达到效果是抽象,把线性的物...
    龟龟51阅读 4,954评论 0 1
  • 虚拟内存1.1. 为什么要使用虚拟内存技术1.2. 理论前提1.3. 虚拟内存实现1.4. 页机制1.5. MMU...
    墨染书阅读 14,129评论 3 33