成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Objective-C之@property和@synthesize

移動開發 iOS
今天要說的內容是Objective-C 中的 @property和@synthesize。在這之前先講講訪問器(Accessor),也就是我們所知道的setter和getter方法。 《Cocoa Design Patterns》中的將它歸類為基礎模式中的一種。訪問器是很重要的技術,用來訪問和設置對象的實例變量(不是指對象本身,而是對象中的屬性)。有時候 可能需要用不同的方式或者通過計算等方式來獲取或設置實例變量,訪問器給了我們很大的靈活性。

我用了不到一周的時間學習了Objective- C,后面的大部分時間我都在了解如何使用iOS的SDK和一些高級的話題,到目前已經有兩個多月的時間了。目前能做一些簡單的應用,但是在寫代碼的時候明 顯感覺到基礎不夠扎實,畢竟一周的時間只能對一門語言有個概覽。要想精通一門語言是遠遠不夠的。

所以我把自己學習過程中遇到的一些問題整理在博客上,這也是一個學習理解的過程。

今天要說的內容是Objective-C 中的 @property和@synthesize。在這之前先講講訪問器(Accessor),也就是我們所知道的setter和getter方法。 《Cocoa Design Patterns》中的將它歸類為基礎模式中的一種。訪問器是很重要的技術,用來訪問和設置對象的實例變量(不是指對象本身,而是對象中的屬性)。有時候 可能需要用不同的方式或者通過計算等方式來獲取或設置實例變量,訪問器給了我們很大的靈活性。在Cocoa中訪問器有很多的優點:

  • 實現靈活性。 可以在訪問器中改變并實現不同的實例變量訪問方式而不影響其他代碼。
  • 可維護性。通過訪問器對實例變量的更改易于維護。
  • 內存管理。訪問器方法提供了簡單的方法去遵守Cocoa的約定把內存管理代碼隔離在少部分代碼中。
  • 支持KVC和KVO。 KVC和KVO是很強大的技術。但是它們依賴于正確命名訪問器。

下面這段代碼簡單的實現了一個訪問器(setter和getter):

  1. //setter 
  2.     -(void)setStuName:(NSString *)stuName 
  3.       {  //_stuName 是實例變量 
  4.          if (_stuName != stuName) 
  5.          { 
  6.             [_stuName release]; 
  7.              _stuName = [stuName copy]; 
  8.          } 
  9.       } 
  10.     //getter 
  11.       -(NSString *)stuName 
  12.       { 
  13.          return _stuName; 
  14.       } 

上面代碼中的setter中還涉及到一定的內存管理,既然這個技術這么重要,那么有沒有一種更方便的方法去做呢?答案就是@property和@synthesize。它們是Objective-C 2.0加入的指令,前者用于聲明,后者用于合成訪問器,結合使用就可以自動生成訪問器了。

下面這段代碼使用@property和@synthesize:

  1. @interface Student : NSObject 
  2.     @property (nonatomic, copy) NSString *stuName; 
  3.     @end      
  4.     @implementation Student 
  5.     @synthesize stuName = _stuName; 
  6.     @end

這段代碼的效果跟上面代碼的效果是一樣的,是不是很方便呢?

使用@property和@synthesize很方便,但又給我們帶來了很多疑問比如在上面的代碼中又出現了nonatomic和copy,是什么意 思?在@property中還有其他幾個關鍵字,它們都是有特殊作用的,我把它們分為三類分別是:原子性,訪問器控制,內存管理。

原子性

atomic(默認):atomic意為操作是原子的,意味著只有一個線程訪問實例變量。atomic是線程安全的至少在當前的訪器上我是安全的。它是一個默認的,但是很少使用。它的比較慢,這跟ARM平臺和內部鎖機制有關。

nonatomic: nonatomic跟atomic剛好相反。表示非原子的,可以被多個線程訪問。它的速度比atomic快。但不能保證在多線程環境下的安全性,在單線程和明確只有一個線程訪問的情況下廣泛使用。

訪問器控制

readwrite(默認):readwrite是默認的,表示同時擁有setter和getter。

readonly: readonly 表示只有getter沒有setter。

有時候為了語意更明確可能需要自定義訪問器的名字:

  1. @property (nonatomic, setter = mySetter:,getter = myGetter ) NSString *name; 

最常見的是BOOL類型,比如標識View是否隱藏的屬性hidden??梢赃@樣聲明

  1. @property (nonatomic,getter = isHidden ) BOOL hidden; 

要注意修改setter或者getter的名字是存在副作用的,可能會使KVC和KVO無法正常工作。

內存管理

retain:使用了retain意味著實例變量要獲取傳入參數的所有權。具體表現在setter中對實例變量先release然后將參數 retain之后傳給它。下面這段代碼展示了retain類似的行為:

  1. -(void)setStuName:(NSString *)stuName 
  2.       { 
  3.          if (_stuName != stuName) 
  4.          { 
  5.             [_stuName release]; 
  6.              _stuName = [stuName retain]; 
  7.          } 
  8.       } 

