這是我個人的學習筆記 , 如有不同見解歡迎評論交流 .
( GeekBand-極客班 http://geekband.com )
( 我的微博 : http://weibo.com/JohnnyB0Y )
屬性( @property )與成員變量的那些事 :
- 屬性對成員變量擴充了存取方法 .
- 屬性默認會生成帶下劃線的成員變量 .
- 早期的 Xcode 不支持自動合成成員變量的存取方法 , 所以古老的iOS工程師是憤怒的 .
- 后來 Xcode 智能了一點 , 可以用 @synthesize 關鍵字自動合成成員變量的存取方法 , 此時的iOS工程師是郁悶的 .
- 現(xiàn)在 Xcode 會在我們聲明屬性時自動合成存取方法 , 連@synthesize都不用寫了 , 這樣iOS工程師徹底解放了 .
- 順便提一下 @dynamic , 這個關鍵字是告訴編譯器存取方法在運行時會有的 . 也可以說 @dynamic 是工程師自己來實現(xiàn)成員變量的存取方法 , @synthesize 是讓 Xcode 幫你生成存取方法 .
屬性中的修飾詞 - 我的理解 :
-
assign ( ARC/MRC )
1.這個修飾詞是直接賦值的意思 , 整型/浮點型等數(shù)據(jù)類型都用這個詞修飾 .
2.如果沒有使用 weak strong retain copy 修飾 , 那么默認就是使用 assign 了. ( 它們之間是有你沒我的關系 )
3.當然其實對象也可以用 assign 修飾 , 只是對象的計數(shù)器不會+1 . ( 與 strong 的區(qū)別 )
4.如果用來修飾對象屬性 , 那么當對象被銷毀后指針是不會指向 nil 的 . 所以會出現(xiàn)野指針錯誤 . ( 與weak的區(qū)別 )
-
weak ( ARC )
1.弱指針是針對對象的修飾詞 , 就是說它不能修飾基本數(shù)據(jù)類型 .
2.weak 修飾的對象計數(shù)器不會+1 , 也就是直接賦值 .
3.弱引用是為打破循環(huán)引用而生的 .
4.它最被人所喜歡的原因是 它所指向的對象如果被銷毀 , 它會指向 nil . 而 nil 訪問什么鬼都不會報野指針錯誤 .
-
strong ( ARC )
1.直接賦值并且計數(shù)器 +1 .
2.在 ARC 里替代了 retain 的作用 .
-
retain ( MRC )
1.release 舊對象( 舊對象計數(shù)器 -1 ) , retain 新對象( 新對象計數(shù)器 +1 ) , 然后指向新對象 .
2.在set方法里面是這樣的 :
if (_dog) {
[_dog release];
}
_dog = [dog retain];
-
copy ( ARC/MRC )
1.copy 在 MRC 時是這樣做的 release 舊對象( 舊對象計數(shù)器 -1 ) , copy 新對象( 新對象計數(shù)器 +1 ) , 然后指向新對象 .(新對象是指最終指向的那個對象抹估,不管深拷貝還是淺拷貝)
1.1在set方法里面是這樣的 :
if (_dog) {
[_dog release];
}
_dog = [dog copy];
2.copy 在 ARC 時是這么干的 copy 新對象( 新對象計數(shù)器 +1 ) , 然后指向新對象 .
2.1在set方法里面是這樣的 :
_dog = [dog copy];
3.使用注意 :
3.1 修飾的屬性本身要不可變的 . 例如 NSMutableArray 采用 copy 修飾 , 添加元素表面上可以 一到運行就崩潰了 , 因為 copy 過后實際上成了NSArray了 . ( 隊友 , 我們不吭你 )
3.2 遵守 NSCopying 協(xié)議的對象使用 .
-
nonatomic ( ARC/MRC )
1.不對set方法加鎖 .
2.性能好
3.線程不安全
-
atomic ( ARC/MRC )
1.原子屬性就是對生成的 set 方法加互斥鎖 @synchronized(鎖對象) .
@synchronized(self) {
_delegate = delegate;
}
2.需要消耗系統(tǒng)資源 .
3.互斥鎖是利用線程同步實現(xiàn)的 , 意在保證同一時間只有一個線程調用 set 方法 .
4.其實還有 get 方法 , 要是同時 set 和 get 一起調用還是會有問題的 . 所以即使用了 atomic 修飾 還是不夠安全 .
-
readonly
1.讓 Xcode 只生成get方法 .
2.不想把暴露的屬性被人隨便替換時 , 可以使用 .
-
readwrite
1.讓 Xcode 生成get/set方法 .
2.不用 readonly 修飾時 , 默認就是 readwrite .
-
getter/setter 的自定義方法名 .
1.一般對于 有/無 是/否 等這樣的屬性 , getter 方法名前面加個 is 會顯得通俗易懂 .
@property (nonatomic, getter = isFinish, setter = setFinish) BOOL finish;
總結 :
工程師畢竟是為解決問題而生的 , 那么擺在你面前的問題是什么 , 就采取什么樣的策略去搞定 .
搞不定怎么辦 , 哈哈 , 我是菜鳥我怕誰 ?