版本记录
版本号 | 时间 |
---|---|
V1.0 | 2017.08.28 |
前言
NSDictionary
是不可变字典,它的不可变性可以参考NSArray
数组,但是它与数组还是有很大不同,尽管他们都属于集合类,下面这几篇我们继续来将一下基础类的知识。还是老规矩从整体到局部,从浅入深进行讲解,谢谢大家。感兴趣的可以参考我上面几篇。
1. NSDictionary细说(一)—— 整体了解
2. NSDictionary细说(二)—— 字典的创建
3. NSDictionary细说(三)—— 字典的初始化
4. NSDictionary细说(四)—— 共享键集、数量以及相等比较
5. NSDictionary细说(五)—— 键和值的获取
6. NSDictionary细说(六)—— 字典的遍历
7. NSDictionary细说(七)—— 字典的排序
8. NSDictionary细说(八)—— 字典的过滤和存储
9. NSDictionary细说(九)—— 获取文件属性
一、@property(readonly, copy) NSString *description;
该属性的作用是:表示字典内容的字符串,格式为属性列表。
这里还要注意:
- 如果字典中的每个键都是一个
NSString
对象,则这些条目按照按升序排列,否则列表中的条目顺序是未定义的。 此属性旨在为调试目的生成可读输出,而不是用于序列化数据。
看示例代码
- (void)demoDescription
{
NSDictionary *dict = @{@"One" : @1, @"Two" : @2, @"Three" : @3};
NSLog(@"dict = %@", dict.description);
}
看输出结果
2017-08-28 20:49:48.788 JJOC[2927:70247] dict = {
One = 1;
Three = 3;
Two = 2;
}
结论:字典的描述输出。
二、@property(readonly, copy) NSString *descriptionInStringsFileFormat;
该方法的作用是:表示字典内容的字符串,格式为.strings
文件格式。
还要注意:
- 条目列出的顺序是未定义的。除非字典可以由字符串资源文件表示,否则此方法将失败。
看一下示例代码
- (void)demoDescriptionInStringsFileFormat
{
NSDictionary *dict = @{@"One" : @1, @"Two" : @2, @"Three" : @3};
NSLog(@"dict = %@", dict.descriptionInStringsFileFormat);
}
看输出结果
2017-08-28 20:53:17.453 JJOC[3085:73676] dict = "One" = 1;
"Two" = 2;
"Three" = 3;
结论:字典的.string
文件格式的描述。
三、- (NSString *)descriptionWithLocale:(id)locale;
该方法的作用是:返回一个字符串对象,该对象表示字典的内容,格式为属性列表。
下面看一下参数和返回值。
-
locale
:指定用于格式化每个字典的键和值的选项的对象; 如果您不希望他们格式化,则传递为零。在iOS和MacOS 10.5
及更高版本上,NSDictionary
或NSLocale
对象的实例可能用于区域设置。 在OS X v10.4及更早版本中,它必须是NSDictionary的一个实例。 -
return
:有关如何将语言环境应用于字典中的每个元素的说明,请参阅descriptionWithLocale:indent :
,如果字典中的每个键都响应compare:
,这些条目按照升序排列,否则列表的顺序是未定义的。
看示例代码
- (void)demoDescriptionWithLocale
{
NSDictionary *dict = @{@"One" : @1, @"Two" : @2, @"Three" : @3};
NSString *resultStr = [dict descriptionWithLocale:nil];
NSLog(@"resultStr = %@", resultStr);
}
看输出结果
2017-08-28 21:06:47.857 JJOC[3368:83190] resultStr = {
One = 1;
Three = 3;
Two = 2;
}
结论:字典描述的字符串表示。
四、- (NSString *)descriptionWithLocale:(id)locale indent:(NSUInteger)level;
该方法的作用是:返回一个字符串对象,该对象表示字典的内容,格式为属性列表。
下面看一下参数和返回值:
-
locale
:指定用于格式化每个字典的键和值的选项的对象; 如果您不希望他们格式化,则传递为零。在iOS和MacOS 10.5及更高版本上,NSDictionary
或NSLocale
对象的实例可能用于区域设置。 在OS X v10.4及更早版本中,它必须是NSDictionary的一个实例。 -
level
:指定缩进级别,使输出更易读:缩进是(4个空格)* 级别。 -
return
:表示字典内容的字符串对象,格式为属性列表。
还要注意:
- 返回的NSString对象包含每个字典条目的字符串表示形式。
descriptionWithLocale:indent:
获取给定键或值的字符串表示形式,如下所示:- 如果对象是NSString对象,那么它就是按原样使用的。
- 如果对象响应
descriptionWithLocale:indent:
,则调用该方法来获取对象的字符串表示形式。 - 如果对象响应
descriptionWithLocale:
,则调用该方法来获取对象的字符串表示形式。 - 如果没有满足上述条件,则通过其描述属性获取对象的字符串表示。
如果字典中的每个键都响应compare:
,这些条目按照升序排列。 否则,列表中列出的顺序是未定义的。
看示例代码
- (void)demoDescriptionWithLocaleLevel
{
NSDictionary *dict = @{@"One" : @1, @"Two" : @2, @"Three" : @3};
NSString *resultStr = [dict descriptionWithLocale:nil indent:6];
NSLog(@"resultStr = %@", resultStr);
}
看输出结果
2017-08-28 21:15:48.977 JJOC[3735:92273] resultStr = {
One = 1;
Three = 3;
Two = 2;
}
大家可以很明显的看到缩进量,这里是 6 * 4个空格。
结论:字典的字符串表示,这个参数更多要求更详细些。
五、- (instancetype)initWithCoder:(NSCoder *)aDecoder;
该方法的作用就是:通过NSCoder对象获得字典实例化对象。
结论:这是获取字典实例化对象的另外一种情况。
后记
未完,待续~~~