新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
c++中#import、#include、@class三者的区别是什么?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
成都创新互联公司服务项目包括屯昌网站建设、屯昌网站制作、屯昌网页制作以及屯昌网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,屯昌网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到屯昌省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!
1. 一般来说,导入objective c的头文件时用#import,包含c/c++头文件时用#include。
2. #import 确定一个文件只能被导入一次,这使你在递归包含中不会出现问题。<标记>
所以,#import比起#include的好处就是不会引起交叉编译。
#import && #class:
1. import会包含这个类的所有信息,包括实体变量和方法(.h文件中),而@class只是告诉编译器,其后面声明的名称是类的名称,至于这些类是如何定义的,后面会再告诉你。
2. 在头文件中, 一般只需要知道被引用的类的名称就可以了。 不需要知道其内部的实体变量和方法,所以在头文件中一般使用@class来声明这个名称是类的名称。 而在实现类里面,因为会用到这个引用类的内部的实体变量和方法,所以需要使用#import来包含这个被引用类的头文件。
备注:#import 就是把被引用类的头文件走一遍,即把.h文件里的变量和方法包含进来一次,且仅一次,而@class不用,所以后者编译效率更高。
3. 在编译效率方面考虑,如果你有100个头文件都#import了同一个头文件,或者这些文件是依次引用的,如A–>B, B–>C, C–>D这样的引用关系。当最开始的那个头文件有变化的话,后面所有引用它的类都需要重新编译,如果你的类有很多的话,这将耗费大量的时间。而是用@class则不会。
4. 如果有循环依赖关系,如:A–>B, B–>A这样的相互依赖关系,如果使用#import来相互包含,那么就会出现编译错误,如果使用@class在两个类的头文件中相互声明,则不会有编译错误出现。
备注:实践证明,A,B相互#import不会出现编译错误。因为<标记>处已经说明#import时文件只被导入一次,所以此条不成立。
总结:
1. 如果不是c/c++,尽量用#import。
2. 能在实现文件中#import,就不在头文件中#import。
3. 能在头文件中@class+实现文件中#import,就不在头文件中
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。