1.简介

我们在查看代码的时候经常会发现有些地方使用@class而有些地方使用#import,他们到底有什么区别呢,

本文意图去归纳和总结这两种类引用的是的处理方法和规则。

2.分析

此小节会通过一些实例代码来讲解这中引用头文件方式的区别所在。

1.首先我们新建一个Single View Application的工程,在此工程中增加一个继承自NSObject的XFPerson类。

2.观察如下代码的错误原因:

在ViewController.m中声明一个XFPerson变量。

虽然XFPerson的相关文件在工程中,但是要想在其他类中引用这个类则必须将这个类的信息告知当前类,换句话数要让当前类知道要引用的类的基本信息。

我们可以使用两种去处理,可以直接使用@class标签或者使用#import去包含引用类的头文件。

这两种方法都为当前提供了引用类的相关信息,但是信息的详细程度是不一样的。

3.直接使用@class

首先来讨论一下@class标签,其实它提供的信息是最少的,可以说它只是告诉当前类当前类”你所引用的类是存在的,就是叫这个名字,他能做什么我就不知道了“,有时候我们也将@class称之为

预申明。基于这一点我们将ViewController.m中改变如下,通过@class引入XFPerson类信息:

我们可以看到通过这个方式,当前类已经放心的去声明引用类变量了。

但是当我们继续去创建XFPerson对象的时候发现如下错误:

xcode所提示的错误已经很

清楚,XFPerson对于当前类来说只是“forward declaration”预声明,当前类因为@class提供的信息只相信了XFPerson确实存在了,由于

信息太少,根本就不知道这个类中有什么样的方法,也就是他能够做些什么?所以当我们试图去调用XFPerson的一些方法的时候就会出错。

就这个时候就需要#import出手了!

4.使用#import 引用类的头文件

当将@class替换为#import后,编译正常:

5.基类头文件的引用

打开XFPerson.h文件,你会看到xcode自动的帮我们引用了系统的一些头文件:

原因在于我们的类继承自NSObject,那么我们就必须将NSObject这个父类的有文件#import方式引入到子类的头文件中。

关于这一点我们可以以下例子来解释:

我们新创建一个类名为:XFAnimal,它同样继承自NSObject

然后我们将XFPerson的父类换成XFAnimal:

我们看到编译器并不知道XFAnimal的信息,那么我们使用@class标示是否可行呢?

依然报错,错误的原因也很清楚。

接着我们使用#import来引入XFAnimal头文件:

一切正常了。

3.总结

我们可以看到#import既可以在.h也可以在.m中使用,那么我们到底应该如何判断呢?

一般只要记住:

1.如果子类集成父类,那么需要将父类的头文件#import到子类的头文件中。

2.如果在.m文件中引用了某个类,则需要将这个类的头文件#import到.m文件中。

那么在上述分析过程中发现#import与@class相比,提供的信息更加丰富,为什么不直接使用#import呢?

我们在苹果官方文档中看到:

The @class directive minimizes the amount of code seen by the compiler and linker, and is there fore the simplest way to give a forward declaration of a class name. Being simple, it avoids potential problems that may come with importing files that import still other files.

所以最终归纳为:

可以使用@class的地方一定要使用@class,必须使用#import的时候才去使用#import

