[Objective-C] 复写NSObject的description方法

本文介绍如何在Objective-C中通过复写NSObject基类的description方法来自定义类的输出格式,提高NSLog输出信息的效率和便利性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参考: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]];
}






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值