Objective-c中@property和@synthesize的用法

@表明“Objective-C”的标志,证实您正在使用Objective-C语言php

 

Objective-C语言关键词,@property与@synthesize配对使用。html

 

功能:让编译好器自动编写一个与数据成员同名的方法声明来省去读写方法的声明。多线程

 

如:app

一、在头文件中:函数

C代码  收藏代码性能

  1. @property int count;  ui

等效于在头文件中声明2个方法:编码

C代码  收藏代码atom

  1. - (int)count;  spa

  2. -(void)setCount:(int)newCount;  

 

二、实现文件(.m)中

C代码  收藏代码

  1. @synthesize count;  

等效于在实现文件(.m)中实现2个方法。

C代码  收藏代码

  1. - (int)count  

  2. {  

  3.     return count;  

  4. }  

  5. -(void)setCount:(int)newCount  

  6. {  

  7.     count = newCount;  

  8. }  

  

以上等效的函数部分由编译器自动帮开发者填充完成,简化了编码输入工做量。

 

格式:

 

声明property的语法为:@property (参数1,参数2) 类型 名字;

 

如:

C代码  收藏代码

  1. @property(nonatomic,retain) UIWindow *window;  

 

其中参数主要分为三类:

 

读写属性: (readwrite/readonly)

setter语意:(assign/retain/copy)

原子性: (atomicity/nonatomic)

 

各参数意义以下:

 

readwrite: 产生setter\getter方法

readonly: 只产生简单的getter,没有setter。

assign: 默认类型,setter方法直接赋值,而不进行retain操做

retain: setter方法对参数进行release旧值,再retain新值。

copy: setter方法进行Copy操做,与retain同样

nonatomic: 禁止多线程,变量保护,提升性能

 

参数类型

参数中比较复杂的是retain和copy,具体分析以下:

 

getter 分析

 

一、

C代码  收藏代码

  1. @property(nonatomic,retain)test* thetest;  

  2. @property(nonatomic ,copy)test* thetest;  

等效代码:

C代码  收藏代码

  1. -(void)thetest  

  2. {  

  3.   return thetest;  

  4. }  

 

二、

C代码  收藏代码

  1. @property(retain)test* thetest;  

  2. @property(copy)test* thetest;  

等效代码:

C代码  收藏代码

  1. -(void)thetest  

  2. {  

  3.     [thetest retain];  

  4.     return [thetest autorelease];  

  5. }  

 

setter分析

 

一、

C代码  收藏代码

  1. @property(nonatomic,retain)test* thetest;  

  2. @property(retain)test* thetest;  

等效于:

C代码  收藏代码

  1. -(void)setThetest:(test *)newThetest {  

  2.     if (thetest!= newThetest) {  

  3.         [thetestrelease];  

  4.         thetest= [newThetest retain];  

  5.     }  

  6. }  

  

 二、

C代码  收藏代码

  1. @property(nonatomic,copy)test* thetest;  

  2. @property(copy)test* thetest;  

 等效于:

C代码  收藏代码

  1. -(void)setThetest:(test *)newThetest {  

  2.     if (thetest!= newThetest) {  

  3.         [thetest release];  

  4.         thetest= [newThetest copy];  

  5.     }  

  6. }  

 

nonatomic

若是使用多线程,有时会出现两个线程互相等待对方致使锁死的状况(具体能够搜下线程方面的注意事项去了解)。在没有(nonatomic)的状况下,即默认(atomic),会防止这种线程互斥出现,可是会消耗必定的资源。因此若是不是多线程的程序,打上(nonatomic)便可

 

retain

代码说明

若是只是@property NSString*str; 则经过@synthesize自动生成的setter代码为:

C代码  收藏代码

  1. -(void)setStr:(NSString*)value{  

  2.     str=value;  

  3. }  

  

若是是@property(retain)NSString*str; 则自动的setter内容为:

