


此處的屬性非成員變量,只是聲明了setter和getter方法

多個分類有同一個實例方法時最后編譯的分類方法生效,分類合并會覆蓋

通過關(guān)聯(lián)對象可以給分類添加“成員變量”











KVC打破了面對對象的編程思想
屬性關(guān)鍵字
atomic只保證了屬性的賦值和獲取的線程安全,比如對可變數(shù)組的增刪改是不能保證線程安全的,不能保證數(shù)據(jù)的安全性,只能保證拿到數(shù)據(jù)的完整性(即能取到值)
assign:
用于對基本數(shù)據(jù)類型進(jìn)行賦值操作,不更改引用計數(shù)。也可以用來修飾對象,但是,被assign修飾的對象在釋放后,指針的地址還是存在的,也就是說指針并沒有被置為nil,成為野指針。如果后續(xù)在分配對象到堆上的某塊內(nèi)存時,正好分到這塊地址,程序就會crash。之所以可以修飾基本數(shù)據(jù)類型,因為基本數(shù)據(jù)類型一般分配在棧上,棧的內(nèi)存會由系統(tǒng)自動處理,不會造成野指針。
weak:
修飾Object類型,修飾的對象在釋放后,指針地址會被置為nil,是一種弱引用。
delegate為何要用weak修飾:
在ARC環(huán)境下,為避免循環(huán)引用,往往會把delegate屬性用weak修飾;在MRC下使用assign修飾。weak和strong不同的是:當(dāng)一個對象不再有strong類型的指針指向它的時候,它就會被釋放,即使還有weak型指針指向它,那么這些weak型指針也將被清除。
ARC下的strong等同于MRC下的retain都會把對象引用計數(shù)加1。
copy:
會在內(nèi)存里拷貝一份對象,兩個指針指向不同的內(nèi)存地址。一般用來修飾NSString等有對應(yīng)可變類型的對象,因為他們有可能和對應(yīng)的可變類型(NSMutableString)之間進(jìn)行賦值操作,為確保對象中的字符串不被修改 ,應(yīng)該在設(shè)置屬性是拷貝一份。而若用strong修飾,如果對象在外部被修改了,會影響到屬性。
block屬性為什么需要用copy來修飾?
因為在MRC下,block在創(chuàng)建的時候,它的內(nèi)存是分配在棧(stack)上的,而不是在堆(heap)上,可能被隨時回收。他本身的作于域是屬于創(chuàng)建時候的作用域,一旦在創(chuàng)建時候的作用域外面調(diào)用block將導(dǎo)致程序崩潰。通過copy可以把block 拷貝(copy)到堆,保證block的聲明域外使用。在ARC下寫不寫都行,編譯器會自動對block進(jìn)行copy操作。
__block與__weak的區(qū)別
__block:在ARC和MRC下都可用,可修飾對象,也可以修飾基本數(shù)據(jù)類型。
__block: 對象可以在block被重新賦值,__weak不可以。
__weak:只在ARC中使用,只能修飾對象,不能修飾基本數(shù)據(jù)類型(int、bool)。
同時,在ARC下,要避免block出現(xiàn)循環(huán)引用,經(jīng)常會:__weak typedof(self) weakSelf = self;
