#import与@class的区别
2015-10-28 16:52
239 查看
1.import会包含这个类的所有信息,包括实体变量和方法,而@class只是告诉编译器,其后面声明的名称是类的名称,至于这些类是如何定义的,暂时不用考虑,后面会再告诉你。
2.在头文件中, 一般只需要知道被引用的类的名称就可以了。 不需要知道其内部的实体变量和方法,所以在头文件中一般使用@class来声明这个名称是类的名称。 而在实现类里面,因为会用到这个引用类的内部的实体变量和方法,所以需要使用#import来包含这个被引用类的头文件。
3.在编译效率方面考虑,如果你有100个头文件都#import了同一个头文件,或者这些文件是依次引用的,如A–>B, B–>C, C–>D这样的引用关系。当最开始的那个头文件有变化的话,后面所有引用它的类都需要重新编译,如果你的类有很多的话,这将耗费大量的时间。而是用@class则不会。
4.如果有循环依赖关系,如:A–>B, B–>A这样的相互依赖关系,如果使用#import来相互包含,那么就会出现编译错误,如果使用@class在两个类的头文件中相互声明,则不会有编译错误出现。
所以,一般来说,@class是放在interface中的,只是为了在interface中引用这个类,把这个类作为一个类型来用的。 在实现这个接口的实现类中,如果需要引用这个类的实体变量或者方法之类的,还是需要import在@class中声明的类进来.
转载自:http://www.cnblogs.com/jqyp/archive/2012/01/13/2321707.html
2.在头文件中, 一般只需要知道被引用的类的名称就可以了。 不需要知道其内部的实体变量和方法,所以在头文件中一般使用@class来声明这个名称是类的名称。 而在实现类里面,因为会用到这个引用类的内部的实体变量和方法,所以需要使用#import来包含这个被引用类的头文件。
3.在编译效率方面考虑,如果你有100个头文件都#import了同一个头文件,或者这些文件是依次引用的,如A–>B, B–>C, C–>D这样的引用关系。当最开始的那个头文件有变化的话,后面所有引用它的类都需要重新编译,如果你的类有很多的话,这将耗费大量的时间。而是用@class则不会。
4.如果有循环依赖关系,如:A–>B, B–>A这样的相互依赖关系,如果使用#import来相互包含,那么就会出现编译错误,如果使用@class在两个类的头文件中相互声明,则不会有编译错误出现。
所以,一般来说,@class是放在interface中的,只是为了在interface中引用这个类,把这个类作为一个类型来用的。 在实现这个接口的实现类中,如果需要引用这个类的实体变量或者方法之类的,还是需要import在@class中声明的类进来.
转载自:http://www.cnblogs.com/jqyp/archive/2012/01/13/2321707.html
相关文章推荐
- linux中查找php***程序例子
- 基于udp的socket编程小例子之使用多线程进行通信
- Node.js的开源、多进程实时WebSocket引擎:SocketCluster
- Xcode7.0 iOS 9.0 Touch 3d demo
- js限制上传文件的大小
- VMware下安装RedHat,Ubuntu,Fedora(下)
- 虚拟机2003没声音的解决办法
- -moz-border-radius CSS属性演示源代码:FireFox下圆角矩形
- resin 配置404错误页面举例
- 给网站添加RSS订阅
- CSS网页布局中 DIV和TABLE超出宽度自动换行的情况分析
- 去掉局域网共享文件夹下的“小手\" 图标
- Win+Apache+PHP+MySQL+Tcomcat(或Resin)
- 网页禁止右键、禁止查看源代码、禁止复制和另存为的代码
- CSS 中文字体的英文名称 (simhei, simsun) 宋体 微软雅黑
- Apache无法启动解决 the requested operation has failed
- Zend studio 5.5 编辑器设置 默认编码
- 屏蔽优酷广告方法
- CSS透明滤镜,支持FF,IE6.0,IE7.0,IE8.0
- 求生之路4的联机方法和秘籍