assign(默認):用于值類型,如int、float、double和NSInteger,CGFloat等表示單純的復制。還包括不存在所有權關系的對象,比如常見的delegate。

strong:是在ARC伴隨IOS引入的時候引入的關鍵字是retain的一個可選的替代。表示實例變量對傳入的參數要有所有權關系即強引用。strong跟retain的意思相同并產生相同的代碼,但是語意上更好更能體現對象的關系。

weak: weak跟assign的效果相似,不同的是weak在對象被回收之后自動設置為nil。而且weak智能用在iOS 5或以后的版本,對于之前的版本,使用unsafe_unretained。

unsafe_unretained:weak的低版本替代。  

copy:copy是為是實例變量保留一個自己的副本。

現在明白了@property是怎么回事了,但是@synthesize是怎么回事,看看之前的***段代碼:

  1. @synthesize stuName = _stuName; 

這里的stuName = _stuName是什么意思?stuName是propertyName跟@property聲明的名字一樣。而后面的_stuName 是實例變量名。生成的訪問器就是來訪問的 _stuName的。代碼的樣子就和最開始那setter和getter代碼所描述的一樣。

注意一個問題,我們并沒有聲明_stuName這個變量,這是編譯器自動幫我們創建的。 如果這段指令我換個寫法:@synthesize stuName = a;   并且我們沒有在interface里面聲明這個變量,那么會自動創建一個變量a。

如果這里寫成這樣:

  1. <em>@synthesize stuName; 
  2.     //等同于 
  3.     @synthesize stuName = stuName;</em> 

在Xcode4.4中,Xcode添加的一些新的編譯特性。其中一個就是默認合成(Default Synthesis)。默認合成就不再需要顯示的使用@synthesize指令了,這很方便但是要注意的是,默認合成遵守的約定,這里的也就是命名規則是propertyName = _propertyName。 

下面一段代碼幫助理解:

  1. //對于下面的@propety 
  2.     @property (nonatomic, copy) NSString *stuName; 
  3.     //默認合成的規則是這樣: 
  4.     @synthesize stuName = _stuName; 

以上是我所了解的@property和@synthesize,如果跟你的理解不同,或者有什么錯誤,請給我留言:)。

責任編輯:閆佳明 來源: oschina
相關推薦

2011-07-19 17:18:35

Objective-C Property

2011-08-17 10:00:12

Objective-CProperty

2011-07-29 15:47:21

iPhone開發 Objective- C

2013-07-24 19:19:03

Objective-CiOS開發動態特性之protoc

2011-08-03 16:22:05

Objective-C CodeBlocks

2011-08-10 18:07:29

Objective-C反射

2013-06-20 10:40:32

Objective-C實現截圖

2013-03-27 12:54:00

iOS開發Objective-C

2011-05-11 15:58:34

Objective-C

2011-05-11 11:20:26

Objective-C

2011-07-08 18:44:09

Objective-C Self Super

2014-09-26 09:49:48

SwiftObjective-C

2011-07-28 15:11:23

iOS Objective-

2011-08-09 15:53:28

2011-05-11 13:54:08

Objective-C

2011-05-11 15:45:50

內存管理Objective-C

2011-08-02 13:16:36

Objective-C 語法 函數

2011-08-04 11:15:46

Objective-C 構造函數 構造方法

2011-05-11 14:06:49

Objective-C

2011-08-04 14:58:37

Objective-C Cocoa NSString
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 在线播放一区 | 亚洲精彩免费视频 | 国产欧美日韩精品一区二区三区 | 在线观看国产视频 | 欧美在线视频一区二区 | 91精品综合久久久久久五月天 | 日韩中文在线观看 | 久久久精品视频一区二区三区 | 国产欧美精品一区二区三区 | 精品国产乱码久久久久久久久 | 成人午夜精品一区二区三区 | 国产高清免费 | 午夜影视大全 | 日日摸日日碰夜夜爽亚洲精品蜜乳 | 国产一级淫片a直接免费看 免费a网站 | 天堂资源最新在线 | 日本在线观看视频 | 精品一区二区三区在线视频 | 中文字幕在线第一页 | 欧美在线一区二区三区四区 | 91精品国产92| 国产精品黄色 | 中文字幕一区二区三区日韩精品 | 日日噜噜噜夜夜爽爽狠狠视频, | 草草精品| 日韩欧美久久 | 欧美精品一区二区三区视频 | 亚洲精品高清视频在线观看 | 精品不卡| 在线国产小视频 | 亚洲欧美一区二区在线观看 | 日韩国产欧美一区 | 中文字幕在线观看一区二区 | 黄色片a级| 国产97碰免费视频 | 国产视频三区 | 狼色网 | 国产视频第一页 | 一级黄色录像片子 | 精品国产乱码久久久久久牛牛 | 免费看黄色小视频 |