Source File
version4.go
Belonging Package
github.com/google/uuid
// Copyright 2016 Google Inc. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package uuid
import
// New creates a new random UUID or panics. New is equivalent to
// the expression
//
// uuid.Must(uuid.NewRandom())
func () UUID {
return Must(NewRandom())
}
// NewString creates a new random UUID and returns it as a string or panics.
// NewString is equivalent to the expression
//
// uuid.New().String()
func () string {
return Must(NewRandom()).String()
}
// NewRandom returns a Random (Version 4) UUID.
//
// The strength of the UUIDs is based on the strength of the crypto/rand
// package.
//
// Uses the randomness pool if it was enabled with EnableRandPool.
//
// A note about uniqueness derived from the UUID Wikipedia entry:
//
// Randomly generated UUIDs have 122 random bits. One's annual risk of being
// hit by a meteorite is estimated to be one chance in 17 billion, that
// means the probability is about 0.00000000006 (6 × 10−11),
// equivalent to the odds of creating a few tens of trillions of UUIDs in a
// year and having one duplicate.
func () (UUID, error) {
if !poolEnabled {
return NewRandomFromReader(rander)
}
return newRandomFromPool()
}
// NewRandomFromReader returns a UUID based on bytes read from a given io.Reader.
func ( io.Reader) (UUID, error) {
var UUID
, := io.ReadFull(, [:])
if != nil {
return Nil,
}
[6] = ([6] & 0x0f) | 0x40 // Version 4
[8] = ([8] & 0x3f) | 0x80 // Variant is 10
return , nil
}
func newRandomFromPool() (UUID, error) {
var UUID
poolMu.Lock()
if poolPos == randPoolSize {
, := io.ReadFull(rander, pool[:])
if != nil {
poolMu.Unlock()
return Nil,
}
poolPos = 0
}
copy([:], pool[poolPos:(poolPos+16)])
poolPos += 16
poolMu.Unlock()
[6] = ([6] & 0x0f) | 0x40 // Version 4
[8] = ([8] & 0x3f) | 0x80 // Variant is 10
return , nil
}
![]() |
The pages are generated with Golds v0.6.7. (GOOS=linux GOARCH=amd64) Golds is a Go 101 project developed by Tapir Liu. PR and bug reports are welcome and can be submitted to the issue list. Please follow @Go100and1 (reachable from the left QR code) to get the latest news of Golds. |