Objective

HeYang
github:https://github.com/HeYang123456789

#import会包含引用类的所有信息(内容),包括引用类的变量和方法
@class仅仅是告诉编译器有这么一个类, 具体这个类里有什么信息, 完全不知

如果有上百个头文件都#import了同一个文件,或者这些文件依次被#import,那么一旦最开始的头文件稍有改动,后面引用到这个文件的所有类都需要重新编译一遍 , 编译效率非常低
相对来讲,使用@class方式就不会出现这种问题了

由于import是一个预编译指令,他会将" "中的文件拷贝到import所在的位置
并且import有一个特点,只有" "中的文件发生了变化,那么import就会重新拷贝一次(更新操作)
注意:由于@class仅仅是告诉编译器后面的名称是一个类,所以编译器并不知道这个类中有哪些属性和方法,所以在.m文件中使用这个类时需要import这个类,才能使用。

总结

使用Import效率低下的缘故:

@Class的使用提高编译效率的缘故:

如果两个类相互拷贝,如果在两个类的.h文件中使用import互相调用,就会出现死循环。所以解决方案也是在两个.h文件中用@class; ,然后在.m文件中import导入需要的类。这样能很好的避免死循环的编译。

4.@class的使用易错注意事项

1 在h头文件中使用@class之后,然后在m实现文件中使用@import注意导入的顺序,一般所在实现文件的对应的头文件是放在最下面的。

2 子类不能在h文件中通过@class导入所继承的父类。

4.@class的使用总结
如果h头文件没有涉及@class所告诉编译器的类的属性和方法,就可以使用@class,然后在对应的m实现文件#import需要用到的类。

未经允许不得转载:Villain博客 » Objective

赞 (0) 打赏

评论 0

评论前必须登录!

登陆 注册

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