Golang でのバイト変換のさまざまな状況について説明します。

PHPz
リリース: 2023-04-24 16:59:44
オリジナル
990 人が閲覧しました

Golang は、高いパフォーマンス、同時実行性、保守性を実現するプログラミング言語です。 Golang では、他の言語とは異なり、バイトは実際に独立したデータ型であるため、バイト変換の問題もよく遭遇する問題です。したがって、実際のコーディングでは、データをより適切に処理するために、バイトと他の一般的に使用されるデータ型間の相互変換方法を習得する必要があります。

この記事では、Golang におけるバイト変換のさまざまな状況、関連する関数とその使用法、および実際の開発でこれらの関数を正しく使用する方法について説明します。

1. byte と string の間の相互変換

Golang では、byte と string が最も一般的に使用される 2 つの型です。バイトはデータの最小単位であるため、Golang では非常に一般的に使用され、文字列はテキスト処理モジュールにとって必須の型です。したがって、実際の開発では、バイトと文字列の間の変換が必要になることがよくあります。

バイト型を文字列型に変換するには、string() 関数を使用できます。例:

b := []byte{'g', 'o', 'l', 'a', 'n', 'g'}
s := string(b)
fmt.Println(s) //输出"golang"
ログイン後にコピー

[]byte() 関数を使用して、文字列型をバイト型に変換できます。例:

s := "golang"
b := []byte(s)
fmt.Println(b) //输出[103 111 108 97 110 103]
ログイン後にコピー

2. byte、int、uint 間の相互変換

Golang では、byte、int、および uint 型間の変換もよく使用されます。実際の開発では、データを byte で送信し、受信側で byte を int 型または uint 型に変換する必要があることがよくあります。

int() 関数を使用すると、byte 型を int 型に変換できます。 byte を int に変換すると、byte で表される数値の ASCII コード値を取得できます。例:

b := byte('a')
i := int(b)
fmt.Println(i) //输出97
ログイン後にコピー

uint() 関数を使用して、バイト型を uint 型に変換できます。例:

b := byte(255)
u := uint(b)
fmt.Println(u) //输出255
ログイン後にコピー

Int 型は、byte() 関数を使用して byte 型に変換できます。例:

i := 97
b := byte(i)
fmt.Println(b) //输出97
ログイン後にコピー

Uint 型は、byte() 関数を使用して byte 型に変換できます。例:

u := uint(255)
b := byte(u)
fmt.Println(b) //输出255
ログイン後にコピー

整数型 integer が 255 より大きい場合、バイト型に変換すると精度が失われ、下位 8 桁のみが保持されることに注意してください。同様に、uint型の整数が255より大きい場合、上位の数値は切り捨てられます。

3. byte型とbool型の相互変換

Golangではbool型の値はtrueとfalseのみです。ただし、場合によっては、bool 型の値を byte 型に変換する必要があります。このとき、trueは1、falseは0に変換できます。

bool 型を byte 型に変換するには、byte() 関数を使用できます。例:

b := true
var v byte
if b {
    v = 1
} else {
    v = 0
}
fmt.Println(v) //输出1
ログイン後にコピー

バイト型から bool 型への変換は、具体的な実際の状況によって決まります。多くの場合、バイトが 0 か 1 かを判断してから、if を通じて bool 型に変換する必要があります。声明。例:

b := byte(1)
var v bool
if b == 1 {
    v = true
} else {
    v = false
}
fmt.Println(v) //输出true
ログイン後にコピー

4、byte と float32 および float64 間の相互変換

Golang では、byte と float32 および float64 型の間の変換も非常に一般的です。通常、バイトを通じてデータを送信する必要があり、受信側はバイトを float32 または float64 型に変換する必要があります。

バイト型を float32 型に変換するには、 math.Float32frombits() 関数を使用できます。例:

b := []byte{222, 162, 163, 66}
f := math.Float32frombits(binary.LittleEndian.Uint32(b))
fmt.Println(f) //输出3.14
ログイン後にコピー

バイト型を float64 型に変換するには、 math.Float64frombits() 関数を使用できます。例:

b := []byte{35, 224, 71, 66, 235, 81, 184, 64}
f := math.Float64frombits(binary.LittleEndian.Uint64(b))
fmt.Println(f) //输出3.141592653589793
ログイン後にコピー

math.Float32frombits() 関数と math.Float64frombits() 関数を使用してバイト型を float32 型と float64 型に変換する場合、binary.LittleEndian.Uint32() と binary に注意してください。バイト配列のバイト順序を変換するには .LittleEndian.Uint64() 関数を使用する必要があります。そうしないと、精度エラーが発生する可能性があります。

float32 型を byte 型に変換するには、 math.Float32bits() 関数を使用できます。例:

f := float32(3.14)
b := make([]byte, 4)
binary.LittleEndian.PutUint32(b, math.Float32bits(f))
fmt.Println(b) //输出[222 162 163 66]
ログイン後にコピー

float64 型を byte 型に変換するには、 math.Float64bits() 関数を使用できます。例:

f := float64(3.141592653589793)
b := make([]byte, 8)
binary.LittleEndian.PutUint64(b, math.Float64bits(f))
fmt.Println(b) //输出[35 224 71 66 235 81 184 64]
ログイン後にコピー

math.Float32bits() 関数と math.Float64bits() 関数を使用して float32 型と float64 型をバイト型に変換する場合は、binary.LittleEndian.PutUint32() と binary.LittleEndian を呼び出す必要があります。 PutUint64( ) 関数を使用して、バイト配列のバイト順序が正しいことを確認します。

概要

Golang では、バイト型が広く使用されていますが、データをより適切に処理するには、バイト型と他の一般的な型の間の相互変換方法に習熟する必要があります。この記事では、byteとstring、int、uint、bool、float32、float64間の相互変換方法と対応する関数について詳しく紹介しますので、皆様のお役に立てれば幸いです。

以上がGolang でのバイト変換のさまざまな状況について説明します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!