ここに私のテストコードがあります:
var myDict: [String: AnyObject] = ["k":"v"]
var a = myDict["k"]
var b = a as String
var c = myDict["k"] as String
Xcode6-beta6 での私の Swift プレイグラウンドは次のとおりです。
型推論のルールによれば、c
論理的に矛盾することについて文句を言うことは、文句を言わないことではありませんb
か?
ここに私のテストコードがあります:
var myDict: [String: AnyObject] = ["k":"v"]
var a = myDict["k"]
var b = a as String
var c = myDict["k"] as String
Xcode6-beta6 での私の Swift プレイグラウンドは次のとおりです。
型推論のルールによれば、c
論理的に矛盾することについて文句を言うことは、文句を言わないことではありませんb
か?
これは、 に2 つの添字オーバーロードDictionary
があるという事実に関係しています。
subscript (key: Key) -> Value?
subscript (i: DictionaryIndex<Key, Value>) -> (Key, Value) { get }
1 つ目は、キーを渡すおなじみのもので、オプションの値が与えられます。キーに値を設定するために使用できます。
2 つ目はあまり一般的ではありません。はDictionaryIndex
一種の辞書への反復子であり、それを添え字として使用して、その反復子でキーと値のペアを直接取得できます。
コンパイラが一致するオーバーロードを見つけられない場合 (この場合、最初のオーバーロードは、非オプションにキャストできないオプションを返すため一致しませんString
)、任意に 1 つを選択します(まあ、任意のようです)。とにかく私に)エラーに表示します。この場所では、認識できない 2 番目のものを選択します。そのため、エラーは奇妙に思えます。
これは機能します。
var c = myDict["k"] as AnyObject! as String // "v"
あなたの質問に答えるために、Swift が不平を言う理由は、これら 2 つの変換を一度に行おうとしている可能性があります。ステートメントvar a = myDict["k"]
には暗黙的な変換が既に含まれていることに注意してください。暗黙の変換はAnyObject?
であるため、上記は次のようにも機能します。
var c = myDict["k"] as AnyObject? as String // "v"
"k"
キーが定義されていない場合、上記は実行時エラーにつながることに注意してください。nil
にキャストすることで、これを返すことができますString?
。