Ответы:
Вы используете NSNumber.
У него есть методы init ... и number ..., которые принимают логические значения, как и целые числа и так далее.
Из справочника класса NSNumber :
// Creates and returns an NSNumber object containing a
// given value, treating it as a BOOL.
+ (NSNumber *)numberWithBool:(BOOL)value
и:
// Returns an NSNumber object initialized to contain a
// given value, treated as a BOOL.
- (id)initWithBool:(BOOL)value
и:
// Returns the receiver’s value as a BOOL.
- (BOOL)boolValue
NSDictionary *dictionary = [NSDictionary dictionaryWithObjectsAndKeys:[NSNumber numberWithBool:YES], @"someKey", nil];
@YES
совпадает с[NSNumber numberWithBool:YES]
Если вы объявляете его как литерал и используете clang v3.1 или выше, вы должны использовать @NO / @YES, если вы объявляете его как литерал. Например
NSMutableDictionary* foo = [@{ @"key": @NO } mutableCopy];
foo[@"bar"] = @YES;
Для получения дополнительной информации об этом:
NSDictionary
, но не объект NSMutableDictionary
. Таким образом , назначая @YES
на foo[@"bar"]
это не представляется возможным , так как @{ @"key": @NO }
не является изменяемым.
Как указал jcampbell1 , теперь вы можете использовать буквальный синтаксис для NSNumbers:
NSDictionary *data = @{
// when you always pass same value
@"someKey" : @YES
// if you want to pass some boolean variable
@"anotherKey" : @(someVariable)
};
Попробуй это:
NSMutableDictionary *dic = [[NSMutableDictionary alloc] init];
[dic setObject:[NSNumber numberWithBool:TRUE] forKey:@"Pratik"];
[dic setObject:[NSNumber numberWithBool:FALSE] forKey:@"Sachin"];
if ([dic[@"Pratik"] boolValue])
{
NSLog(@"Boolean is TRUE for 'Pratik'");
}
else
{
NSLog(@"Boolean is FALSE for 'Pratik'");
}
if ([dic[@"Sachin"] boolValue])
{
NSLog(@"Boolean is TRUE for 'Sachin'");
}
else
{
NSLog(@"Boolean is FALSE for 'Sachin'");
}
Результат будет следующим:
Boolean является значение TRUE для ' Pratik '
Логическое значение FALSE для ' Sachin '
[NSNumber numberWithBool:NO]
и [NSNumber numberWithBool:YES]
.