iOS-深复制(mutableCopy)与浅复制(copy)

浅复制:只复制指向对象的指针,而不复制引用对象本身。对于浅复制来说,A和A_copy指向的是同一个内存资源,复制的只是一个指针,对象本身资源还是只有一份(对象引用计数+1),那如果我们对A_copy执行了修改操作,那么发现A引用的对象同样被修改了。

深复制就好理解了,内存中存在了两份独立对象本身。

在Objective-C中并不是所有的对象都支持Copy,MutableCopy,遵守NSCopying协议的类才可以发送Copy消息,遵守NSMutableCopying协议的类才可以发送MutableCopy消息。

(一).对非集合类对象的copy操作:

在非集合类对象中:

1、对immutable对象进行copy操作,是指针复制,mutableCopy操作时内容复制;

2、对mutable对象进行copy和mutableCopy都是内容复制。

用代码简单表示如下:

[immutableObject copy] //浅复制

[immutableObject mutableCopy] //深复制

[mutableObject copy] //深复制

[mutableObject mutableCopy] //深复制

代码:

NSString*string =@"origin";

NSString*stringCopy = [stringcopy];//浅复制复制后的对象不可变

NSMutableString*mStringCopy = [stringmutableCopy];//深复制复制后的对象可变

NSLog(@"%p - %p - %p", string, stringCopy, mStringCopy);

2016-03-03 14:56:44.068 Copy[18197:493711] 0x100001080 - 0x100001080 - 0x1003003e0

查看结果:stringCopy和string的内存地址是一样的,mStringCopy和string的内存地址是不一样的。

NSMutableString*string2 = [NSMutableStringstringWithString:@"origin2"];

NSString*stringCopy2 = [string2copy];//深复制复制后的对象不可变

NSMutableString*mStringCopy2 = [string2mutableCopy];//深复制复制后的对象可变

NSLog(@"%p - %p - %p", string2, stringCopy2, mStringCopy2);

2016-03-03 14:56:44.068 Copy[18197:493711] 0x100103920 - 0x326e696769726f75 - 0x1001039b0

查看结果:mStringCopy2、stringCopy2和string2的内存地址都是不一样的。

(二)、集合类对象的copy与mutableCopy

[immutableObject copy] //浅复制

[immutableObject mutableCopy] //单层深复制

[mutableObject copy] //单层深复制

[mutableObject mutableCopy] //单层深复制

代码:

NSArray*array =@[@[@"a",@"b"],@[@"c",@"d"]];

NSArray*copyArray = [arraycopy];//浅复制复制后的对象不可变

NSMutableArray*mCopyArray = [arraymutableCopy];//单层深复制复制后的对象可变

NSLog(@"%p - %p - %p", array, copyArray, mCopyArray);

2016-03-03 14:56:44.069 Copy[18197:493711] 0x100600450 - 0x100600450 - 0x1006038e0

查看结果:copyArray和array的内存地址是一样的,mCopyArray和array的内存地址是不一样的。

NSMutableArray*array2 = [NSMutableArrayarrayWithObjects:[NSMutableStringstringWithString:@"a"],@"b",@"c",nil];

NSArray*copyArray2 = [arraycopy];//单层深复制复制后的对象不可变

NSMutableArray*mCopyArray2 = [arraymutableCopy];//单层深复制复制后的对象可变

NSLog(@"%p - %p - %p", array2, copyArray2, mCopyArray2);

2016-03-03 14:56:44.069 Copy[18197:493711] 0x100106fd0 - 0x100600450 - 0x100107020

查看结果:mCopyArray2、copyArray2和array2的内存地址都是不一样的。

(三)、自定义对象的copy

.h文件

@interfaceComplex :NSObject<NSCopying>//采用NSCoping协议,实现深层拷贝

{

int_real;

int_imaginary;

}

- (void)setReal:(int)real andImg:(int)img;

- (void)Show;

@end

.m文件

@implementationComplex

-(void)setReal:(int)real andImg:(int)img

{

_real= real;

_imaginary= img;

}

-(void)Show

{

NSLog(@"%d+%di",_real,_imaginary);

}

#pragma mark - NSCopying

-(id)copyWithZone:(NSZone*)zone

