Source File
timer.go
Belonging Package
github.com/nats-io/nats.go
// Copyright 2017-2022 The NATS Authors// Licensed under the Apache License, Version 2.0 (the "License");// you may not use this file except in compliance with the License.// You may obtain a copy of the License at//// http://www.apache.org/licenses/LICENSE-2.0//// Unless required by applicable law or agreed to in writing, software// distributed under the License is distributed on an "AS IS" BASIS,// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.// See the License for the specific language governing permissions and// limitations under the License.package natsimport ()// global pool of *time.Timer's. can be used by multiple goroutines concurrently.var globalTimerPool timerPool// timerPool provides GC-able pooling of *time.Timer's.// can be used by multiple goroutines concurrently.type timerPool struct {p sync.Pool}// Get returns a timer that completes after the given duration.func ( *timerPool) ( time.Duration) *time.Timer {if , := .p.Get().(*time.Timer); && != nil {.Reset()return}return time.NewTimer()}// Put pools the given timer.//// There is no need to call t.Stop() before calling Put.//// Put will try to stop the timer before pooling. If the// given timer already expired, Put will read the unreceived// value if there is one.func ( *timerPool) ( *time.Timer) {if !.Stop() {select {case <-.C:default:}}.p.Put()}
![]() |
The pages are generated with Golds v0.8.2. (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 @zigo_101 (reachable from the left QR code) to get the latest news of Golds. |