1.#import會包含這個類的所有信息,包括實體變量和方法,而@class只是告訴編譯器,其後面聲明的名稱是類的名稱,在編譯的時候,告訴編譯器,這是一個類名,無需報錯。
2.在頭文件中, 一般只需要知道被引用的類的名稱就可以了。 不需要知道其內部的實體變量和方法,所以在頭文件中一般使用@class來聲明這個名稱是類的名稱。 而在實現類裏面,因爲會用到這個引用類的內部的實體變量和方法,所以需要使用#import來包含這個被引用類的頭文件。
3.在編譯效率方面考慮,如果你有100個頭文件都#import了同一個頭文件,或者這些文件是依次引用的,如A–>B, B–>C, C–>D這樣的引用關係。當最開始的那個頭文件有變化的話,後面所有引用它的類都需要重新編譯,如果你的類有很多的話,這將耗費大量的時間。而是用@class則不會。
4.如果有循環依賴關係,如:A–>B, B–>A這樣的相互依賴關係,如果使用#import來相互包含,那麼就會出現編譯錯誤,產生死循環的問題。如果使用@class在兩個類的頭文件中相互聲明,則不會有編譯錯誤出現。
綜上所述.@class一般出現在頭文件中.#import一般出現在實現,也就是.m中.