Code Bye

几个属性修饰的问题retain 和 copy

如果说retain只是一个指针copy 而 copy是一个指针和内容都copy的画。那如下例子怎么会不成立?

代码如下:
#import “ViewController.h”

@interface ViewController ()
@property (nonatomic, copy) NSString *nameCopy;
@property (nonatomic, retain) NSString *retainName;
@end

@implementation ViewController

– (void)viewDidLoad {
    [super viewDidLoad];
    NSString *string = @”xiaoming”;
    NSMutableString *string1 = [NSMutableString stringWithString:string];
    self.nameCopy = string1;
    self.retainName = string1;
    [string1 stringByAppendingString:@”xiaowang!!”];//改变内容
    
    NSLog(@”nameCopy = %@”,self.nameCopy);//这个不会变应该是xiaoming没错。
    
    NSLog(@”retainName = %@”,self.retainName);//这个打印值应该是xiaomingxiaowang
    
 但是打印的结果如下:
2015-04-02 09:12:27.452 TestCopyAndRetain[789:17553] nameCopy = xiaoming
2015-04-02 09:12:27.453 TestCopyAndRetain[789:17553] retainName = xiaoming
(lldb) 
}
以前只是知道这个道理,但是很少用,但是没认真深究,请问怎么解释?


5分
NSString和NSArray这些Foundation框架里的类型,如果对不是Mutable的String调用copy,等同于retain

10分
[string1 stringByAppendingString:@”xiaowang!!”];//改变内容,
其实没有改变内容:string1还是xiaoming.

for example:

NSString *errorTag = @”Error: “;
NSString *errorString = @”premature end of file.”;
NSString *errorMessage = [errorTag stringByAppendingString:errorString];


5分
copy:对于可变对象为深复制,引用计数不改变;对于不可变对象是浅复制,引用计数每次加一。始终返回一个不可变对象。
当我们copy的是一个不可变的对象时,它的作用相当于retain(cocoa做的内存优化)

mutableCopy:始终是深复制,引用计数不改变。始终返回一个可变对象。当我们使用mutableCopy时,无论源对象是否可变,副本是可变的,并且实现了真正意义上的拷贝

被邀请来回答问题,可是看不懂啊真心,不好意思。


CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明几个属性修饰的问题retain 和 copy