字符串
不可变 -> 可变
可变 -> 可变
可变 -> 不可变
不可变 -> 不可变
由以上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,相当于一直强引用着.