zoukankan      html  css  js  c++  java
  • setObject与setValue的区别

    在使用NSMutableDictionary的时候经常会使用setValue forKey与setObject forKey,他们经常是可以交互使用的,代码中经常每一种的使用都有。
    1.先看看setValue: forKey:的定义
    @interface NSMutableDictionary(NSKeyValueCoding)
    /* Send -setObject:forKey: to the receiver, unless the value is nil, in which case send -removeObject:forKey:.
    */
    - (void)setValue:(id)value forKey:(NSString *)key;
    @end
    扩展NSMutableDictionary的一个类别,上面注释说的很清楚,发送setObject:forKey 给接收者,也就是调用setObject:forKey方法
    除非value为nil的时候,调用方法removeObject:forKey

    2.看看setObject:forKey:的定义
    @interface NSMutableDictionary :NSDictionary
    - (void)removeObjectForKey:(id)aKey;
    - (void)setObject:(id)anObject forKey:(id <NSCopying>)aKey;
    @end
    注意:setObject:forKey:中Key的对象是一个id类型,并不是NSString,只不过我们经常使用NSString而已。

    现在总结他们2者的区别就是:
    1, setObject:forkey:中value是不能够为nil的,不然会报错。
    setValue:forKey:中value能够为nil,但是当value为nil的时候,会自动调用removeObject:forKey方法
    2, setValue:forKey:中key的参数只能够是NSString类型,而setObject:forKey:的可以是任何类型

    注意:setObject:forKey:对象不能存放nil要与下面的这种情况区分:
    1, [imageDictionarysetObject:[NSNullnull] forKey:indexNumber];
    [NSNull null]表示的是一个空对象,并不是nil,注意这点

    2, setObject:forKey:中Key是NSNumber对象的时候,如下:
        [imageDictionarysetObject:obj forKey:[NSNumber numberWithInt:10]];

    注意:
    上面说的区别是针对调用者是dictionary而言的。
    setObject:forKey:方法NSMutabledictionary特有的,而
    setValue:forKey:方法是KVC(键-值编码)的主要方法。

    当 setValue:forKey:方法调用者是对象的时候:
    setValue:forKey:方法是在NSObject对象中创建的,也就是说所有的oc对象都有这个方法,所以可以用于任何类。
    比如使用:
    SomeClass *someObj = [[SomeClass alloc] init];
    [someObj setValue:self forKey:@"delegate"];
    表示的意思是:对象someObj设置他的delegate属性的值为当前类,当然调用此方法的对象必须要有delegate属性才能设置,不然调用了也没效果

  • 相关阅读:
    《Vue.js 2.x实践指南》 已出版
    《H5+移动应用实战开发》已出版
    关于《ASP.NET MVC企业级实战》
    ASP.NET MVC企业级实战目录
    ASP.NET MVC4入门到精通系列目录汇总
    网站服务架构
    ASP.NET MVC搭建项目后台UI框架—1、后台主框架
    webpack介绍—上
    通过一个vue+elementUI的小实例来讲解一下它们是如何使用的
    不要为自己学历低找借口
  • 原文地址:https://www.cnblogs.com/lanbodada/p/5534985.html
Copyright © 2011-2022 走看看