NSDictionary 的用法样例

#import <Foundation/Foundation.h>

int main(int argc, const char * argv[]) {
    @autoreleasepool {
        //1.实例化一个字典对象
        /*
         字典的元素 是任意的对象地址类型
         元素 是键值对   key - value 必须一一对应 成对出现
         最后 nil 作为结束
         字典内容 是无序的 跟存放顺序无关
         key是唯一 的不能重复    但是 不同的key 可以对应相同的值
         
         key通常写成 NSString *
         
         哈希表 散列函数的算法 进行存放和查找  查找效率非常高
         
         */

        NSDictionary *dict = [[NSDictionary alloc] initWithObjectsAndKeys:@"1",@"one",@"2",@"two",@"3",@"three",@"2015-4-23",@"today",@"xiaohong",@"name",@"2015-4-23",@"date", nil];
        NSLog(@"dict:%@",dict);
        //2.用一个字典实例化另外一个字典
        NSDictionary *dict2 = [[NSDictionary alloc] initWithDictionary:dict];
        NSLog(@"dict2:%@",dict2);
        
        //3.类方法实例化对象
        NSDictionary *dict3 = [NSDictionary dictionaryWithObjectsAndKeys:@"1",@"one",@"2",@"two",@"3",@"three", nil];
        NSLog(@"dict3:%@",dict3);
        
        NSDictionary *dict4 = [NSDictionary dictionaryWithDictionary:dict3];
        NSLog(@"dict4:%@",dict4);
        
        NSArray *keysArr = [[NSArray alloc] initWithObjects:@"one",@"two", nil];
        NSArray *valuesArr = [[NSArray alloc] initWithObjects:@"1",@"2", nil];
        //用两个数组 实例化一个字典 两个数组 元素要一一对应
        NSDictionary *dict5 = [NSDictionary dictionaryWithObjects:valuesArr forKeys:keysArr];
        NSLog(@"dict5:%@",dict5);
        
        //通过key 找到值  重要函数
        
        //只要我们 通过A找A对应的值 那么我们就可以用字典结构来存储
        //查找非常 快
        NSString *str = [dict2 objectForKey:@"date"];
        if (str) {
            NSLog(@"str:%@",str);
        }else {
            NSLog(@"没有找到");//找不到返回nil
        }
        
        
        //快速枚举遍历
        //快速枚举遍历的是key
        for (NSString *key in dict2) {
            NSLog(@"key:%@ - %@",key,[dict2 objectForKey:key]);
        }
        
        //扩展
        //获取字典 所有的key
        NSArray *allKeysArr = [dict2 allKeys];
        NSArray *allValuesArr = [dict2 allValues];
        NSLog(@"%@",allKeysArr);
        NSLog(@"%@",allValuesArr);
        
        
        
    }
    return 0;
}


转载于:https://my.oschina.net/u/2410306/blog/519892

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值