@class和#import的區(qū)別
使用@class不必知道這個類里到底有什么,只要知道有這樣一個類#import是把這個類里所有有的方法和屬性都導入了進來,非必要情況下牺堰,使用@class可以減少類的使用者所需引入頭文件的數(shù)量操软,也避免了引入根本用不到的內容,從而可以縮短編譯時間掂林,所以我們將引入頭文件的時機盡量延后,只在確有需要時才引入蛤虐。
頭文件的循環(huán)引用
我們常提到頭文件的循環(huán)引用党饮,如果在A類里引入B類的頭文件,當解析A類頭文件時驳庭,編譯器會發(fā)現(xiàn)他引入了B類的頭文件刑顺,而B類頭文件又回過頭來應用A類頭文件氯窍,使用#import而非#include指令雖然不會導致死循環(huán),但卻意味著這兩個類里有一個無法被正確編譯蹲堂,@class也覺得了兩個類互相引用的問題狼讨。
協(xié)議單獨放在一個頭文件中
有時候,必須要在頭文件中引入其他頭文件柒竞,如果你寫的類繼承自某個超類政供,則必須引入定義那個超類的文件。同理朽基,如果要聲明你寫的類遵從某個協(xié)議布隔,那么該協(xié)議必須有完整定義,且不能使用向前聲明(@class)稼虎,向前聲明只能告訴編譯器有某個協(xié)議衅檀,而此時編譯器卻要知道該協(xié)議中定義的方法,這樣#import是難免的霎俩,鑒于此哀军,最好是把協(xié)議單獨放在一個頭文件里。要是把協(xié)議放到某個大文件里打却,那么只要引入協(xié)議杉适,就必定會引入那個頭文件中的全部內容,如此一來柳击,就會產生相互依賴問題猿推,增加編譯器時間
委托協(xié)議(delegate protocol)
然而有些協(xié)議,例如“委托協(xié)議”腻暮,就不用單獨寫一個頭文件了彤守,在那種情況下毯侦,協(xié)議只有與接受協(xié)議委托的類放在一起定義才有意義哭靖,此時最好能在實現(xiàn)文件中聲明此類實現(xiàn)了該協(xié)議,并把這段實現(xiàn)代碼放在“分類”侈离。這樣的話试幽,只要在實現(xiàn)文件中引入包含委托協(xié)議的頭文件即可,而不需要將其放在公共頭文件里卦碾。
要點
1铺坞、除非卻有必要,否則不要引入頭文件洲胖。一般來說济榨,應在某個類的頭文件中使用先前聲明來提及別的類,并在實現(xiàn)文件中引入那些類的頭文件绿映,這樣做可以盡量降低類之間的耦合
2擒滑、有時無法使用向前聲明腐晾,比如聲明某個類遵循一項協(xié)議。這種情況下丐一,盡量把“該類遵循某協(xié)議”這條聲音移至分類里藻糖,如果不信的話,就把協(xié)議單獨放在一個頭文件中库车,然后將其引入巨柒。