文档章节

老师儿学习IOS 之 一 “实现description方法”

孙启超
 孙启超
发布于 2014/03/27 21:53
字数 1067
阅读 128
收藏 0

输出和debug在老师儿看来同样有很大学问,下面来谈一下:

调试程序时,经常需要打印并查看对象信息。一种比较傻比的方法是把对象的所有属性一一输出到日志中。但是最常用的还是这种直接输出。

    NSLog(@"arr = %@",array);

在构建需要打印到日志的字符串时,array对象会收到description消息,该方法所返回的描述信息将取代“各式字符串”(format string)里的“%@”。比方说,object是个数组,若用下列代码打印其信息:

    NSArray *array = @[@"lao shi",@"didi",@"hou",@(222)];

    NSLog(@"arr = %@",array);

则会输出:

arr = (

    "lao shi",

    didi,

    hou,

    222

)

然而如果输出自定义的类对象时,输出的是

<CustomAlertView: 0x14643e30>

与array为数组时所输出的信息相比,上面这种内容不太有用。除非在自己的类里覆写dexcription方法,否则打印信息时就会调用NSObject类所实现的默认方法。此方法定义在NSObject协议里,不过NSObject类也实现它。因为NSObject并不是唯一的“根类”,所以许多方法都要定义再NSObject协议里。比方说NSProxy也是一个遵从了NSObject协议的“根类”。由于description等方法定义在NSObject协议里,因此像NSProxy这种“根类”及其子类也必须实现他们。如前所见,这些实现好的方法并没有打印出较为有用的内容,只不过是输出了类名和对像的内存地址。只有在你想判断两指针是否真的指向同一对象时,这种信息才有用处。除此之外,再也看不出其他有用的内容了。我们想打印出来的对象信息应该比这更多才对。

要向输出更为有用的信息也很简单,只需覆写description方法并将描述此对象的字符串返回即可。例如,有下面这个代表个人信息的类:

@interface LaoShiEr : NSObject


@property (nonatomic, copy) NSString *name;

@property (nonatomic, copy) NSString *age;


- (id)initWithName:(NSString *)name age:(NSString *)age;


@end


@implementation LaoShiEr


- (id)initWithName:(NSString *)name age:(NSString *)age

{

    if ((self = [super init])) {

        _name = name;

        _age = age;


    }

    return self;

}


@end

该类的description方法通常可以这样实现:

- (NSString *)description

{

    return [NSString stringWithFormat:@"<%@: %p,\"%@ %@\">",[self class],self,_name,_age];

}

假如按上面的代码来写,那么

LaoShiEr对象就会输出如下格式的信息:

@interface LaoShiEr : NSObject


@property (nonatomic, copy, readonly) NSString *name;

@property (nonatomic, copy, readonly) NSString *work;



- (id)initWithName:(NSString *)name

              work:(NSString *)work;


@end

@implementation LaoShiEr



- (id)initWithName:(NSString *)name

              work:(NSString *)work

{

    if ((self = [super init])) {

        _name = [name copy];

        _work = [work copy];

    }

    return self;

}


- (NSString *)description

{

    return [NSString stringWithFormat:@"<%@ : %p,\"%@ %@\">",[self class],self,_name,_work];

}


@end

按照上面的代码来写,输出如下信息

LaoShiEr *laoshi = [[LaoShiEr alloc]

                        initWithName:@"laoshier"

                        work:@"coder"];

    NSLog(@"laoshier = %@",laoshi);

laoshier = <LaoShiEr : 0xb64bec0,"laoshier coder">

这样就比之前所输出得信息更加清楚了,也更为有用了。再description中输出很多互不相同的信息的时候可以借助NSDictionary类的description方法。修改一下老师儿的description方法

- (NSString *)description

{

    return [NSString stringWithFormat:@"<%@ : %p, %@>",[self class],self,@{@"name":_name,@"work":_work}];

}

再此输出

laoshier = <LaoShiEr : 0xb677420, {

    name = laoshier;

    work = coder;

}>

这样是不是看上去非常帅气啊发火

NSObject协议中还有个方法要注意,那就是debugDescription,此方法的用意与description非常想似。二者区别在于,debugDescription方法是开发者在调试器中以控制台命令打印对象时才调用的。在NSObject类的默认实现中,此方法只是直接调用了description。以LaoShiEr为例,我们在创建实例所用的代码后面插入断点,然后通过调试器运行程序,暂停于此:并且po完成对象打印:

