二者的區(qū)別在于:
1.import會包含這個類的所有信息浑彰,包括實體變量和方法,而@class只是告訴編譯器拯辙,其后面聲明的名稱是類的名稱郭变,至于這些類是如何定義的颜价,暫時不用考慮,后面會再告訴你诉濒。
2.在頭文件中周伦, 一般只需要知道被引用的類的名稱就可以了。 不需要知道其內(nèi)部的實體變量和方法未荒,所以在頭文件中一般使用@class來聲明這個名稱是類的名稱专挪。 而在實現(xiàn)類里面,因為會用到這個引用類的內(nèi)部的實體變量和方法片排,所以需要使用#import來包含這個被引用類的頭文件寨腔。
3.在編譯效率方面考慮,如果你有100個頭文件都#import了同一個頭文件率寡,或者這些文件是依次引用的迫卢,如A–>B, B–>C, C–>D這樣的引用關(guān)系。當(dāng)最開始的那個頭文件有變化的話勇劣,后面所有引用它的類都需要重新編譯靖避,如果你的類有很多的話,這將耗費大量的時間比默。而是用@class則不會幻捏。
4.如果有循環(huán)依賴關(guān)系,如:A–>B, B–>A這樣的相互依賴關(guān)系命咐,如果使用#import來相互包含篡九,那么就會出現(xiàn)編譯錯誤,如果使用@class在兩個類的頭文件中相互聲明醋奠,則不會有編譯錯誤出現(xiàn)榛臼。
所以,一般來說窜司,@class是放在interface中的沛善,只是為了在interface中引用這個類,把這個類作為一個類型來用的塞祈。 在實現(xiàn)這個接口的實現(xiàn)類中金刁,如果需要引用這個類的實體變量或者方法之類的,還是需要import在@class中聲明的類進(jìn)來.