golangの整数除算

WBOY
WBOYオリジナル
2023-05-27 18:49:381234ブラウズ

Golang は、クロスプラットフォーム、同時プログラミング、強力な型推論などの機能を備えた効率的なプログラミング言語です。整数の除算はプログラムを書くときの基本的な演算です。この記事では、Golang における整数除算のさまざまな方法と詳細について説明します。

まず第一に、整数の値の範囲を理解する必要があります。 Golang では、int 型の長さはオペレーティング システムとアーキテクチャによって異なります。 32 ビット オペレーティング システムでは、int 型の長さは 4 バイト (32 ビット) で、値の範囲は -2147483648 ~ 2147483647 です。 64 ビット オペレーティング システムでは、int 型の長さは 8 バイト (64 ビット) で、値の範囲は -9223372036854775808 ~ 9223372036854775807 です。

Golang では、整数の除算は整数の除算と浮動小数点の除算の 2 種類に分類されます。整数除算の結果は整数型となり、浮動小数点除算の結果は浮動小数点型になります。

次に、Golang における整数の除算をそれぞれ紹介していきます。

  1. 除算演算子 (/)

除算に除算演算子 (/) を使用する場合、Golang は結果の精度を維持するために最善を尽くします。両方の整数が正または負の場合、結果も整数になります。ただし、2 つの整数のうちの 1 つが負の場合、結果はゼロに向かって丸められます (小数部分は切り捨てられます)。例:

fmt.Println(5 / 2)   // 输出 2
fmt.Println(5 / -2)  // 输出 -2
fmt.Println(-5 / 2)  // 输出 -2
fmt.Println(-5 / -2) // 输出 2

除算演算子の結果が予想したものと同じではないことがわかります。これは、Golang が切り捨て操作を実行するためです。正確な結果を得る必要がある場合は、浮動小数点除算を使用できます。

  1. 床除算 (math.FloorDiv)

床除算とは、2 つの整数を割り、最も近い整数に切り捨てることを意味します。 Golang では、 math.FloorDiv 関数を使用して床の分割演算を実行します。

fmt.Println(math.FloorDiv(5, 2))   // 输出 2
fmt.Println(math.FloorDiv(5, -2))  // 输出 -3
fmt.Println(math.FloorDiv(-5, 2))  // 输出 -3
fmt.Println(math.FloorDiv(-5, -2)) // 输出 2

フロア除算を使用すると正確な結果が得られますが、フロア除算は最も近い整数に切り捨てられるため、負の数で除算する場合は注意が必要です。

  1. 直接型変換

直接型変換は単純で大雑把な方法ですが、いくつかの詳細に注意する必要があります。たとえば、2 つの整数を浮動小数点数に強制的に変換してから除算したり、除算結果を整数型に強制的に変換したりすることができます。

var a, b int
a = 5
b = 2
fmt.Println(float64(a) / float64(b)) // 输出 2.5
fmt.Println(int(a / b))              // 输出 2
fmt.Println(int(float64(a) / float64(b))) // 输出 2

直接型変換を使用すると正確な結果が得られますが、型変換プロセス中にオーバーフローや精度の低下が発生する傾向があります。

つまり、整数の除算はプログラミングの基本演算です。 Golang では、除算演算子、floor 除算関数、または直接型変換を使用して整数除算を実装できます。方法が異なれば詳細や適用シナリオも異なるため、柔軟に使用する必要があります。同時に、正確な結果を得るために負の数を除算する際の丸めの問題にも注意する必要があります。

以上がgolangの整数除算の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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