博客
关于我
NSString的属性修饰使用copy和strong的区别
阅读量:379 次
发布时间:2019-03-05

本文共 733 字,大约阅读时间需要 2 分钟。

一、不可变字符串属性

@property (nonatomic, strong) NSString *strongedString;

@property (nonatomic, copy) NSString *copiedString;

当源不可变字符串改变时:

  • 使用strong修饰的属性由于取得的还是源不可变字符串地址,其值会跟随源字符串改变而改变。
  • 使用copy修饰的属性进行了浅拷贝,依然取得了源不可变字符串的地址,其值也会跟随源字符串改变而改变。

当源可变字符串改变时:

  • 使用strong修饰的属性由于取得的还是源不可变字符串地址,其值会跟随源字符串改变而改变。
  • 使用copy修饰的属性由于进行了深拷贝,取得了另一份内存地址,其值不会跟随源字符串改变。

二、可变字符串属性

@property (nonatomic, strong) NSMutableString *strongedString;

@property (nonatomic, copy) NSMutableString *copiedString;

当源字符串为不可变字符串时:

  • 使用strong修饰的属性由于取得的地址改变,源字符串不可变,其值不会跟随源字符串改变而改变。
  • 使用copy修饰的属性进行了深拷贝,源字符串不可变,其值不会随着字符串改变而改变。然而,对其使用appendString方法会造成闪退。

当源字符串为可变字符串时:

  • 使用strong修饰的属性的地址跟随源字符串地址,源字符串可变,其值会随着改变。
  • 使用copy修饰的属性进行了深拷贝,改变了地址,且为不可变字符串。然而,对其使用appendString方法会造成闪退。

可变字符串属性理解感觉不到位,待考究...

转载地址:http://hyhg.baihongyu.com/

你可能感兴趣的文章
MySQL(2)DDL详解
查看>>
MySQL(3)DML详解
查看>>
MySQL(4)运算符 | 关联查询详解
查看>>
MySQL(5)条件查询 | 单行函数 | 事务详解
查看>>
Mysql,group by分组查询、order by排序查询、join连接查询、union联合查询
查看>>
Mysql,sql文件导入和导出
查看>>
MYSQL:int类型升级到bigint,对PHP开发语言影响
查看>>
Mysql:mysql 5.X 报错 ERROR 1193 (HY000): Unknown system variable ‘validate_password_length‘
查看>>
MySQL:MySQL执行一条SQL查询语句的执行过程
查看>>
Mysql:SQL性能分析
查看>>
mysql:SQL按时间查询方法总结
查看>>
MySQL:什么样的字段适合加索引?什么样的字段不适合加索引
查看>>
MySQL:判断逗号分隔的字符串中是否包含某个字符串
查看>>
MySQL:某个ip连接mysql失败次数过多,导致ip锁定
查看>>
MySQL:索引失效场景总结
查看>>
Mysql:避免重复的插入数据方法汇总
查看>>
MyS中的IF
查看>>
M_Map工具箱简介及地理图形绘制
查看>>
m_Orchestrate learning system---二十二、html代码如何变的容易
查看>>
M×N 形状 numpy.ndarray 的滑动窗口
查看>>