博客
关于我
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 InnoDB引擎的锁机制详解
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>
mysql 写入慢优化
查看>>
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>
mysql 判断表字段是否存在,然后修改
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段类型类型
查看>>
MySQL 存储引擎
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
mysql 自增id和UUID做主键性能分析,及最优方案
查看>>
Mysql 自定义函数
查看>>
mysql 行转列 列转行
查看>>
Mysql 表分区
查看>>