Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Hasilkan nombor rawak menggunakan kripto/rand. Fungsi Baca daripada dokumentasi bahasa Go

Hasilkan nombor rawak menggunakan kripto/rand. Fungsi Baca daripada dokumentasi bahasa Go

WBOY
WBOYasal
2023-11-04 15:39:15778semak imbas

Hasilkan nombor rawak menggunakan kripto/rand. Fungsi Baca daripada dokumentasi bahasa Go

Gunakan bahasa Go untuk menjana nombor rawak

Bahasa Go ialah bahasa pengaturcaraan moden, ringkas dan cekap yang menyediakan banyak perpustakaan terbina dalam, Boleh digunakan untuk menjana nombor rawak. Antaranya, pakej crypto/rand menyediakan satu siri fungsi untuk menjana nombor rawak yang selamat. Dalam artikel ini, kami akan menjana nombor rawak dengan menggunakan fungsi Baca daripada pakej crypto/rand.

Pertama, kita perlu mengimport pakej crypto/rand dan mencipta tatasusunan bait untuk menyimpan nombor rawak. Contoh kod adalah seperti berikut:

package main

import (
    "crypto/rand"
    "fmt"
)

func main() {
    var randomBytes [16]byte
    _, err := rand.Read(randomBytes[:])
    if err != nil {
        fmt.Println("无法生成随机数:", err)
        return
    }

    fmt.Printf("随机数: %x
", randomBytes)
}

Dalam contoh di atas, kami mencipta tatasusunan bait rawakBytes dengan panjang 16 bait untuk menyimpan nombor rawak yang dijana. Kemudian, kami memanggil fungsi rand.Read untuk mengisi tatasusunan rawakBytes. Fungsi mengembalikan dua nilai Nilai pertama ialah bilangan nombor rawak yang dijana Kami menggunakan garis bawah _ untuk menunjukkan bahawa kami tidak mengambil berat tentang nilai ini. Nilai kedua ialah nilai ralat dan kami menggunakan pembolehubah err untuk menerimanya.

Seterusnya, kami memastikan penjanaan nombor rawak berjaya dengan menyemak pembolehubah err. Jika ralat tidak kosong, ini bermakna ralat telah berlaku semasa menjana nombor rawak, dan kami akan mencetak ralat dan menamatkan atur cara. Jika ralat kosong, ia bermakna penjanaan nombor rawak berjaya.

Akhir sekali, kami menggunakan fungsi fmt.Printf untuk mencetak nombor rawak yang dijana dalam format heksadesimal. Kami menggunakan ruang letak %x untuk mewakili nombor perenambelasan bercetak.

Menggunakan kod di atas, kita boleh menjana nombor rawak dengan panjang 16 bait. Jika anda perlu menjana nombor rawak dengan panjang yang berbeza, cuma ubah suai panjang tatasusunan rawakBytes.

Perlu diingatkan bahawa kerana fungsi rand.Read menggunakan penjana nombor rawak yang disulitkan dalam pakej crypto/rand untuk menjana nombor rawak, nombor rawak yang dijana adalah selamat. Ini bermakna nombor rawak yang dijana adalah cukup rawak dan boleh digunakan dalam senario dengan keperluan keselamatan yang tinggi seperti kriptografi.

Ringkasan:
Dalam artikel ini, kami memperkenalkan cara menggunakan pakej crypto/rand dalam bahasa Go untuk menjana nombor rawak. Dengan menggunakan fungsi rand.Read, kami boleh menjana nombor rawak selamat, yang sesuai untuk senario dengan keperluan keselamatan yang tinggi seperti kriptografi. Saya harap artikel ini akan membantu anda memahami cara menjana nombor rawak dalam bahasa Go.

Atas ialah kandungan terperinci Hasilkan nombor rawak menggunakan kripto/rand. Fungsi Baca daripada dokumentasi bahasa Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn