iOS 内存管理总结

941 阅读2分钟

参考

ke.qq.com/course/3145…

OC对象的内存管理

在iOS中,使用引用计数来管理OC对象的内存。

一个新创建的OC对象引用计数默认是1,当引用计数减为0,OC对象就会销毁,释放其占用的内存空间。

调用retain会让OC对象的引用计数+1,调用release会让OC对象的引用计数-1。

内存管理经验总结

当调用alloc、new、copy、mutableCopy方法返回了一个对象,在不需要这个对象时,要调用release或者autorelease来释放它。

想拥有某个对象,就让它的引用计数+1;不想再拥有某个对象,就让它的引用计数-1。

引用计数的存储

引用计数存在优化过的isa共用体的extra_rc中,当数字过大,共用体分配的extra_rc的内存不够用了,共用体的has_sidetable_rc就会变为1,然后引用计数就会存储在SideTable中的refcnts散列表中。

内存布局

内存地址从低到高,一共分为代码段,数据段,堆,栈。

代码段: 存放编译之后的代码。

数据段: 1.字符串常量:比如 Nsstring *str=@"123" 2.已初始化数据:已初始化的全局变量、静态变量等。 3.未初始化数据:末初始化的全局变量、静态变量等。

堆: 通过alloc、 malloc、 calloc等动态分配的空间。 分配的内存空间地址越来越大。

栈: 函数调用开销,比如局部变量。 分配的内存空间地址越来越小。

深拷贝、浅拷贝、copy、mutableCopy

深拷贝: 内容拷贝,产生新的对象。

浅拷贝: 指针拷贝,没有产生新的对象。

copy: 不可变拷贝,产生不可变副本。

mutableCopy: 可变拷贝,产生可变副本。

image.png
结论:

1.对字符串,字典,数组进行mutableCopy操作,属于深拷贝,并且会生成一个新的可变对象。

2.对可变字符串,字典,数组进行copy操作,属于深拷贝,并且会生成一个新的不可变对象。

3.对不可变字符串,字典,数组进行copy操作,属于浅拷贝,不会生成一个新的对象。

补充

1.refcnts是一个存放着对象引用计数的散列表。

2.本文如有侵犯隐私或其他请联系我,我将在第一时间整改或删除。