
用Xcode开发时,有时需要跟踪对象的详细信息内容,但是有时 对象的属性中有数组并且数组的内容为中文时,用NSLog输出对象时,数组中的中文无法显示会无法显示。
例如:
//person类
#import <Foundation/Foundation.h>
@interface Person : NSObject
@PRoperty (nonatomic,copy) NSString *name;
//兴趣属性,为数组
@property (nonatomic,strong) NSArray *interests;
@end
#import "Person.h"
@implementation Person
- (NSString *)description
{
return [NSString stringWithFormat:@"name = %@,interests = %@",_name,_interests];
}
@end
#import <Foundation/Foundation.h>
#import "Person.h"
int main(int argc, const char * argv[])
{
@autoreleasepool {
Person *p = [[Person alloc]init];
p.name = @"王二麻子";
p.interests = @[@"打架",@"嫖娼",@"贩毒"];
//输出p对象的内容
NSLog(@"%@",p);
}
return 0;
}
输出结果:
2014-05-25 20:24:14.887 显示中文[1064:303] name = 王二麻子,interests = (
"\U6253\U67b6",
"\U5ad6\U5a3c",
"\U8d29\U6bd2"
)
Program ended with exit code: -1
要想显示中文,需要对数组添加分类如下:
1 #import "NSArray+Log.h"
2
3 @implementation NSArray (Log)
4
5 - (NSString *)descriptionWithLocale:(id)locale
6 {
7 // 遍历数组中的所有内容,将内容拼接成一个新的字符串返回
8 NSMutableString *strM = [NSMutableString string];
9
10 [strM appendString:@"(\n"];
11
12 // 遍历数组,self就是当前的数组
13 for (id obj in self) {
14 // 在拼接字符串时,会调用obj的description方法
15 [strM appendFormat:@"\t%@,\n", obj];
16 }
17
18 [strM appendString:@")"];
19
20 return strM;
21 }
22
23 @end
再次运行结果:
2014-05-25 20:33:45.259 显示中文[1116:303] name = 王二麻子,interests = (
打架,
嫖娼,
贩毒,
)