在面向对象objective-C语言中,当一个类使用到另一个类时,并且在类的头文件中需要创建被引用的指针时,可以#import方式引入,通过@class引入;
1、运用#import方式:会包含被引用类的所有信息,包括被引用类的变量和方法;
运用@class方式:告诉编译器只是类的声明,具体这个类里有什么信息,如何定义的,这里不需要知道,等实现文件中真正要用到时,才会真正去查看被引用类中的信息(属性,方法);
2、在头文件中, 一般只需要知道被引用的类的名称就可以了。不需要知道其内部的实体变量和方法,所以在头文件中一般使用@class来声明这个名称是类的名称。 而在实现类由于要用到这个引用类的内部的实体变量和方法,所以需要使用#import来包含这个被引用类的头文件。
3、通过上面2点也很容易知道在编译效率上,如果有上百个头文件都#import了同一 个文件,或者这些文件依次被#improt(A->B, B->C,C->D…),一旦最开始的头文件稍有改动,后面引用到这个文件的所有类都需要重新编译一遍,这样的效率也是可想而知的,而相对来 讲,使用@class方式就不会出现这种问题了;
可见,@class是放在interface中的,只是为了在interface中引用这个类,把这个类作为一个类型来用的。如果需要引用到被引用类的实体变量或者方法时, 在实现类中还需要使用#import方式引入被引用类。简单来说:使用@class关键字,使其编译通过, 使用#improt关键字,使其运行通过。
当我们在代码中使用两次#include的时候会报错:因为#include相当于拷贝头文件中的声明内容,所以会报重复定义的错误
。但是使用两次#import的话,不会报错,所以它可以解决重复导入的问题,它会做一次判断,如果已经导入一次就不导入了。