本帖最后由 翟宇浩 于 2015-9-7 11:11 编辑
如:
@interface Dog :NSObject
-(void)run;
@end
@implementation Dog
-(void)run{
NSLog(@"奔跑");
}
@end
Dog *d = [[Dog alloc] init];
NSLog(@"%@",d);
此时打印的结果为 <Dog: 0x1001002e0> ,此时系统调用的就是 descriotion 的方法
我们可以在@impelementation中对description方法进行重写,如:
-(NSString *)description{
return @"你好";
}
此时再执行
NSLog(@"%@",d); 时,就会打印
你好
当我们以%@的格式打印了对象d,此时调用了对象的description方法,对象中如果没有重写父类的description方法,则调用父类
如果我们重写 description的类方法,则:
+(NSString *)description{
return @"类方法";
}
调用的写法为:
NSLog(@"%@",[d class]);
此时[d class]即为Dog ,由于这里不能写类名,所以用[d class]代替类名,打印结果为:
类方法
description使用陷阱:
千万不要在description方法中同时使用%@和self,比如:
-(NSString *)description{
return [NSString stringWithFormat:@"%@",self];
}
同时使用了%@和self,代表要调用self的description方法,因此最终会导致程序陷入死循环,循环调用description方法。
|
|