博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
property相关参数介绍
阅读量:6432 次
发布时间:2019-06-23

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

1、copy 使用类型 :NSString,block

2、assign使用类型 :delegate,int,float,NSInteger,bool,枚举,结构体...

3、retain使用类型 :NSArray,NSDate

4、strong使用类型 :NSString/block以外的OC对象

5、weak 使用类型 :当2个对象相互引用,一端用strong,一端用weak;

6、readOnly :只读时候(即只需要getter方法的时候);

7、readWriete :默认属性(getter&&setter方法)

assign ( ARC/MRC )

1、这个修饰词是直接赋值的意思 , 整型/浮点型等数据类型都用这个词修饰 .

2、如果没有使用 weak strong retain copy 修饰 , 那么默认就是使用 assign 了. ( 它们之间是有你没我的关系 )

3、当然其实对象也可以用 assign 修饰 , 只是对象的计数器不会+1 . ( 与 strong 的区别 )

4、如果用来修饰对象属性 , 那么当对象被销毁后指针是不会指向 nil 的 . 所以会出现野指针错误 . ( 与weak的区别 )

------------------------------------------------------------------------------

weak ( ARC )

1、弱指针是针对对象的修饰词 , 就是说它不能修饰基本数据类型 .

2、weak 修饰的对象计数器不会+1 , 也就是直接赋值 .

3、弱引用是为打破循环引用而生的 .

4、它最被人所喜欢的原因是 它所指向的对象如果被销毁 , 它会指向 nil . 而 nil 访问什么鬼都不会报野指针错误 .

------------------------------------------------------------------------------

strong ( ARC )

1、直接赋值并且计数器 +1 .

2、在 ARC 里替代了 retain 的作用 .

------------------------------------------------------------------------------

retain ( MRC )

1、release 旧对象( 旧对象计数器 -1 ) , retain 新对象( 新对象计数器 +1 ) , 然后指向新对象 .

2、在set方法里面是这样的 :

if (_delegate)

  {

     [_delegate release];

   }

   _delegate = [delegate retain];

------------------------------------------------------------------------------

copy ( ARC/MRC )

1、copy 在 MRC 时是这样做的 release 旧对象( 旧对象计数器 -1 ) , copy 新对象( 新对象计数器 +1 ) , 然后指向新对象 .

在set方法里面是这样的 :

if (_delegate)

  {

     [_delegate release];

   }

   _delegate = [delegate copy];

2、copy 在 ARC 时是这么干的 copy 新对象( 新对象计数器 +1 ) , 然后指向新对象 .

在set方法里面是这样的 :

_delegate = [delegate copy];

3、使用注意 : 修饰的属性本身要不可变的 . 例如 NSMutableArray 采用 copy 修饰 , 添加元素表面上可以 一到运行就崩溃了 , 因为 copy 过后实际上成了NSArray了 . ( 队友 , 我们不吭你 ) 遵守 NSCopying 协议的对象使用 .

------------------------------------------------------------------------------

nonatomic ( ARC/MRC )

1、不对set方法加锁 .

2、性能好

3、线程不安全

atomic ( ARC/MRC )

1、原子属性就是对生成的 set 方法加互斥锁 @synchronized(锁对象) .

   @synchronized(self) {

     _delegate = delegate;

  }

2、需要消耗系统资源 .

3、互斥锁是利用线程同步实现的 , 意在保证同一时间只有一个线程调用 set 方法 .

4、其实还有 get 方法 , 要是同时 set 和 get 一起调用还是会有问题的 . 所以即使用了 atomic 修饰 还是不够安全 .

------------------------------------------------------------------------------

readonly

1、让 Xcode 只生成get方法 .

2、不想把暴露的属性被人随便替换时 , 可以使用 .

------------------------------------------------------------------------------

readwrite

1、让 Xcode 生成get/set方法 .

2、不用 readonly 修饰时 , 默认就是 readwrite .

------------------------------------------------------------------------------

getter/setter 的自定义方法名 .

1、一般对于 有/无 是/否 等这样的属性 , getter 方法名前面加个 is 会显得通俗易懂 .

 

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

你可能感兴趣的文章
linux系统使用tomcat服务器部署web项目
查看>>
虚拟文件系统相关结构描述【续】
查看>>
我的友情链接
查看>>
思科通配符(Cisco Wildcard Mask)
查看>>
PHP cURL快速入门
查看>>
在errpt中报E87EF1BE的解决方法(转载)
查看>>
aix chfs及mklvcopy报错的解决方法
查看>>
取消新增的constraints
查看>>
MAC OS X 使用记录
查看>>
Azure 中使用 iPerf 进行网络带宽测试
查看>>
OPTIMIZE TABLE
查看>>
flask框架+pygal+sqlit3搭建图形化业务数据分析平台
查看>>
Fedora24下MySQL开发环境搭建
查看>>
shell实战训练营Day20
查看>>
jQuery 之 TAB切换菜单
查看>>
mysql 数据库集群搭建:(二)3台CentOS-7安装Percona-XtraDB-Cluster-57集群
查看>>
Jenkins实战演练之Windows系统节点管理
查看>>
MySQL高可用架构之MHA
查看>>
1.8 nginx域名跳转
查看>>
PHP面向对象之接口编程
查看>>