Apabila memanipulasi nilai bait dalam Go, selalunya perlu bekerja dengan bit individu. Artikel ini meneroka kaedah untuk mengekstrak perwakilan bit daripada bait, menangani cabaran khusus untuk menentukan perwakilan bit untuk nilai bait 1.
Untuk mewakili bit secara visual dalam bait, anda boleh menggunakan fmt.Sprintf("b", ...), seperti yang dicadangkan oleh orang lain. Walau bagaimanapun, untuk operasi matematik yang melibatkan bit, operator bitwise adalah penting.
Untuk menentukan nth bit bait, laksanakan operasi bitwise AND (&) antara bait dan bait dengan bit nth ditetapkan kepada 1 (topeng). Topeng ini dikira sebagai 2n-1.
Untuk mencari bit pertama nombor 13 (00001101), tutupkannya dengan 20 = 1 (00000001):
fmt.Print(13 & 1) // Output: 1
Hasilnya ialah 1, menunjukkan bahawa bit pertama ialah 1.
Jarak Hamming antara dua bait ukuran bilangan bit yang berbeza. Berikut ialah fungsi yang mengira jarak Hamming antara dua tatasusunan bait (tatasusunan bait tunggal dalam senario yang diberikan):
func hamming(a, b []byte) (int, error) { if len(a) != len(b) { return 0, errors.New("a b are not the same length") } diff := 0 for i := 0; i < len(a); i++ { b1 := a[i] b2 := b[i] for j := 0; j < 8; j++ { mask := byte(1 << uint(j)) if (b1 & mask) != (b2 & mask) { diff++ } } } return diff, nil }
Fungsi ini menggunakan operasi bitwise AND untuk membandingkan bit tatasusunan bait yang sepadan. The Go Playground menunjukkan penggunaannya:
https://play.golang.org/p/O1EGdzDYAn
Atas ialah kandungan terperinci Bagaimanakah saya boleh mengekstrak perwakilan bit nilai bait dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!