打印字典时有如果里面有中文的话,有时候会打印成unicode,这时候给字典添加一个分类,重写description方法如下:
第一种方法,直接分类解决
- (NSString*)my_description
{
NSString *desc = [self description];
desc = [NSString stringWithCString:[desc cStringUsingEncoding:NSUTF8StringEncoding] encoding:NSNonLossyASCIIStringEncoding];
return desc;
}
使用方法 NSLog(@"%@" , [dic my_description]);
用这个替代系统的打印方法。这样做之后可以基本解决问题。
第二种方法,替换系统description方法
不过以后打印都要手动调用my_description方法,如果不想手动调用,可以使用JRSwizzle将NSDictionary类的description系统方法跟my_description方法进行运行时替换,这样打印时可直接打印字典,无需手动调用my_description方法。
- (NSString*)my_description
{
//方法实现已经交换过,所以并不会递归调用
NSString *desc = [self my_description];
desc = [NSString stringWithCString:[desc cStringUsingEncoding:NSUTF8StringEncoding] encoding:NSNonLossyASCIIStringEncoding];
return desc;
}
[NSDictionary jr_swizzleMethod:@selector(description) withMethod:@selector(my_description) error:nil];
//替换后可直接打印字典
NSLog(@"%@" , dic);
原理如下,一个字典被打印时会调用runtime方法description,现在替换系统description和自己的my_description方法实现,这样再打印时虽然还是调用description方法,但是description函数指针指向的已经是my_description的实现了。如下图: