self和super关键字
@class和#import
这两个指令时为了解决循环引用导致的死锁问题
区别:
(1)如果有循环依赖关系,如A->B,B->A这样的相互依赖关系,如果使用#import来相互包含,那么就会出现编译错误,如果使用@class在两个类的头文件中相互声明,则不会有编译错误出现。
(2)#import会包含这个类的所有信息,包括实体变量和方法,而@class只会告诉编译器,其后面声明的名称是类的名称。
(3)在头文件中,一般只需要知道被引用的类的名称就可以了。不需要知道骑内部的实体变量和方法,所以在头文件中一般使用@class来声明这个名称是类的名称。
改变p1对象的值的方法可以这样写:
-(id)changeAge:(int)_Age
{
Age = _Age;
return self;
}
-(id)changeInfo:(id)_p1
{
Age = [_p1 Age];
Identify = [_p1 Identify];
return self;
}
也可以这样写:
-(id)changeInfo:(id)_p1
{
return _p1;
}
OC中,不同的方法用方法名区别,与返回值类型和参数类型无关(与C++不同)
oc中的方法特点:
1.两个方法是否相同,与参数类型和返回值类型无关,即不可以重载。
self 和 super:
1.self 指的是类对象本身。
2.super是父类对象本身。
3.self用来调用本类对象的方法
4.super调用父类的方法
什么是真相?
*self是类的隐藏的参数,指向当前调用方法的类,另一个隐藏参数是_cmd,代表当前类方法的selector。
*super并不是隐藏的参数,它只是一个“编译器指示符”。它和self指向的是相同的消息接受者。
*当使用self调用方法时,会从当前类的方法列表开始找,如果没有,就从父类中再找,而使用super时,则从父类的方法列表中开始找,然后调用父类的这个方法。
@class 和 #import
区别:imort 会包含这个类的所有信息,包括实体变量和方法,而@class 只是告诉编译器,其后面声明的名称是类的名称,至于这些类是如何定义的,暂时不用考虑,后面再告诉你。
在头文件中,一般只需要知道被引用的类的名称就可以了。不需要知道其内部的实体变量和方法,所以在头文件中一般使用@class 来声明这个名称是类的名称。而在实现类里面,因为会用到这个引用类内部的实体变量和方法,所以需要使用#import 来包含这个被引用类的头文件。
如果有循环依赖关系,如:A->B,B->A这样的相互依赖关系。如果使用#import 来相互包含,那么就会出现编译错误,如果使用@class 在两个类的头文件中相互声明,则不会有编译器错误出现。
所以,一般来说,@class是放在interface中的,只是为了在interface中引用这个类,把这个类作为一个类型来用的,在实现这个接口的实现类中,如果需要引用这个类的实体变量或者方法之类的,还需#import。
学员评论
hjc_allen2012-12-19
金仁杰2012-12-02
001bufanbin2012-10-16
你感兴趣的课程