{

Complex*p = [ComplexallocWithZone:zone];//申请一块Complex的内存

[psetReal:_realandImg:_imaginary];//拷贝数据

returnp;

}

@end

NSLog(@"------------浅拷贝--------------");

Complex*com1 = [[Complexalloc]init];

[com1setReal:12andImg:3];

//浅拷贝

Complex*com2 = com1;

[com1Show];

[com2Show];

2016-03-03 15:23:43.627 Copy[18424:509266] 12+3i

2016-03-03 15:23:43.627 Copy[18424:509266] 12+3i

[com1setReal:3andImg:5];// com1重新赋值

[com1Show];

[com2Show];

// com1重新赋值,com2随之变化

2016-03-03 15:23:43.627 Copy[18424:509266] 3+5i

2016-03-03 15:23:43.627 Copy[18424:509266] 3+5i

[com2setReal:10andImg:5];// com2重新赋值

[com1Show];

[com2Show];

// com2重新赋值,com1也随之变化

2016-03-03 15:23:43.628 Copy[18424:509266] 10+5i

2016-03-03 15:23:43.628 Copy[18424:509266] 10+5i

NSLog(@"------------深拷贝------------");

Complex*comA = [[Complexalloc]init];

[comAsetReal:2andImg:3];

Complex*comB = [comAcopy];//深层拷贝,使用copy方法,但是前提必须实现NSCopying协议中的copyWithZone方法

[comAShow];

[comBShow];

2016-03-03 15:23:43.628 Copy[18424:509266] 2+3i

2016-03-03 15:23:43.628 Copy[18424:509266] 2+3i

[comAsetReal:3andImg:4];// comA重新赋值

[comAShow];

[comBShow];

// comA改变不引起comB变化

2016-03-03 15:23:43.628 Copy[18424:509266] 3+4i

2016-03-03 15:23:43.628 Copy[18424:509266] 2+3i

[comBsetReal:100andImg:2];// comB重新赋值

[comAShow];

[comBShow];

// comB改变不引起comA变化

2016-03-03 15:23:43.628 Copy[18424:509266] 3+4i

2016-03-03 15:23:43.628 Copy[18424:509266] 100+2i

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Objective-C 中,拷贝(Deep Copy)和拷贝(Shallow Copy)是用于复制对象的两种不同方式。 拷贝是指创建一个新的对象,该对象与原始对象共享数据的内存地址。换句话说,新对象只是原始对象的一个引用,对新对象的修改也会影响原始对象。在 Objective-C 中,可以使用 `copy` 方法来执行拷贝。 拷贝是指创建一个新的对象,并且复制原始对象的所有数据。这意味着新对象有自己的内存地址,对新对象的修改不会影响原始对象。在 Objective-C 中,可以使用 `mutableCopy` 方法来执行拷贝。 需要注意的是,拷贝只会复制对象本身,而不会递归地复制对象所包含的其他对象。如果需要对对象的所有数据进行递归复制,可以通过实现 NSCopying 协议来自定义拷贝操作。 下面是一个示例代码,演示了如何执行拷贝和拷贝: ```objective-c #import <Foundation/Foundation.h> @interface Person : NSObject <NSCopying> @property (nonatomic, copy) NSString *name; @end @implementation Person - (instancetype)copyWithZone:(NSZone *)zone { Person *copy = [[Person allocWithZone:zone] init]; copy.name = self.name; return copy; } @end int main(int argc, const char * argv[]) { @autoreleasepool { Person *person1 = [[Person alloc] init]; person1.name = @"John"; // 拷贝 Person *person2 = [person1 copy]; NSLog(@"person1: %@, person2: %@", person1.name, person2.name); // 输出:person1: John, person2: John // 拷贝 Person *person3 = [person1 mutableCopy]; person3.name = @"Emily"; NSLog(@"person1: %@, person3: %@", person1.name, person3.name); // 输出:person1: John, person3: Emily } return 0; } ``` 在上面的示例中,使用 `copy` 方法执行了拷贝操作,`mutableCopy` 方法执行了拷贝操作。注意,为了实现拷贝,我们在 `Person` 类中遵循了 NSCopying 协议,并重写了 `copyWithZone:` 方法来自定义拷贝操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值