协程的三种同步方式Channel、Mutex、WaitGroup

1、无缓冲的channel:无缓冲的channel只能发送完之后协程立马阻塞,只有等有协程接受了之后才能继续发送,等待协程接受了,之后立马阻塞,等待channel中有数据才会启动
package main

import (
	"fmt"
	"time"
)

/*
无缓冲的channel只能发送完之后协程立马阻塞,只有等有协程接受了之后才能继续发送,
等待协程接受了,之后立马阻塞,等待channel中有数据才会启动
*/
func main() {
	c := make(chan int) //声明一个int类型的无缓冲通道
	go func() {
		fmt.Println("准备发送1数据")
		c <- 1
		fmt.Println("发送1数据完毕")
		fmt.Println("协程开始睡眠1秒")
		time.Sleep(time.Second)
		fmt.Println("协程结束睡眠")
		c <- 2
		fmt.Println("发送2数据完毕")
	}()

	fmt.Println("主线程休眠1秒")
	time.Sleep(time.Second)
	fmt.Println("主线程结束休眠")
	i := <-c
	fmt.Printf("接受 %d\n", i)
	i = <-c
	fmt.Printf("接受 %d\n", i)
	time.Sleep(time.Second)
}

2、有缓冲的channel:当缓冲区满了发送线程阻塞,缓冲区空了接受线程阻塞

package main

import (
"fmt"
"time"
)
/*
当缓冲区满了发送线程阻塞,缓冲区空了接受线程阻塞
*/

func main() {
	c := make(chan int, 2) //声明一个int类型的有缓冲通道
	go func() {
		for i := 0; i < 4; i++ {
			c <- i
			fmt.Printf("send %d\n", i)
		}
		time.Sleep(5 * time.Second)
		for i := 4; i < 6; i++ {
			c <- i
			fmt.Printf("send %d\n", i)
		}
	}()
	for i := 0; i < 6; i++ {
		time.Sleep(time.Second)
		fmt.Printf("receive %d\n", <-c)
	}
}

3、sync.Mutex

package main

import (
	"fmt"
	"sync"
	"time"
)

var share_cnt uint64 = 0

var lck sync.Mutex

func incrShareCnt() {
	for i := 0; i < 1000000; i++ {
		lck.Lock()
		share_cnt++ //共有资源
		lck.Unlock()
	}
	fmt.Println(share_cnt)
}
func main() {
	for i := 0; i < 2; i++ {
		go incrShareCnt()
	}
	time.Sleep(1 * time.Second) //1秒
}

4、sync.Waitgroup:使用等待组进行多个任务的同步,等待组可以保证在并发环境中完成指定数量的任务

package main

import (
"fmt"
"sync"
)
//使用等待组进行多个任务的同步,等待组可以保证在并发环境中完成指定数量的任务
func main() {
	fmt.Println("Hello World")
	var waitgroup sync.WaitGroup
	waitgroup.Add(1)
	go myFunc(&waitgroup)
	waitgroup.Wait()
	fmt.Println("Finished Execution")
}
func myFunc(waitgroup *sync.WaitGroup) {
	fmt.Println("Inside my goroutine")
	waitgroup.Done()
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在RTOS中,常见的任务同步方式有以下几种: 1. 信号量(Semaphore):信号量是一种计数器,用于控制对共享资源的访问。它可以用来实现任务之间的互斥和同步。当一个任务访问共享资源时,它需要获取信号量,如果信号量为0,则任务会被阻塞,直到其他任务释放信号量。通过适当地使用信号量,可以确保共享资源的独占访问。 2. 互斥锁(Mutex):互斥锁是一种二进制信号量,用于保护共享资源的访问。同一时间只有一个任务能够获取互斥锁的所有权,其他任务需要等待该任务释放锁后才能获取它。互斥锁可以用来避免数据竞争和冲突,确保同一时间只有一个任务能够访问共享资源。 3. 队列(Queue):队列是一种用于在任务之间传递数据的机制。一个任务可以将数据发送到队列中,而另一个任务可以从队列中接收这些数据。队列可以用于实现生产者-消费者模型和任务间的消息传递。 4. 事件标志组(Event Flags):事件标志组是一种用于任务间事件通知的机制。每个事件标志可以表示一个或多个事件,任务可以等待某个或某些事件的发生。当事件发生时,任务可以继续执行或被唤醒。 5. 信号量组(Semaphore Group):信号量组是一种用于多任务同步的机制,类似于信号量。每个信号量组有多个计数器,任务可以等待和释放这些计数器。任务可以通过等待和释放不同的计数器来实现复杂的同步操作。 这些任务同步方式可以根据具体的应用场景和需求来选择和使用。不同的同步方式适用于不同的任务间通信和资源共享的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值