iOS DeveloperiOS学习

OC copy muatbleCopy

2017-03-29  本文已影响0人  fordG

看了下OC的 copy和mutableCopy记录下:

//    #define address(obj) NSLog(@"%p", obj);

/*

不可变copy浅拷贝(指针拷贝), mutableCopy深拷贝(值拷贝)

*/

//    NSString *a = @"123";

//    address(a)

//    address(a.copy)

//    address(a.mutableCopy)

/*

可变的copy, mutableCopy都是深拷贝,都是值拷贝,内存拷贝

*/

//    NSMutableString *a = [NSMutableString stringWithFormat:@"123"];

//    address(a)

//    address(a.copy)

//    address(a.mutableCopy)

/*

NSArray object只是指针的拷贝,不会拷贝值,本身的拷贝,copy浅拷贝, mutableCopy深拷贝

*/

//    NSArray *arr = @[@"123",@"345"];

////    address(arr)

//    address(arr.firstObject)

//

//    NSArray *arr2 = arr.copy;

////    address(arr2)

//    address(arr2.firstObject)

//

//    NSArray *arr3 = arr.mutableCopy;

////    address(arr3)

//    address(arr3.firstObject)

/*

NSMutableArray 本身的copy, mutableCopy都是深拷贝, object只是指针拷贝

*/

//    NSMutableArray *arr = [NSMutableArray arrayWithObjects:@1,@2,@3, nil];

//    address(arr)

//    address(arr.firstObject)

//

//    NSMutableArray *arr2 = arr.copy;

//    address(arr2)

//    address(arr2.firstObject)

//

//    NSMutableArray *arr3 = arr.mutableCopy;

//    address(arr3)

//    address(arr3.firstObject)

/*

1:所谓浅拷贝,实际上是这样的:一个指针,指向一块内存1, 对这块内存进行浅拷贝,其实就是提取了 这块内存的地址,然后把他给另外一个 8字节的指针类型存放,这时候浅拷贝的意义就是 多了一个8字节(64位系统)的指针,同样指向这块内存,综合来看,内存并未有任何变化,但是现在有两个指针指向它,

并且这两个指针存放的值一样,就是这块内存的首地址,但是 这两个指针本身的值(8字节)不一样,所以就是:两个不同的指针指向同一块内存

2:所谓深拷贝:实际上是这样: 一个指针,指向了一块内存1,对这块内存1进行深拷贝,首先,我要开辟一块跟这块内存一样大的内存2,然后把内存1里面的值(请注意,这里是值)丝毫不差的拷贝到内存2里面去,然后再搞一个指针,指向内存2,这时候来看,有两块内存了,并且两块内存毫不相干,只是里面的值一样而已。 修改其中一个并不会影响另外一个

3:完全拷贝:深拷贝 请记住是内存里面的值拷贝,如果内存里面放的都是一些基本类型,比如char int long 等等,无所谓, 但如果是指针类型或者对象类型,深拷贝只能保证拷贝到第一层,也就是如果有指针类型,他只拷贝了指针的值。

想象一下:如果内存1里面有个指针,指向了一个对象a, 这时候对内存1进行深拷贝得到了内存2,我们知道深拷贝是值拷贝,这时候内存2里面同样有一个指针指向了对象a ,因为他俩存的指针类型的值是一摸一样的,所以深拷贝不能保证其内部指针指向的对象的拷贝。 这也就是为什么深拷贝的对象必须也要实现nscopy协议 才能实现第二层也能实现深拷贝,否则就是浅拷贝

总结:浅拷贝一定是这块内存首地址指针拷贝,深拷贝一定是这块内存所有值(包括指针的值)的值拷贝。如果你想实现完全拷贝,那么请让你内存中所有指针所指向的对象实现nscopying协议,否则深拷贝只能完全拷贝第一层,拷贝不到第二层

*/

上一篇 下一篇

猜你喜欢

热点阅读