golang には暗黙的な型変換はありません。すべての型変換は、構文 "valueOfTypeB = typeB(valueOfTypeA)" を使用して明示的に宣言する必要があります。型変換は定義が正しい場合にのみ成功するため、値の範囲が大きい型から値の範囲が小さい型に変換すると、精度の低下 (切り捨て) が発生します。
このチュートリアルの動作環境: Windows10 システム、GO 1.11.2、thinkpad t480 コンピューター。
Go 言語のデータ型変換
型変換は、値がある型から別の型に変換されるときに発生します。 c/c や Java などの静的言語では暗黙的な型変換が提供されますが、golang のような強力な型システムでは異なり、Golang は自動型変換や暗黙的な型変換をサポートしていません。
Go 言語には暗黙的な型変換がないため、すべての型変換は明示的に宣言する必要があります。
1 |
|
の意味は次のとおりです。 型 B の値 = 型 B (値型 A)
例:
1 2 |
|
型変換は、定義が正しい場合にのみ成功します。たとえば、範囲が狭い値から型変換への型変換です。値の範囲が大きい型 (int16 を int32 に変換)。より大きな範囲の型からより小さな範囲の型に変換するとき (int32 から int16 または float32 から int に変換)、精度の損失 (切り捨て) が発生します。
同じ基礎となる型の変数のみを相互に変換できます (int16 型を int32 型に変換するなど)。異なる基礎となる型の変数を相互に変換すると、コンパイル エラーが発生します。 bool 型を int 型に変換します).):
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
|
コードの説明は次のとおりです:
行 11 ~ 14 は、いくつかの一般的な整数の数値範囲を出力します。種類。
17 行目で、int32 型の変数 a を宣言し、初期化します。
19 行目では、fmt.Printf の %x 動詞を使用して値を 16 進形式で出力しており、変換前の a の 32 ビット値を出力しています。
22行目、aの値をint16型に変換、つまり32ビット符号付き整数型から16ビット符号付き整数型に変換します。 type 値の範囲が int32 型より小さいため、値は切り捨てられます (精度が失われます)。
行 24 は、変換された a 変数値 (b の値) を出力します。これも 16 進数と 10 進数の形式で出力されます。
行 27, math.Pi は math パッケージの定数です。デフォルトでは型がありません。参照される実際の型に基づいて自動的に推定されます。ここで math は.Pi は変数.c に代入されているため、型は float32 です。
29行目、float32をint型に変換して出力します。
コード出力は次のとおりです。
1 2 3 4 5 6 7 |
|
出力結果によると、16 ビット符号付き整数の範囲は -32768 ~ 32767 で、その値は変数 a、1047483647 はこの範囲内にありません。 1047483647 の対応する 16 進値は 0x3e6f54ff ですが、int16 型に変換すると長さが半分に短縮、つまり 16 進数で半分に切られて 0x54ff となり、対応する 10 進値は 21759 となります。
浮動小数点数を整数に変換すると、小数部分が削除され、整数部分のみが残ります。
型変換の練習
実戦1
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
|
テスト結果
1 2 3 |
|
実戦 2
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
|
テスト結果
1 |
|
#実戦 3
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
1 2 |
|
プログラミング ビデオ をご覧ください。 !
以上がgolangでデータ型変換を行う方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。