Merge pull request #19 from nishaad78/monotonic_clock

Optimize monotonic clock code
This commit is contained in:
Skippy 2019-04-11 15:57:57 -05:00 committed by GitHub
commit 7dcf86e66a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -79,7 +79,7 @@ var ErrInvalidBase32 = errors.New("invalid base32")
type Node struct { type Node struct {
mu sync.Mutex mu sync.Mutex
epoch time.Time epoch time.Time
time time.Duration time int64
node int64 node int64
step int64 step int64
@ -132,14 +132,14 @@ func (n *Node) Generate() ID {
n.mu.Lock() n.mu.Lock()
now := time.Since(n.epoch) now := time.Since(n.epoch).Nanoseconds() / 1000000
if now-n.time < time.Millisecond { if now == n.time {
n.step = (n.step + 1) & n.stepMask n.step = (n.step + 1) & n.stepMask
if n.step == 0 { if n.step == 0 {
for now-n.time < time.Millisecond { for now <= n.time {
now = time.Since(n.epoch) now = time.Since(n.epoch).Nanoseconds() / 1000000
} }
} }
} else { } else {
@ -148,7 +148,7 @@ func (n *Node) Generate() ID {
n.time = now n.time = now
r := ID((now.Nanoseconds()/1000000)<<n.timeShift | r := ID((now)<<n.timeShift |
(n.node << n.nodeShift) | (n.node << n.nodeShift) |
(n.step), (n.step),
) )