github.com/zebozhuang/go@v0.0.0-20200207033046-f8a98f6f5c5d/src/crypto/rand/rand.go (about)

     1  // Copyright 2010 The Go Authors. All rights reserved.
     2  // Use of this source code is governed by a BSD-style
     3  // license that can be found in the LICENSE file.
     4  
     5  // Package rand implements a cryptographically secure
     6  // pseudorandom number generator.
     7  package rand
     8  
     9  import "io"
    10  
    11  // Reader is a global, shared instance of a cryptographically
    12  // strong pseudo-random generator.
    13  //
    14  // On Linux, Reader uses getrandom(2) if available, /dev/urandom otherwise.
    15  // On OpenBSD, Reader uses getentropy(2).
    16  // On other Unix-like systems, Reader reads from /dev/urandom.
    17  // On Windows systems, Reader uses the CryptGenRandom API.
    18  var Reader io.Reader
    19  
    20  // Read is a helper function that calls Reader.Read using io.ReadFull.
    21  // On return, n == len(b) if and only if err == nil.
    22  func Read(b []byte) (n int, err error) {
    23  	return io.ReadFull(Reader, b)
    24  }