ホームページ  >  記事  >  バックエンド開発  >  C# での暗黙的および明示的な型変換

C# での暗黙的および明示的な型変換

黄舟
黄舟オリジナル
2017-02-10 15:12:161359ブラウズ

暗黙的変換と明示的変換に関しては、どの言語にもあり、C# も例外ではありません。よく使用される状況としては、算術式を記述する場合、全体のデータ型が一貫していて、計算が正確である必要がある場合です。たとえば、int 型の変数 a があり、これは加算、減算、乗算、除算によって取得されます。演算 明示的な変換の使用を検討する必要があります。除算演算は float または double に変換する必要があり、その結果は強制的に int に変換される必要があります。明示的な変換を行うか、コレクションに値を割り当てるときに型にも注意する必要があります。
1. 暗黙的な型変換
いわゆる暗黙的な変換は、ストレージ容量の小さいデータ型が自動的にストレージ容量の大きいデータ型に変換されることです。以下の型があります:
sbyte型からshort、int、long、float、double、または10進数型まで。

byte 型から short、ushort、int、uint、long、ulong、float、double、または 10 進数型まで。

short型からint、long、float、double、または10進型まで。

ushort 型から int、uint、long、ulong、float、double、または 10 進数型へ。

int型からlong、float、double、または10進型まで。

uint 型から、long、ulong、float、double、または 10 進数型まで。

long型からfloat型、double型、またはdecimal型まで。

ulong 型から float、double、または 10 進数型まで。

char型からushort、int、uint、long、ulong、float、double、または10進型まで。

float型からdouble型へ。


2. 明示的な型変換

明示的な型変換、つまり強制的な型変換。暗黙的な変換とは対照的に、キャストではデータ損失が発生します。

sbyte から byte、ushort、uint、ulong、または char へ。

バイトからsbyteまたはcharへ。

short から sbyte、byte、ushort、uint、ulong、または char まで。

ushort から sbyte、byte、short、または char まで。

int から sbyte、byte、short、ushort、uint、ulong、または char。

uint から sbyte、byte、short、ushort、int、または char。

long から sbyte、byte、short、ushort、int、uint、ulong、または char。

ulong から sbyte、byte、short、ushort、int、uint、long、または char まで。

charからsbyte、byte、またはshortまで。

float から sbyte、byte、short、ushort、int、uint、long、ulong、char、または 10 進数まで。

double から sbyte、byte、short、ushort、int、uint、long、ulong、char、float、または 10 進数まで。

10 進数から sbyte、byte、short、ushort、int、uint、long、ulong、char、float、または double まで。

変換によって情報が失われたり、例外がスローされる場合、変換は次の規則に従って実行されます:

ある整数型から別の整数型への変換では、オーバーフローが発生しない場合、コンパイラーは変換に対してオーバーフロー検出を実行します。 , 変換は成功しますが、それ以外の場合は OverflowException がスローされます。この検出は、チェックされたオプションがコンパイラに設定されているかどうかにも関係します。

float、double、または 10 進数から整数への変換の場合、ソース変数の値は、変換結果として最も近い整数値に丸められます。整数値が対象の型の範囲を超える場合、OverflowException がスローされます。

double から float への変換では、double 値は最も近い float 値に丸められます。この値が小さすぎる場合、結果は正の 0 または負の 0 になり、この値が大きすぎる場合は正の
無限大または負の無限大になります。元の double 値が Nan の場合、変換結果も NaN になります。

float または double から 10 進数への変換の場合、ソース値は 10 進数形式に変換され、(必要に応じて) 小数点以下 28 桁に丸められます。ソース値が小さすぎる場合、結果は 0 になります。大きすぎて 10 進数で表現できない場合、または無限大または NaN の場合は、InvalidCastException がスローされます。

10 進数から float または double への変換では、10 進数の値は最も近い値に丸められます。この変換では精度が失われる可能性がありますが、例外は発生しません。

上記は C# における暗黙的および明示的な型変換の内容です。さらに関連する内容については、PHP 中国語 Web サイト (www.php.cn) に注目してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。