1.#import会包含这个类的所有信息,包括属性和方法。而@class只是告诉编译器,其后声明的类只是类的名称而已。
2.在头文件中, 一般只需要知道被引用类的名称就可以, 不需要知道其内部的属性和方法,所以在头文件中一般使用@class(向前声明)来声明这个类。 而在实现文件里面,因为会用到这个引用类的内部的属性和方法,所以需要使用#import来引入。
3.在编译效率方面考虑,如果你有100个头文件都#import了同一个头文件,或者这些文件是依次引用的,如A–>B, B–>C, C–>D这样的引用关系。当最开始的那个头文件有变化的话,后面所有引用它的类都需要重新编译,这将耗费大量的时间。而使用@class则不会。
4.如果有如A–>B, B–>A这样的相互依赖关系,如果使用#import来相互包含,那么就会出现编译错误。如果使用@class在两个类的头文件中相互声明,则不会有编译错误出现。
5.但是有时候必须在头文件中使用#import引入其他类,如果你的类继承自某个类,则必须用#import引入那个超类;还有你的类如果要遵从某个协议,那么该协议必须有完整定义,就必须用#import引入,这时候尽量把遵从的协议移至实现文件的分类(class-continuation 分类)中,如果不行,就把协议单独放在一个头文件中。