C代码  收藏代码

  1. -(void)setStr:(NSString*)v{  

  2.     if(v!=str){  

  3.         [str release];  

  4.         str=[v retain];  

  5.     }  

  6. }  

 

 

全部者属性

咱们先来看看与全部权有关系的属性,关键字间的对应关系。

属性值 关键字 全部权




strong

__strong

weak

__weak

unsafe_unretained

__unsafe_unretained

copy

__strong

assign

__unsafe_unretained

retain

__strong

  • strong

  • 该属性值对应 __strong 关键字,即该属性所声明的变量将成为对象的持有者。

  • weak

  • 该属性对应 __weak 关键字,与 __weak 定义的变量一致,该属性所声明的变量将没有对象的全部权,而且当对象被破弃以后,对象将被自动赋值nil。

    而且,delegate 和 Outlet 应该用 weak 属性来声明。同时,如上一回介绍的 iOS 5 以前的版本是没有 __weak 关键字的,因此 weak 属性是不能使用的。这种状况咱们使用 unsafe_unretained。

  • unsafe_unretained

  • 等效于__unsafe_unretaind关键字声明的变量;像上面说明的,iOS 5以前的系统用该属性代替 weak 来使用。

  • copy

  • 与 strong 的区别是声明变量是拷贝对象的持有者。

  • assign

  • 通常Scalar Varible用该属性声明,好比,int, BOOL。

  • retain

  • 该属性与 strong 一致;只是可读性更强一些。

  •  

    参考:

    http://blog.eddie.com.tw/2010/12/08/property-and-synthesize/

    http://www.cocoachina.com/bbs/read.php?tid=7322

    http://www.cnblogs.com/pinping/archive/2011/08/03/2126150.html

     

     

    声明的分类

    在 Objective-C官方文档 中的Property一章里有对类Property详细说明。
    @property中的声明列表已分类为如下几种:

    1, 声明属性的访问方法:

    • getter=getterName

    • setter=setterName
      声明访问属性的设置与获取方法名。

    2,声明属性写操做权限:

    • readwrite
      声明此属性为读写属性,便可以访问设置方法(setter),也能够访问获取方法(getter),与readonly互斥。

    • readonly
      声明此属性为只读属性,只能访问此属性对应的获取方法(getter),与readwrite互斥。

    3,声明写方法的实现:

    • assign
      声明在setter方法中,采用直接赋值来实现设值操做。如:

    C代码  收藏代码

    1. -(void)setName:(NSString*)_name{  

    2.      name = _name;  

    3. }  

     

    • retain
      声明在setter方法中,须要对设过来的值进行retain 加1操做。如:

    C代码  收藏代码

    1. -(void)setName:(NSString*)_name{  

    2.      //首先判断是否与旧对象一致,若是不一致进行赋值。  

    3.      //由于若是是一个对象的话,进行if内的代码会形成一个极端的状况:当此name的retain为1时,使这次的set操做让实例name提早释放,而达不到赋值目的。  

    4.      if ( name != _name){  

    5.           [name release];  

    6.           name = [_name retain];  

    7.      }  

    8. }  

     

    • copy
      调用此实例的copy方法,设置克隆后的对象。实现参考retain。

    4,访问方法的原子性:

    • nonatomic
      在默认的状况下,经过synthesized 实现的 setter与getter 都是原子性访问的。多线程同时访问时,保障访问方法同时只被访问一个线程访问,如:

    • C代码  收藏代码

       

      1. [ _internal lock ]; // lock using an object-level lock  

      2. id result = [ [ value retain ] autorelease ];  

      3. [ _internal unlock ];  

      4. return result;  

    • 但若是设置nonatomic时,属性的访问为非原子性访问。

     

    来源:http://wiki.magiche.net/pages/viewpage.action?pageId=1540101

     

     

    @synthesize tabBarController=_tabBarController;

    @synthesize 中能够定义 与变量名不相同的getter和setter的命名,籍此来保护变量不会被不恰当的访问

相关文章
相关标签/搜索