在Objective-C中,可以使用#import和@class來引用別的類型, 但是你知道兩者有什麼區別嗎?
@class叫做forward-class, 你經常會在頭文件的定義中看到通過@class的引用, 原因就是當你只用@class來引入一個類時, 編譯器知道有這麼一個類,也就是說它能識別Engine *engine;
而在implementation文件中,如果你想要訪問engine.price, 編譯器就會出錯, 即使你用了@class引入了. 這時需要使用的其實是#import 來引入Engine.h這個頭文件,它包括這個類的所有的定義, 它
知道你有定義一個price, 而通過@class引入的除了類本身之外,沒有具體的信息.
#import<> 跟 #import""又什麼區別?“”的意思是自己創建的文件,用這個首先會在當前的目錄中尋找,如果找不到就到其他的位置尋找,“”和<>是相對的一個是自己創建的文件一個是系統的文件
更詳細的分析:
在Objective-c中,當一個類需要引用另一個類的接口時,需要在類的頭文件中建立被引用類的指針
Person.h
@interface Person: NSObject
{
Woman *woman;
Man *man;
}
.......
如果直接編譯,會出錯,因為不知道Woman,Man是什麼。
這時有兩個選擇,一是import這兩個被引用類的頭文件,另一個是使用@class申明Woman和Man是類名,二者的區別:
1. import會包含這個類的所有信息,包括實體變量和方法,而@class只是告訴編譯器,其後面聲明的名稱是類的名稱,至於這些類是如何定義的,暫時不用考慮,後面會再告訴你;
2. 在頭文件中,一般只需要知道被引用的類的名稱就可以了,不需要知道其內部的實體變量和方法,所以在頭文件中一般使用@class來聲明這個名稱是類的名稱,而在類的實現部分,因為會用到這個引用類的內部的實體變量和方法,所以需要使用#import來包含這個被引用類的頭文件。
3. 在編譯效率方面考慮,如果你有100個頭文件都#import了同一個頭文件,或者這些文件是依次被引用的,如A–>B, B–>C, C–>D這樣的引用關系。當最開始的那個頭文件有變化的話,後
面所有引用它的類都需要重新編譯,如果你的類有很多的話,這將耗費大量的時間。而是用@class則不會。
4. 如果有循環依賴關系,如:A–>B, B–>A這樣的相互依賴關系,如果使用#import來相互包含,那麼就會出現編譯錯誤,如果使用@class在兩個類的頭文件中相互聲明,則不會有編譯錯誤出現。
所以,一般來說,@class是放在interface中的,只是為了在interface中引用這個類,把這個類作為一個類型來用的。 在實現這個接口的實現類中,如果需要引用這個類的實體變量或者方法之類的(存在繼承關系或者代理),還是需要import在@class中聲明的類進來.