Objective-C中有一些很有趣的数据类型经常会被错误地理解。他们中的大多数都可以在/usr/include/objc/objc.h或者这个目录中的其他头文件中找到。下面是从objc.h中摘录的一段,定义了一些数据类型:
objc.h
-
typedef
struct objc_class *Class; -
typedef struct objc_object { -
Class isa; -
}
*id; -
-
typedef
struct objc_selector
*SEL; -
typedef
id (*IMP)(id, SEL,
…); -
typedef
signed char BOOL; -
-
#define
YES(BOOL)1 -
#define
NO(BOOL)0 -
-
#ifndef
Nil -
#define
Nil 0 -
#endif
-
-
#ifndef
nil -
#define
nil 0 -
#endif
id
id和void
*并非完全一样。在上面的代码中,id是指向struct objc_object的一个指针,这个意思基本上是说,id是一个指向任何一个继承了Object(或者NSObject)类的对象。需要注意的是id是一个指针,所以你在使用id的时候不需要加星号。比如id foo=nil定义了一个nil指针,这个指针指向NSObject的一个任意子类。而id *foo=nil则定义了一个指针,这个指针指向另一个指针,被指向的这个指针指向NSObject的一个子类。
nil
nil和C语言的NULL相同,在objc/objc.h中定义。nil表示一个Objctive-C对象,这个对象的指针指向空(没有东西就是空)。
Nil
首字母大写的Nil和nil有一点不一样,Nil定义一个指向空的类(是Class,而不是对象)。
SEL
这个很有趣。SEL是“selector”的一个类型,表示一个方法的名字。比如以下方法:
-[Foo
和 -[Bar
使用同一个selector,它们的selector叫做count。
在上面的头文件里我们看到,SEL是指向
Objective-C的运行时间库和NeXT Objective-C的运行运行时间库(Mac OS X使用NeXT的运行时间库)时,它们的定义是不一样的。实际上Mac OSX仅仅将SEL映射为C字符串。比如,我们定义一个Foo的类,这个类带有一个- (int)
blah方法,那么以下代码:
-
NSLog
(@"SEL=%s", @selector(blah)); 会输出为 SEL=blah。说白了SEL就是返回方法名。
IMP