源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

NSString属性何时用strong何时用copy?

  • 时间:2020-08-27 21:39 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:NSString属性何时用strong何时用copy?
[b]前言[/b] 我们在声明一个NSString属性时,对于其内存相关特性,通常有两种选择(基于ARC环境):strong与copy。那这两者有什么区别呢?什么时候该用strong,什么时候该用copy呢?让我们先来看个例子。 [b]代码验证[/b]
@property (nonatomic, strong) NSString *myStrongString;
@property (nonatomic, copy) NSString *myCopyString;
- (void)stringTest {
 NSMutableString *mutableStr = [NSMutableString stringWithFormat:@"https://"];
 self.myStrongString = mutableStr;
 self.myCopyString = mutableStr;
 NSLog(@"mutableStr:%p,%p", mutableStr,&mutableStr);
 NSLog(@"strongString:%p,%p", _myStrongString, &_myStrongString);
 NSLog(@"copyString:%p,%p", _myCopyString, &_myCopyString);
 //---------------分割线--------------------- 
 [mutableStr appendString:@"devthinking.com"];
 NSLog(@"strongString:%p,%p", _myStrongString, &_myStrongString);
 NSLog(@"copyString:%p,%p", _myCopyString, &_myCopyString);
}
[b]打印日志如下:[/b]
2016-11-09 14:14:18.532 DemoCollectOC[92929:1731791] mutableStr:0x60800026fe00,0x7fff549c9be8
2016-11-09 14:14:18.532 DemoCollectOC[92929:1731791] strongString:0x60800026fe00,0x7ff095402308
2016-11-09 14:14:18.533 DemoCollectOC[92929:1731791] copyString:0x6080004234a0,0x7ff095402310
2016-11-09 14:14:18.533 DemoCollectOC[92929:1731791] strongString:0x60800026fe00,0x7ff095402308
2016-11-09 14:14:21.039 DemoCollectOC[92929:1731791] copyString:0x6080004234a0,0x7ff095402310
[b]结论[/b]      1.myStrongString跟mutableStr的指向地址始终一样,都为0x60800026fe00,myCopyString跟mutableStr指向的地址不同,即为深copy,新开辟了一份内存;      2.赋值时,当原始字符串是mutable String时,存在此差异,当mutableStr变化时,myStrongString会随着改变,而myCopyString则不会。通常我们不想让其随着改变,故用copy属性较多;如果我们想其随着改变,则用strong。      3. 如果原始赋值字符串为string时,则用copy和strong属性是一样的。 [b]变量存储地址[/b] [list=1] [*]&取地址符,取出来的是变量的存储地址,如myStrongString myCopyString是存在堆里的,地址以0x7ff09开头,mutableStr为临时变量,是存在栈里的,以0x7fff5开头。 [/*] [*]直接p打印出来的地址,则是存储内容实际存在的地址,其实里面存储的还是地址,详细的请看下一节,但是我们可以用这个地址区间来判断存储的区域。[/*] [/list] [b]附:x/3gx查看对象内存[/b] 查看基本数据类型的内存时,可直接查看,16进制转化一下就可以,查看对象时,则不可以,这跟String的结构体是相关的: [img]http://files.jb51.net/file_images/article/201612/2016128104123648.jpg?2016118104138[/img] 以NSString为例
 NSString *str = @"a";
先打印出地址:
(lldb) p str
(__NSCFConstantString *) $0 = 0x0000000109b3aa30 @"a"
再用x/3gx命令查看内存:
(lldb) x/3gx 0x0000000109b3aa30
0x109b3aa30: 0x000000010bf3e348 0x00000000000007c8
0x109b3aa40: 0x0000000109b276db
再查看0x0000000109b276db中的地址即为字母a的Ascii码实际存在地址:
(lldb) p (char*)0x0000000109b276db
(char *) $2 = 0x0000000109b276db "a"
可以直接在变量上右键上打开view memory of “*str”, 这就打开memory查看,在Address里面输上0x0000000109b276db,即可查看每个字节的内容。 [img]http://files.jb51.net/file_images/article/201612/2016128104246867.jpg?201611810432[/img] [b]总结[/b] 以上就是这篇文章的全部内容,希望本文的内容对各位iOS开发者们能有所帮助,如果有疑问大家可以留言交流,谢谢大家对编程素材网的支持。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部