當前位置: 首頁>>代碼示例>>Golang>>正文


Golang RWMutex.RLocker方法代碼示例

本文整理匯總了Golang中sync.RWMutex.RLocker方法的典型用法代碼示例。如果您正苦於以下問題:Golang RWMutex.RLocker方法的具體用法?Golang RWMutex.RLocker怎麽用?Golang RWMutex.RLocker使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在sync.RWMutex的用法示例。


在下文中一共展示了RWMutex.RLocker方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。

示例1: New

func New(wd string, ss Strategizer, gro ...GrabberOption) (*Grabber, error) {
	if wd == "" {
		return nil, MissingWorkDirError
	}
	mx := new(sync.RWMutex)
	g := &Grabber{
		wd:          wd,
		s:           ss,
		writeState:  mx,
		readState:   mx.RLocker(),
		qIn:         make(chan Segmenter, 100), // TODO(negz): Determine best buffer len.
		qOut:        make(chan Segmenter, 100),
		maxRetry:    3,
		doneMx:      new(sync.Mutex),
		pp:          make(chan bool),
		decoder:     yenc.NewDecoder, // TODO(negz): Detect encoding.
		fileCreator: createSegmentFile,
		grabT:       new(tomb.Tomb),
		enqueueT:    new(tomb.Tomb),
	}
	for _, o := range gro {
		if err := o(g); err != nil {
			return nil, err
		}
	}
	if g.name == "" {
		return nil, MissingNameError
	}
	g.hash = util.HashString(g.name)
	return g, nil
}
開發者ID:frank3nst3in,項目名稱:grabby,代碼行數:31,代碼來源:grabber.go

示例2: NewSegment

func NewSegment(ns *nzb.Segment, f Filer) Segmenter {
	mx := new(sync.RWMutex)
	return &Segment{
		ns:           ns,
		f:            f,
		writeState:   mx,
		readState:    mx.RLocker(),
		failedServer: make(map[Serverer]bool),
		failedGroup:  make(map[string]bool),
	}
}
開發者ID:frank3nst3in,項目名稱:grabby,代碼行數:11,代碼來源:segment.go

示例3: BenchmarkMtxBlock

func BenchmarkMtxBlock(b *testing.B) {
	var primer int64
	m := new(sync.RWMutex)
	c := sync.NewCond(m.RLocker())
	die := make(chan struct{})
	for i := 0; i < runtime.GOMAXPROCS(0); i++ {
		go func() {
			for {
				select {
				case <-die:
					return
				default:
					// Gosched doubles as our item of work, as above.
					runtime.Gosched()
				}
				m.Lock()
				atomic.AddInt64(&primer, 1)
				c.Broadcast()
				m.Unlock()
			}
		}()
	}
	b.RunParallel(func(pb *testing.PB) {
		for pb.Next() {
			myPrimer := atomic.LoadInt64(&primer)
			for {
				m.RLock()
				if myPrimer != primer {
					m.RUnlock()
					break
				}
				c.Wait()
				m.RUnlock()
			}
		}
	})
	close(die)
}
開發者ID:twmb,項目名稱:dash,代碼行數:38,代碼來源:block_test.go

示例4: NewFile

func NewFile(nf *nzb.File, g Grabberer, filter ...*regexp.Regexp) Filer {
	mx := new(sync.RWMutex)
	f := &File{
		nf:         nf,
		g:          g,
		hash:       util.HashString(nf.Subject),
		segments:   make([]Segmenter, 0, len(nf.Segments)),
		writeState: mx,
		readState:  mx.RLocker(),
		doneMx:     new(sync.Mutex),
		required:   true,
	}

	for _, ns := range nf.Segments {
		f.segments = append(f.segments, NewSegment(ns, f))
	}

	if par2RE.MatchString(nf.Subject) {
		f.par2 = true
		f.required = false
		f.Pause()
	}

	for _, r := range filter {
		if r.MatchString(nf.Subject) {
			f.filtered = true
			f.required = false
			f.Pause()
		}
	}

	if f.required {
		f.g.FileRequired()
	}

	return f
}
開發者ID:frank3nst3in,項目名稱:grabby,代碼行數:37,代碼來源:file.go


注:本文中的sync.RWMutex.RLocker方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。