#import和#include的區別spa
import引入的頭文件,能夠防止重複包含code
include它是使用預處理指令防止重複包含,若是沒有寫預處理指令,則沒法防止重複包含問題orm
2. #import和@class的區別
接口
#import會鏈入該頭文件的所有信息,包括實體變量和方法等;而@class只是告訴編譯器,其後面聲明的名稱是類的名稱,至於這些類是如何定義的,暫時不用考慮。在頭文件中, 通常只須要知道被引用的類的名稱就能夠了。 不須要知道其內部的實體變量和方法,因此在頭文件中通常使用@class來聲明這個名稱是類的名稱。 而在實現類裏面,由於會用到這個引用類的內部的實體變量和方法,因此須要使用#import來包含這個被引用類的頭文件。 在編譯效率方面考慮,若是你有100個頭文件都#import了同一個頭文件,或者這些文件是依次引用的,如A–>B, B–>C, C–>D這樣的引用關係。當最開始的那個頭文件有變化的話,後面全部引用它的類都須要從新編譯,若是你的類有不少的話,這將耗費大量的時間。而是用@class則不會。 若是有循環依賴關係,如:A–>B, B–>A這樣的相互依賴關係,若是使用#import來相互包含,那麼就會出現編譯錯誤,若是使用@class在兩個類的頭文件中相互聲明,則不會有編譯錯誤出現。因此,通常來講,@class是放在interface中的,只是爲了在interface中引用這個類,把這個類做爲一個類型來用的。 在實現這個接口的實現類中,若是須要引用這個類的實體變量或者方法之類的,仍是須要import在@class中聲明的類進來.
3. #import<> 和#import""的區別
編譯器
""表示從當前項目路徑開始尋找文件,若是找不到,則到系統(項目)中配置的頭文件路徑去找;
<>表示直接到系統(項目)中配置的頭文件路徑去找。
it
也就是說系統的頭文件用<>,自定義類的頭文件用「」。編譯