• +(void)load
import进时就调用。
父类优于子类,类优于类别。
• +(void)initialize
类的第一个方法调用前调用。+(void)load不当成第一个方法。
父类优于子类调用。
http://www.cnblogs.com/ider/archive/2012/09/29/objective_c_load_vs_initialize.html。
• copy
需要响应<NSCopying>协议的类才可以调用copy方法。即实现
-(id)copyWithZone:(NSZone *)zone
{
MyObj*copy = [[[self class] allocWithZone:zone] init];
……
return copy;
}
• +(BOOL)isSubclassOfClass:(Class)aClass
是否子类
• +(BOOL)instancesRespondToSelector:(SEL)aSelector
类是否响应此方法[?不包括类方法]
•+(BOOL)conformsToProtocol:(Protocol *)aProtocol
类是否响应此协议
• -(void)doesNotRecognizeSelector:(SEL)aSelector
当类不能响应aSelector方法时由系统调用。当要使类的某个方法失效时,也可以手动调用,代码示例如下:
-(id)copy
{
[selfdoesNotRecognizeSelector:_cmd];
}
其中_cmd为每个方法的隐藏参数,代表@selector(copy)的值
• hash 哈希值
每个对象都有一个固定的哈希值,表现形式为NSInteger。Hash相等,isEqual也相等。
• -(BOOL)isProxy
是否代理类。NSProxy类也是和NSObject一样的根类,响应<NSObject>协议。
NSProxy类通过
-(NSMethodSignature*)methodSignatureForSelector:(SEL)sel
和
• (void)forwardInvocation:(NSInvocation*)invocation
方法实现代理。这种方式可以实现多重继承。
但其实NSObject类也有这两个方法,NSObject子类也可以实现消息转发。?mark,NSProxy是否有必要存在??
http://blog.csdn.net/onlyou930/article/details/7548476
-(id)forwardingTargetForSelector:(SEL)sel
{
if([objectrespondsToSelector:sel])
returnobject;
returnnil;
}
forwardingTargetForSelector的作用相当于methodSignatureForSelector和forwardInvocation之和。
•- (IMP)methodForSelector:(SEL)aSelector
取到aSelector方法的地址。IMP是一个address类型。
方法:
-(void)fun:(NSInteger)abc
{
NSLog(@"fun:%d",(int)abc);
}
执行代码:
void(*setter)(id,SEL,NSInteger);
setter=(void(*)(id,SEL,NSInteger))[selfmethodForSelector:@selector(fun:)];
setter(self,@selector(fun:),2000);
结果:fun:2000
优点:每个方法,都有两个隐藏参数,id和SEL。Id是对象名,SEL是方法名。每次执行都需要根据id和SEL找到相应的地址,再执行计算。
setter=(void(*)(id,SEL,NSInteger))[selfmethodForSelector:@selector(fun:)];
这句代码执行后,setter保存了此方法的地址。当重复执行很多次一个方法时,通过setter可以减少查地址的操作,提升效率。
+(IMP)instanceMethodForSelector:(SEL)aSelector是相应的类方法,aSelector只能是实例方法,不能是类方法。
• -(id)autoContentAccessingProxy [?mark]
•+ (BOOL)resolveInstanceMethod:(SEL)name
动态绑定,优于forwarding和respondsToSelector:调用。
voiddynamicMethodIMP(id self, SEL _cmd)
{
//implementation ....
}
+(BOOL) resolveInstanceMethod:(SEL)aSEL
{
if(aSEL == @selector(resolveThisMethodDynamically))
{
class_addMethod([selfclass], aSEL, (IMP) dynamicMethodIMP, "[email protected]:");
returnYES;
}
return[super resolveInstanceMethod:aSel];
}
可以调用[objectresolveThisMethodDynamically]方法;来调用dynamicMethodIMP函数。
http://www.onevcat.com/2012/04/objective-c-runtime/
class_addMethod的相关介绍:http://longtimenoc.com/archives/ios在运行时为类添加方法
meta
class
http://blog.csdn.net/weiqubo/article/details/7367073
object-c运行时
http://www.linuxidc.com/Linux/2012-02/54989.htm
• +(void)setVersion:(NSInteger)aVersion
设置version。归档时有用。
14.– awakeAfterUsingCoder:
– classForCoder
– classForKeyedArchiver
+ classFallbacksForKeyedArchiver
+ classForKeyedUnarchiver
– replacementObjectForCoder:
– replacementObjectForKeyedArchiver:
[?mark归档相关方法]