<iOS>关于自定义description的一点用法

今天在写一段代码时, 自定义了一个UIView, 并且修改了其description 显示, 

修改如下:

- (NSString *)description {

    NSLog(@"XXXX");

    NSString *selfDes = [NSString stringWithFormat:@"self=%@, yourAge=%d", self, self.yourAge];

    return selfDes;

}

运行时, 发现, 在使用NSLog这个自定义的UIView对象时, 发现程序崩溃,而且提示也比较莫名其妙,错误信息如下:

0x1c03b9c:  calll  0x1c03ba1                 ; __CFStringAppendFormatCore + 17

然后在左边的调试栈中,发现有大量的调用[SIniView description];  于是便推测,可以这个方法被多次调用, 然后才想到加入一免NSLog(@"xxxx");

运行发现在崩溃前, xxxx被反复地调用并显示出来。


后来,分析问题的原因,在于自定义description时,不能在里面还去调用self的转换成NSString的输出。因为在description中再去取self=%@,会使得里面又会调用自己的description方法。 所以形成了无效循环, 直到系统资源耗尽。

但是在description中,输入自己的其它对象,则是可以的。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值