昨天在和基友討論.h要用什么方式引用比較好,特意去查了一下這方面的資。學無止境學無止境。
1. import會包含這個類的所有信息,包括實體變量和方法,而@class只是告訴編譯器,其后面聲明的名稱是類的名稱,至于這些類是如何定義的,暫時不用考慮,后面會再告訴你;
2. 在頭文件中,一般只需要知道被引用的類的名稱就可以了,不需要知道其內(nèi)部的實體變量和方法,所以在頭文件中一般使用@class來聲明這個名稱是類的名稱,而在類的實現(xiàn)部分,因為會用到這個引用類的內(nèi)部的實體變量和方法,所以需要使用#import來包含這個被引用類的頭文件。
3. 在編譯效率方面考慮,如果你有100個頭文件都#import了同一個頭文件,或者這些文件是依次被引用的,如A–>B, B–>C, C–>D這樣的引用關系。當最開始的那個頭文件有變化的話,后面所有引用它的類都需要重新編譯,如果你的類有很多的話,這將耗費大量的時間。而是用@class則不會。
4. 如果有循環(huán)依賴關系,如:A–>B, B–>A這樣的相互依賴關系,如果使用#import來相互包含,那么就會出現(xiàn)編譯錯誤,如果使用@class在兩個類的頭文件中相互聲明,則不會有編譯錯誤出現(xiàn)。
所以,一般來說,@class是放在interface中的,只是為了在interface中引用這個類,把這個類作為一個類型來用的。 在實現(xiàn)這個接口的實現(xiàn)類中,如果需要引用這個類的實體變量或者方法之類的,還是需要import在@class中聲明的類進來.