参考:http://www.johnwordsworth.com/2011/01/overriding-nsobjects-description/
对一个自定义的类,在NSLog时,通常不会想当然的输出我们想要的类的全部有用信息,相反,通常只会输出类名、内存地址等简单信息。比如:
NSLog(@"%@", self);
> 2011-01-19 10:20:30.123 AppName[...] <ClassName: 0x000000>
当然,我们可以逐个输出一个类的所有成员的信息,比如像这样:
NSLog(@"Age:%d, Name:%@, Grade:%d", [student age], [student name], [student grade]);
> 2011-01-19 10:20:30.123 AppName[...] Age:10, Name:Jack, Grade:3
这样做毕竟不方便,每次要格式化输出类的所有信息时,都要重复写一遍上面的格式化代码。最好的方法就是,我们复写类的description方法。Objective-C的世界中的类,基本上都已NSObject为基类,复写该类的description方法,在输出类信息的时候像下面这样做就可以了:
NSLog(@"%@", student);
2011-01-19 10:20:30.123 AppName[...] Age:10, Name:Jack, Grade:3
复写description的做法如下:
-(NSString *)description
{
return [NSString stringWithFormat:@"Age:%d, Name:%@, Grade:%d",
[self age], [self name], [self grade]];
}