[New learn]@class和#import的区别使用的更多相关文章

  1. python中import和from...import...的区别

    python中import和from...import...的区别: 只用import时,如import xx,引入的xx是模块名,而不是模块内具体的类.函数.变量等成员,使用该模块的成员时需写成xx ...

  2. 【转载】link和@import的区别

    link和@import的区别 原文地址:http://www.cnblogs.com/zbo/archive/2010/11/17/1879590.html 页面中使用CSS的方式主要有3种:行内添 ...

  3. Objective-C 【关于导入类(@class 和 #import的区别)】

    之前我们分析过 #include 和 #import 的区别,#import不会引起交叉编译,#import 确定一个文件只能被导入一次,使在递归包含中不会出现问题. 那么 #import 和 @cl ...

  4. 引入CSS文件的方式,以及link与@import的区别

    一.引入css的方式 在HTML中引入css的方法主要有4种:行内式.内嵌式.链接式和导入式. 1.行内式 <div style="background:yellow;"&g ...

  5. 页面引入css用link和import的区别

    假设有一个css文件a.css,文件里的内容如下: p { font-size: 18px; } 现在分别使用两种方式引入a.css: 1.使用html的link标签 <link rel=&qu ...

  6. 1ink 与 @import 的区别

    1ink与@import的区别 目录 1ink与@import的区别 差别1:归属关系的差别 差别2:加载顺序的差别 差别3:兼容性的差别 差别4:使用dom控制样式时的差别 1ink与@import ...

  7. import 与 from…import 的区别

    首先你要了解 import 与 from…import 的区别. import 模块:导入一个模块:注:相当于导入的是一个文件夹,是个相对路径. from…import:导入了一个模块中的一个函数:注 ...

  8. 由link和@import的区别引发的CSS渲染杂谈

    我们都知道,外部引入 CSS 有2种方式,link标签和@import. 它们有何本质区别,有何使用建议,在考察外部引入 CSS 这部分内容时,经常被提起. 如今,很多学者本着知其然不欲知其所以然的学 ...

  9. import与from...import...的区别

    from ... import ... 的用法和直接import的区别: 1.直接使用import时,如果需要使用到导入模块内的属性和方法,必须使用模块名.属性和模块名.方法的方式进行调用 2.使用f ...

随机推荐

  1. [ZJOJ2007]时态同步 贪心

    不是很懂为什么luogu标签是树形DP,感觉我想的就是一个贪心啊... 随机造几组数据,我们发现贪心的确可以得到最优解,那么为什么呢? 假设将所有时态贪心的调整是对的,那么如果一个节点的各个儿子时态不 ...

  2. BZOJ3427 Poi2013 Bytecomputer 【dp】

    题目链接 BZOJ3427 题解 容易发现最终序列一定是\(\{-1,0,1\}\)组成的 因为如果有一个位置不是,那么这个位置一定大于\(1\),那么上一个位置一定为\(1\),所以该位置一定加到过 ...

  3. AOJ.850 电缆公司的烦恼 (二分+枚举)

    AOJ.850 电缆公司的烦恼 (二分+枚举) 题意分析 从[1,average]二分枚举长度即可,由于保留2位小数,可以将数据扩大10^2倍后后枚举,输出时除100即可. 代码总览 #include ...

  4. Change the IPTables log file

    http://www.networkinghowtos.com/howto/change-the-iptables-log-file/     An important aspect of any f ...

  5. mybatis分页查询需要注意的问题

    一般对mybatis的分页查询的关键代码就两行: #currentPage代表当前页,pageSize代表每页的行数 PageHelper.startPage(currentPage, pageSiz ...

  6. POJ 1698 最大流

    Alice's Chance Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 7327   Accepted: 2992 De ...

  7. FreeRTOS - 定时器使用注意

    1.只有进入定时器守护任务,从定时器命令队列取出命令,队列空间才会空出一个可用空间:所有定时器公用一个定时器队列 2.如果使用软件定时器,在调度器开始前,会自动创建一个定时器守护任务,configTI ...

  8. CSS知识之 background-position 用法详细介绍

    一.语法 background-position : length || length background-position : position || position 二.取值 length   ...

  9. 深入探索C++对象模型(一)

    再读<深入探索C++对象模型>笔记. 关于对象 C++在加入封装后(只含有数据成员和普通成员函数)的布局成本增加了多少? 答案是并没有增加布局成本.就像C struct一样,memeber ...

  10. c# txt 文件上传、写入TXT文件、创建图形验证码

    asp.net mvc 图片上传 html 在使用包含文件上传控件的表单时,必须使用 enctype="multipart/form-data" 属性 <form encty ...