前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[Go] golang的竞争状态

[Go] golang的竞争状态

作者头像
唯一Chat
发布2019-09-10 11:17:04
4810
发布2019-09-10 11:17:04
举报
文章被收录于专栏:陶士涵的菜地

1.goroutine在逻辑处理器的线程上进行交换

2.竞争状态:两个或者多个goroutine在没有互相同步的情况下,访问某个共享的资源,并试图同时读和写这个资源,就处于互相竞争的状态 对共享资源的读和写操作必须是原子化的,同一时刻只能有一个goroutine对共享资源进行读和写操作

3.使用竞争检测器编译代码,执行检查竞争状态 go build -race

代码语言:javascript
复制
package main

import (
	"fmt"
	"runtime"
	"sync"
)

//全局共享变量
var (
	//要读写的变量
	counter int
	//wg计数
	wg sync.WaitGroup
)

func main() {
	//只使用一个逻辑处理器
	runtime.GOMAXPROCS(1)
	//增加两个goroutine
	wg.Add(2)
	go incCounter(1)
	go incCounter(2)
	//等待两个子goroutine结束
	wg.Wait()
	fmt.Println("最终Counter:", counter)
}

//改变counter的值
func incCounter(id int) {
	//减少wg计数
	defer wg.Done()
	for i := 0; i < 2; i++ {
		//获取counter的值,两个goroutine同时启动获取到此时counter的值是0
		//等切换调度后,副本的值还是之前的0
		value := counter
		//当前goroutine从线程退出,放回等待队列,切换到下一个goroutine,强制调度器进行切换
		//以便使竞争状态的效果更明显
		runtime.Gosched()
		value++
		//修改counter的值
		counter = value
	}
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-02-03 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档