为了账号安全,请及时绑定邮箱和手机立即绑定

iOS模型打印

标签:
Html5

在开发当中,我们很多时候需要打印模型的所有属性。如果我们直接使用NSLog(@"%@",model);的方式,打印出来只是model的内存地址

https://img1.sycdn.imooc.com//5d2dd3b4000170dc07370056.jpg

image.png


解决方法可以通过重写模型的description方法

https://img1.sycdn.imooc.com//5d2dd3b60001825607120337.jpghttps://img1.sycdn.imooc.com//5d2dd3bb0001fb9c07160138.jpg

image.png


这样在我们再次使用NSLog(@"%@",model);的时候,就可以显示模型的所有属性值


https://img1.sycdn.imooc.com//5d2dd3bf0001fb9c07160138.jpg

image.png

但是很多时候,我们在断点调试的时候,并不是使用NSLog(@"%@",model);来打印模型,而是通过po这个命令,我们需要重写debugDescription方法而不是description方法


https://img1.sycdn.imooc.com//5d2dd3c40001bcb907170333.jpg

image.png


我们再次使用NSLog和使用po来打印下


https://img1.sycdn.imooc.com//5d2dd3c8000188f907250388.jpg

image.png

debugDescription方法只会在调试po的时候调用,而在代码中打印不会调用。但是我们需要在每个模型中都重写这个方法,而且代码都不一样,肯定受不了。我的解决方式是写一个NSObject的分类NSObject+DebugDescription并重写debugDescription,并处理了po其他类型的情况


https://img1.sycdn.imooc.com//5d2dd3cc0001965207240357.jpg

image.png


如果是其他数据类型,则返回self.debugDescription。这样的话只有打印model时会打印显示属性,而其他类型就不会受影响了

https://img1.sycdn.imooc.com//5d2dd3da00015fa407200438.jpg

image.png



作者:小明的知识库
链接:https://www.jianshu.com/p/c173d1460463


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消