Xcode 4.4 リリースノートに記載されている「Objective-C リテラル」の詳細は何ですか? 質問する

Xcode 4.4 リリースノートに記載されている「Objective-C リテラル」の詳細は何ですか? 質問する

Xcode 4.4 のリリース ノートを読んでいて、次のことに気付きました。

LLVM 4.0 コンパイラ

Xcode には Apple LLVM コンパイラ バージョン 4.0 が含まれ、次の新しい Objective-C 言語機能が含まれています: [...]
- Objective-C リテラル: NSString のリテラルと同じように、NSArray、NSDictionary、および NSNumber のリテラルを作成します。

この機能に興味をそそられています。リテラル for がどのように機能し、それを、、NSStringにどのように使用できるのかは、私にはよくわかりません。NSArrayNSDictionaryNSNumber

詳細は何ですか?

ベストアンサー1

以下からそのままコピーhttp://cocoaheads.tumblr.com/post/17757846453/objective-c-literals-for-nsdictionary-nsarray-and:

Objective-C リテラル:NSArray、NSDictionary、NSNumber のリテラルを作成できるようになりました (NSString のリテラルを作成できるのと同じように)

NSArrayリテラル

以前:

array = [NSArray arrayWithObjects:a, b, c, nil];

今:

array = @[ a, b, c ];

NSDictionary リテラル

以前:

dict = [NSDictionary dictionaryWithObjects:@[o1, o2, o3]
                                   forKeys:@[k1, k2, k3]];

今:

dict = @{ k1 : o1, k2 : o2, k3 : o3 };

NSNumberリテラル

以前:

NSNumber *number;
number = [NSNumber numberWithChar:'X'];
number = [NSNumber numberWithInt:12345];
number = [NSNumber numberWithUnsignedLong:12345ul];
number = [NSNumber numberWithLongLong:12345ll];
number = [NSNumber numberWithFloat:123.45f];
number = [NSNumber numberWithDouble:123.45];
number = [NSNumber numberWithBool:YES];

今:

NSNumber *number;
number = @'X';
number = @12345;
number = @12345ul;
number = @12345ll;
number = @123.45f;
number = @123.45;
number = @YES;

[編集]

ズクソクhttp://news.ycombinator.com/item?id=3672744さらに興味深い新しい添え字が追加されました。(リテラルで追加されました):

arr[1]      === [arr objectAtIndex:1]
dict[@"key"] === [dict objectForKey:@"key"]

[編集2]

新しいObjCリテラルは複数の2012年世界開発会議セッション。各スライドのファイル名と時間は意図的に削除していないので、必要に応じて自分で見つけることができます。基本的にはこの投稿で述べたものと同じですが、画像の上にいくつか新しい点も記載しています。

画像はすべて大きいので注意してください。元のサイズで表示するには、別のタブにドラッグしてください。

リテラルとボクシング

[NSNumber numberWithint:42]
[NSNumber numberWithDouble:10.8]
[NSNumber numberWithBool:YES]
[NSNumber numberWithint:6 + x * 2012]

リテラルとボクシング

@42
@10.8
@YES
@(6 + x * 2012)

コレクションの添え字

[NSArray arrayWithObjects: a, b, c, nil]
[array objectAtIndex:i]
[NSDictionary dictionaryWithObjectsAndKeys: v1, k1, v2, k2, nil];
[dictionary valueForKey:k]

コレクションの添え字

@[a, b, c]
array[i]
@{k1:v1, k2:v2}
dictionary[k]

@# 数値、@{} 辞書、@"" 文字列、@[] 配列、@() 式


この部分は新しいです。式リテラル

式 (M_PI / 16例) がある場合は、それを括弧内に入れる必要があります。

この構文は、数値式、ブール値、(C) 文字列内のインデックスの検索、ブール値、列挙定数、さらには文字列にも機能します。

式リテラル

NSNumber *piOverSixteen = [NSNumber numberWithDouble: (M_PI / 16)];

NSNumber *hexDigit = [NSNumber numberWithChar:"0123456789ABCDEF"[i % 16]];

NSNumber *usesScreenFonts = [NSNumber numberWithBool:[NSLayoutManager usesScreenFonts]];

NSNumber *writingDirection = [NSNumber numberWithInt:NSWritingDirectionLeftToRight];

NSNumber *path = [NSString stringWithUTF8String: getenv("PATH")];

式リテラル

NSNumber *piOverSixteen = @( M_PI / 16 );

NSNumber *hexDigit = @( "0123456789ABCDEF"[i % 16] );

NSNumber *usesScreenFonts = @( [NSLayoutManager usesScreenFonts] );

NSNumber *writingDirection = @( NSWritingDirectionLeftToRight );

NSNumber *path = @( getenv("PATH") );

文字列の詳細と、このリテラル構文をいつどのように使用できるかについて説明します。

ボックス文字列式

NSString *path = [NSString stringWithUTF8String: getenv("PATH")];
for (NSString *dir in [path componentsSeparatedByString: @":"]) {
    // search for a file in dir...
}

ボックス文字列式

NSString *path = @( getenv("PATH") );
for (NSString *dir in [path componentsSeparatedByString: @":"]) {
    // search for a file in dir...
}

配列リテラルの仕組み

配列リテラルの仕組み

// when you write this:
array = @[a, b, c ];

// compiler generates:
id objects[] = { a, b, c };
NSUInteger count = sizeof(objects) / sizeof(id);
array = [NSArray arrayWithObjects:objects count:count];

辞書リテラルの仕組み

辞書リテラルの仕組み

// when you write this:
dict = @{k1 : o1, k2 : o2, k3 : o3 };

// compiler generates:
id objects[] = { o1, o2, o3 };
id keys[] = { k1, k2, k3 };
NSUInteger count = sizeof(objects) / sizeof(id);
dict = [NSDictionary dictionaryWithObjects:objects
                                   forKeys:keys
                                     count:count];

配列の添え字についての詳細

配列の添え字

@implementation SongList {
    NSMutableArray *_songs;
}

- (Song *)replaceSong:(Song *)newSong atindex:(NSUinteger)idx {
    Song *oldSong = [_songs objectAtIndex:idx];
    [_songs replaceObjectAtindex:idx withObject:newSong];
    return oldSong;
}

配列の添え字

@implementation SongList {
    NSMutableArray *_songs;
}

- (Song *)replaceSong:(Song *)newSong atindex:(NSUinteger)idx {
    Song *oldSong = _songs[idx];
    _songs[idx] = newSong;
    return oldSong;
}    

辞書の添え字について

辞書の添え字

@implementation Database {
    NSMutableDictionary *_storage;
}

- (id)replaceObject:(id)newObject forKey:(id <NSCopying>)key {
    id oldObject = [_storage objectForKey:key];
    [_storage setObject:object forKey:key];
    return oldObject;
}

辞書の添え字

@implementation Database {
    NSMutableDictionary *_storage;
}

- (id)replaceObject:(id)newObject forKey:(id <NSCopying>)key {
    id oldObject = _storage[key];
    _storage[key] = newObject;
    return oldObject;
}

[編集3]

マイク・アッシュにはこれらの新しいリテラルに関する素晴らしい記事があります。このことについてもっと知りたい場合は、それをチェックしてください


おすすめ記事