浅析copy

2017-05-19  本文已影响81人  JessWang

字符串

不可变 -> 可变

可变 -> 可变

可变 -> 不可变

不可变 -> 不可变

由以上log日志可以得出

不可变 -> 可变  在copy之后,老字符串和新字符串的内存地址是一样的,所以在copy之后不会开辟出一块儿新的内存空间,为浅拷贝.

可变 -> 可变  在copy之后,老字符串和新字符串的内存地址发生了变化,是不一致的,所以在copy之后,新字符串独立申请出了一块儿新的内存空间,为深拷贝.

可变 -> 不可变 同 可变 -> 可变    不可变 -> 不可变  同 不可变 -> 可变

数组

可变 -> 可变

可变 -> 不可变

不可变 -> 不可变

不可变 -> 可变

由以上log日志可以看出:

可变 -> 不可变  会申请新的内存  内置对象  不会申请新的内存 

可变 -> 可变    会申请新的内存  内置对象  不会申请新的内存

不可变 -> 可变  不会申请新的内存 内置对象  不会申请新的内存

不可变 -> 不可变  不会申请新的内存  内置对象  不会申请新的内存

而字典也是如此 

有内置对象地址可以看出. 不管是数组还是字典,都只是对外置容器的copy,并没有实质性的对数组内部的元素进行copy,由此可以看出,数组和数组元素是两个东西.如果我们想强制性实现深copy.那么就需要具体到某个类中去实现NSCopying协议,按照自己的方法去执行深copy.

由此可以看出,赋值对象的时决定采用浅拷贝还是深拷贝,一般情况下尽量执行浅拷贝.

为什么字符串要使用copy

根据以上代码可以得出结论,如果字符串使用strong来修饰,当你创建一个可变的字符串,向name赋值的时候,如果你改变了str的值,那么name的值也会跟着改.但是如果用copy的话就不会有这个问题,互不影响,所以说在一定程度上保证了数据的安全性吧.

Block为什么要使用copy

由以上代码可以看出

全局的block是存储在代码区(存储方法或函数)

block内部访问外部变量,block本身是一个结构体,存储在栈区.但是栈区可能会被随时回收

如果对block进行一次copy操作的话,block就会成堆block,相当于一直强引用着.

上一篇 下一篇

猜你喜欢

热点阅读