属性修饰符:
MRC:
assign:基本数据类型(当出现循环引用时,也要用assign)
retain:除Block和NSString外的其他对象
copy:一般用于NSString和Block
ARC:
strong:默认
weak:多用于ui和解决循环引用
copy:用于NSString和Block
assign:非OC对象
既然NSString
属于OC
对象,那么我们先不使用Copy
修饰,在ARC
模式下,声明的属性默认是strong
修饰, 接下来就演示strong
修饰NSString
的后果
1.使strong
修饰一个NSString
对象
2.在viewDidLoad
中实例化一个空的可变字符串
3.给可变字符串添加内容
4.让strong
修饰的NSString
对象指向可变字符串对象
5.继续向可变字符串中添加内容
6.打印strong
修饰的NSString
对象结果
#import "ViewController.h"
@interface ViewController ()
/* 为什么字符串使用copy修饰?
这里先不使用copy修饰,NSString是OC对象,并且是ARC模式,所以先使用strong来修饰演示
*/
@property (nonatomic,strong) NSString *name;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
NSMutableString *str = [NSMutableString string];
[str appendString:@"xiaoming"];
self.name = str;
[str appendString:@"xiaogang"];
NSLog(@"%@",_name);
}
@end
结果为:
2016-07-31 13:51:35.218 字符串使用copy修饰[9376:241671] xiaomingxiaogang
结果分析:
如果使用strong
修复NSString
类型属性
self.name
指向可变字符串对象的地址
当可变字符串内容发生变化时,self.name
相对应的也发生变化
使用copy
修饰后,将可变字符串重新拷贝一份,重新开辟内存空间,修改mutableString
的值,不会对self.name
造成影响
2016-07-31 14:22:00.070 字符串使用copy修饰[9548:269772] str:0x7fa871488750,name:0xa006412031812da8
2016-07-31 14:22:00.074 字符串使用copy修饰[9548:269772] str:0x7fa871488750,name:0xa006412031812da8
2016-07-31 14:22:00.074 字符串使用copy修饰[9548:269772] xiaoming
刚刚的演示,我使用了NSMutableString
(可变字符串),对mutableString
执行copy
操作,属于深拷贝,所以开辟的新内存空间,如果使用的是NSString
(不可变内存),对NSString
进行copy
属于浅拷贝,不会开辟新的内存空间,是不是就不会出现这个问题了呢?
接下来使用NSString
来进行演示,将属性修饰符再次改回strong
#import "ViewController.h"
@interface ViewController ()
/* 为什么字符串使用copy修饰?
这里先不使用copy修饰,NSString是OC对象,并且是ARC模式,所以先使用strong来修饰演示
*/
@property (nonatomic,strong) NSString *name;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
NSString *str = [NSString string];
str = @"xiaoming";
self.name = str;
NSLog(@"str:%p,name:%p",str,_name);
str = @"xiaogang";
NSLog(@"str:%p,name:%p",str,_name);
NSLog(@"%@",_name);
}
@end
打印结果:
2016-07-31 14:17:19.127 字符串使用copy修饰[9499:264651] str:0x10c937060,name:0x10c937060
2016-07-31 14:17:19.128 字符串使用copy修饰[9499:264651] str:0x10c9370a0,name:0x10c937060
2016-07-31 14:17:19.128 字符串使用copy修饰[9499:264651] xiaoming
从结果上看,重新设置str
的值后,self.name
确实没有受到影响
原因:
将之前的可变字符串变为不可变字符串,因为NSString
不支持append
添加操作,我这里的两次str
赋值操作,其实是让str
重新指向了一片内存空间,并不是修改了str
原本内存中的值
(OC
中对象即指针,实际上存储的是内存地址,self.name = str
; 实际是将str
存储的@"xiaoming"
这块地址给了self.name
, self.name
还指向着@"xiaoming"
)
所以改变str
的指向后, self.name
的指向并没有改变,输出没有受到影响