<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title> &#187; golang sync Cond</title>
	<atom:link href="http://www.liguosong.com/tag/golang-sync-cond/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.liguosong.com</link>
	<description></description>
	<lastBuildDate>Tue, 08 May 2018 01:02:19 +0000</lastBuildDate>
	<language>zh-CN</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.5.2</generator>
		<item>
		<title>golang sync Cond</title>
		<link>http://www.liguosong.com/2014/05/07/golang-sync-cond/</link>
		<comments>http://www.liguosong.com/2014/05/07/golang-sync-cond/#comments</comments>
		<pubDate>Wed, 07 May 2014 12:47:26 +0000</pubDate>
		<dc:creator>lgs</dc:creator>
				<category><![CDATA[golang]]></category>
		<category><![CDATA[golang sync Cond]]></category>

		<guid isPermaLink="false">http://www.liguosong.com/?p=283</guid>
		<description><![CDATA[Cond在Locker的基础上增加的一个消息通知的功能。但是它只能按照顺序去使一个goroutine解除阻塞。 [...]]]></description>
				<content:encoded><![CDATA[<p>Cond在Locker的基础上增加的一个消息通知的功能。但是它只能按照顺序去使一个goroutine解除阻塞。</p>
<p>Cond有三个方法：Wait，Signal，Broadcast。<br />
Wait添加一个计数，也就是添加一个阻塞的goroutine。<br />
Signal解除一个goroutine的阻塞，计数减一。<br />
Broadcast接触所有wait goroutine的阻塞。<span id="more-283"></span></p>
<p>那外部传入的Locker，是对wait，Signal，Broadcast进行保护。防止发送信号的时候，不会有新的goroutine进入wait。在wait逻辑完成前，不会有新的事件发生。</p>
<p><span style="color: #ff0000;">注意：在调用Signal，Broadcast之前，应确保目标进入Wait阻塞状态。</span></p>
<p>例子：</p>
<p>&nbsp;</p>
<pre class="brush:c">package main

import (
	"fmt"
	"sync"
	"time"
)

func main() {
	wait := sync.WaitGroup{}
	locker := new(sync.Mutex)
	cond := sync.NewCond(locker)

	for i := 0; i &lt; 3; i++ {
		go func(i int) {
			defer wait.Done()
			wait.Add(1)
			cond.L.Lock()
			fmt.Println("Waiting start...")
			cond.Wait()
			fmt.Println("Waiting end...")
			cond.L.Unlock()

			fmt.Println("Goroutine run. Number:", i)
		}(i)
	}

	time.Sleep(2e9)
	cond.L.Lock()
	cond.Signal()
	cond.L.Unlock()

	time.Sleep(2e9)
	cond.L.Lock()
	cond.Signal()
	cond.L.Unlock()

	time.Sleep(2e9)
	cond.L.Lock()
	cond.Signal()
	cond.L.Unlock()

	wait.Wait()
}</pre>
<p>输出：</p>
<pre class="brush:c">Waiting start...
Waiting start...
Waiting start...
Waiting end...
Goroutine run. Number: 0
Waiting end...
Goroutine run. Number: 1
Waiting end...
Goroutine run. Number: 2</pre>
<p>可以看出来，每执行一次Signal就会执行一个goroutine。如果想让所有的goroutine执行，那么将所有的Signal换成一个Broadcast方法可以。</p>
]]></content:encoded>
			<wfw:commentRss>http://www.liguosong.com/2014/05/07/golang-sync-cond/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>
