layoutSubviews何時(shí)調(diào)用的問題
layoutSubviews何時(shí)調(diào)用的問題,這個(gè)方法是當(dāng)你需要在調(diào)整subview的大小的時(shí)候需要重寫(我這個(gè)翻譯不嚴(yán)謹(jǐn),以下是原文:You should override this method only if the autoresizing behaviors of the subviews do not offer the behavior you want.),但有時(shí)候經(jīng)常指望它被調(diào)用的時(shí)候沒被調(diào)用,不希望它被調(diào)用的時(shí)候被調(diào)用了,搞的很上火。根據(jù)國外社區(qū)一個(gè)人帖子,做了總結(jié)性翻譯。
layoutSubviews在以下情況下會(huì)被調(diào)用:
1、init初始化不會(huì)觸發(fā)layoutSubviews
2、addSubview會(huì)觸發(fā)layoutSubviews
3、設(shè)置view的Frame會(huì)觸發(fā)layoutSubviews,當(dāng)然前提是frame的值設(shè)置前后發(fā)生了變化
4、滾動(dòng)一個(gè)UIScrollView會(huì)觸發(fā)layoutSubviews
5、旋轉(zhuǎn)Screen會(huì)觸發(fā)父UIView上的layoutSubviews事件
6、改變一個(gè)UIView大小的時(shí)候也會(huì)觸發(fā)父UIView上的layoutSubviews事件
iOS中assign,copy,retain之間的區(qū)別以及weak和strong的區(qū)別
@property (nonatomic, assign) NSString *title;
什么是assign,copy,retain之間的區(qū)別?
assign: 簡單賦值,不更改索引計(jì)數(shù)(Reference Counting)。
copy: 建立一個(gè)索引計(jì)數(shù)為1的對象,然后釋放舊對象
retain:釋放舊的對象,將舊對象的值賦予輸入對象,再提高輸入對象的索引計(jì)數(shù)為1
weak 和strong的區(qū)別:
(weak和strong)不同的是 當(dāng)一個(gè)對象不再有strong類型的指針指向它的時(shí)候 它會(huì)被釋放 ?,即使還有weak型指針指向它。
一旦最后一個(gè)strong型指針離去 ,這個(gè)對象將被釋放,所有剩余的weak型指針都將被清除。
可能有個(gè)例子形容是妥當(dāng)?shù)摹?/p>
想象我們的對象是一條狗,狗想要跑掉(被釋放)。
strong型指針就像是栓住的狗。只要你用牽繩掛住狗,狗就不會(huì)跑掉。如果有5個(gè)人牽著一條狗(5個(gè)strong型指針指向1個(gè)對象),除非5個(gè)牽繩都脫落 ,否著狗是不會(huì)跑掉的。
weak型指針就像是一個(gè)小孩指著狗喊到:“看!一只狗在那” 只要狗一直被栓著,小孩就能看到狗,(weak指針)會(huì)一直指向它。只要狗的牽繩脫落,狗就會(huì)跑掉,不管有多少小孩在看著它。
只要最后一個(gè)strong型指針不再指向?qū)ο?,那么對象就?huì)被釋放,同時(shí)所有的weak型指針都將會(huì)被清除。
使用assign: 對基礎(chǔ)數(shù)據(jù)類型 (NSInteger,CGFloat)和C數(shù)據(jù)類型(int, float, double, char, 等等)
使用copy: 對NSString
使用retain: 對其他NSObject和其子類
nonatomic關(guān)鍵字:
atomic是Objc使用的一種線程保護(hù)技術(shù),基本上來講,是防止在寫未完成的時(shí)候被另外一個(gè)線程讀取,造成數(shù)據(jù)錯(cuò)誤。而這種機(jī)制是耗費(fèi)系統(tǒng)資源的,所以在iPhone這種小型設(shè)備上,如果沒有使用多線程間的通訊編程,那么nonatomic是一個(gè)非常好的選擇。