強引用和弱引用:
我們已經(jīng)知道OC中的內(nèi)存管理是通過“引用計數(shù)器”來實現(xiàn)的。一個對象的生命周期取決于它是否還被其他對象引用(是否retainCount=0)梯浪。但在有些情況下捌年,我們并不希望對象的銷毀時間由是否被其他對象引用來決定,而是這個對象本該是什么時候銷毀就什么時候被銷毀挂洛。這時礼预,我們得引入“強引用”和“弱引用”的概念。
強引用:當前對象被其他對象引用時抹锄,會執(zhí)行retain操作逆瑞,引用計數(shù)器+1。當retainCount=0時伙单,該對象才會被銷毀获高。因為我們要進行對象的內(nèi)存管理,所以這是默認的引用方式吻育。(默認是強引用)
弱引用:當前對象的生命周期不被是否由其他對象引用限制念秧,它本該什么時候銷毀就什么時候被銷毀。即使它的引用沒斷布疼,但是當它的生存周期到了時就會被銷毀摊趾。
在定義屬性時,若聲明為retain類型的游两,則就是強引用砾层;若聲明為assign類型的,則就是弱引用贱案。后來內(nèi)存管理都由ARC來完成后肛炮,若是強引用,則就聲明為strong;若是弱引用侨糟,則就聲明為weak碍扔。
所以說,retain和strong是一致的(聲明為強引用)秕重;assign和weak是基本一致的(聲明為弱引用)不同。 之所以說它倆是基本一致是因為它倆還是有所不同的,weak嚴格的說應當叫“ 歸零弱引用 ”溶耘,即當對象被銷毀后二拐,會自動的把它的指針置為nil,這樣可以防止野指針錯誤汰具。而assign銷毀對象后不會把該對象的指針置nil卓鹿,對象已經(jīng)被銷毀菱魔,但指針還在癡癡的指向它留荔,這就成了野指針,這是比較危險的澜倦。
避免“強引用循環(huán)“的僵局:
默認的引用方式是強引用聚蝶,但上面說了有時我們還得使用弱引用,那是什么情況呢藻治?
答案碘勉,強引用循環(huán):A對象強引用了B對象,B對象也強引用了A桩卵。因為都是強引用验靡,也就是無論是A是B都要在對方的引用斷了后才能銷毀,但要斷了引用雏节,就必須對方對象銷毀胜嗓。就會出現(xiàn)這種僵局,為了避免出現(xiàn)這種情況钩乍,就應該有一個對象“示弱”辞州,使其為“弱引用”。
比較常見的寥粹,視圖中的父子視圖之間的引用:父視圖強引用子視圖变过,子視圖弱引用父視圖。
總結:由于要進行內(nèi)存管理的緣故涝涤,OC里的引用默認都是強引用媚狰,但為了避免出現(xiàn)”強引用循環(huán)僵局“,所以有了弱引用(assign)阔拳。
retain和strong都是 指針拷貝崭孤。 當有其他對象引用當前對象時,會拷貝一份當前對象的地址,這樣它就也指向當前對象了裳瘪。所以土浸,還是同一個對象,只是retainCount+1彭羹;
而copy則是 內(nèi)容拷貝黄伊。 是實實在在的拷貝一個新的對象,拷貝了它的內(nèi)存內(nèi)容派殷,成為一個新的對象(retainCount=1)还最。
深拷貝(mutableCopy)和淺拷貝(copy):
深拷貝就是內(nèi)容拷貝,淺拷貝就是指針拷貝毡惜。
在OC中拓轻,若要進行對象的拷貝,則該對象所屬的類必須遵守NSCopying和NSMutableCopy協(xié)議经伙,并重寫copyWithZone:和mutableCopyWithZone:方法扶叉。而系統(tǒng)原生類,之所以可以直接進行拷貝是因為它已幫我們自動做了這些事帕膜。