<LaoShiEr : 0xb7c4310, {

    name = laoshier;

    work = coder;

}>

当你不想把类名与指针地址这种额外内容放在普通的描述信息里,但是却希望调试的时候能够很方便地看到它们,在此情况下,就可以使用这种输出方式来实现。

- (NSString *)description

{

    return [NSString stringWithFormat:@"<%@>",@{@"name":_name,@"work":_work}];

}


- (NSString *)debugDescription

{

    return [NSString stringWithFormat:@"<%@ : %p, %@>",[self class],self,@{@"name":_name,@"work":_work}];

}


好的,今天就到这里,真正用的到位的话,调试起来会很方便,很省时间,提高效率的。









© 著作权归作者所有

孙启超
粉丝 123
博文 172
码字总数 276188
作品 0
浦东
高级程序员
私信 提问
加载中

评论(0)

【书坊赠书福利——第二期】《iOS 8开发指南》

本周是人邮IT书坊赠书的第二期,第一期参与度极高,微信君在此感谢你们的支持,第一期获奖赠书已全部寄出。 本周赠品 本周,微信君给大家推荐@人民邮电出版社-信息技术分社 刚刚上架的新书《...

生气的散人
2014/09/23
406
0
10个优秀Objective-C和iOS开发在线视频教程

如果你自己开发iOS应用,你肯定会发现网上有很多资源。学习编程的一个最好的方法就是自己写代码,而开始写代码的最快的方式就是看其他人怎么写。我们从海量视频和学习网站中整理出了我们认为...

mingxun
2014/05/09
232
0
IOS学习笔记——Objective-c基础(一)

最近自学ios,ios的支持语言是Objective-c,所以要学习ios就需要先学习Objective-c语言。当掌握了Objective-c的基础知识之后,我们就可以入手学习iOS开发做出一些自己的应用。 我现在还是...

丛林迷雾
2012/12/30
1.3K
1
iOS开发经验总结,我的2019进阶之路!

4G改变了生活,抓住机会的人已经在这个社会有了立足之地,马上迎来5G的时代,你做好准备了吗!对于即将迎来的5G时代,无疑会是音视频的又一个高潮!那么作为程序员的我们,应该怎么样去迎接它...

卓远
2019/04/11
0
0
iOS与JS交互之WKWebView-WKUIDelegate协议

级别:★★☆☆☆ 标签:「iOS与JS交互」「WKWebView与JS交互」「WKUIDelegate」 作者: Xs·H 审校: QiShare团队 先解释下标题:“iOS与JS交互”。iOS指原生代码(文章只有示例),JS指前端...

QiShare
2018/09/03
0
0

没有更多内容

加载失败,请刷新页面

加载更多

郑州哪哪里可以开工程款发票-郑州_新闻网

【电薇同步;1.3.8 - 2.7.4.1 - 5.2.9.7.】张生、诚、信、合、作,保、真、售、后、保、障、长、期、有、效。adb的全称为Android Debug Bridge,是Android手机通用...

yyqqvip
今天
30
0
Nginx 反向代理访问

在Nginx 配置 server { listen 80; server_name www.xiaocx.org www.xiaocx.org www.xiaocx.org; root /Users/maison/work/xiaocx/dist; index i......

韩庚庚
今天
33
0
python笔记:环境变量已设置CMD中一直报错"python"不是内部命令,也不是可运行的程序或批处理文件

这些天虽然也写了几个小工具,但是打包都是在anaconda prompt中完成的,因为CMD中一直报错"python"不是内部命令,也不是可运行的程序或批处理文件,各种查度,千篇一律的是环境变量配置的问题...

小玲_001
今天
13
0
AI+BI服务模式

术语与缩写解释 缩写、术语 解 释 BI 商业智能(Business Intelligence,简称:BI),又称商业智慧或商务智能,指用现代数据仓库技术、线上分析处理技术、数据挖掘和数据展现技术进行数据分析...

zoegu228
今天
28
0
leetcode1227(面试题 17.09. 第 k 个数)--C语言实现

求: 有些数的素因子只有 3,5,7,请设计一个算法找出第 k 个数。注意,不是必须有这些素因子,而是必须不包含其他的素因子。例如,前几个数按顺序应该是 1,3,5,7,9,15,21。 示例 1:...

拓拔北海
今天
27
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部