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

    在使用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:[NSNullnullforKey: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属性才能设置,不然调用了也没效果

  • 相关阅读:
    html meta标签
    随滚动条滚动,动态修改元素class
    获取浏览器长宽自动设置
    SpringMVC常用注解實例詳解2:@ModelAttribute
    SpringMVC常用注解實例詳解1:@Controller,@RequestMapping,@RequestParam,@PathVariable
    Freemarker常用指令使用范例
    Spring整合Freemarker
    SpringMVC配置入門
    再谈深浅拷贝 后端
    转发-react 性能深度探讨
  • 原文地址:https://www.cnblogs.com/chengfang/p/4156321.html
Copyright © 2011-2022 走看看