【Golang】Go语言编程思想(六):Channel,第五节,传统同步机制

传统同步机制

上一节介绍 select 的使用时,展示了一个例子,在该例子中,我们首先在 main 函数中使用 generator() 来开启发送数据的 goroutine,之后使用 creatWorker()worker() 开启接受数据的 goroutine,在 main 函数中使用无限循环和 select 建立了一个总控的程序段。使用 channel 和 select 可以方便地在上述四部分(包括 main 函数的主线程以及三个 goroutine 协程)之间进行通信。

上述逻辑成为 Golang 的 CSP 模型,但 Golang 也是由传统的同步机制的,比如 WaitGroup、Mutex 和 Condition Variable。

比如,下例使用库 sync 当中的 Mutex 方法实现了一个线程安全的 int 类型:

go 复制代码
package main

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

type atomicInt struct {
	value int
	lock  sync.Mutex
}

func (a *atomicInt) increment() {
	a.lock.Lock()
	defer a.lock.Unlock()
	a.value++
}

func (a *atomicInt) get() int {
	a.lock.Lock()
	defer a.lock.Unlock()
	return a.value
}

func main() {
	var a atomicInt
	a.increment()
	go func() {
		a.increment()
	}()
	time.Sleep(time.Millisecond)
	fmt.Println(a.get())
}

Golang 当中应该尽可能地不使用传统的同步机制,而是使用 channel 来进行通信。

相关推荐
闲猫6 小时前
go orm GORM
开发语言·后端·golang
丁卯4046 小时前
Go语言中使用viper绑定结构体和yaml文件信息时,标签的使用
服务器·后端·golang
卑微的小鬼20 小时前
rpc和http的区别,为啥golang使用grpc 不使用http?
http·rpc·golang
大脑经常闹风暴@小猿1 天前
1.1 go环境搭建及基本使用
开发语言·后端·golang
tekin1 天前
Go、Java、Python、C/C++、PHP、Rust 语言全方位对比分析
java·c++·golang·编程语言对比·python 语言·php 语言·编程适用场景
zhoupenghui1681 天前
golang时间相关函数总结
服务器·前端·golang·time
孤雪心殇1 天前
简单易懂,解析Go语言中的Map
开发语言·数据结构·后端·golang·go
闲猫1 天前
go 反射 interface{} 判断类型 获取值 设置值 指针才可以设置值
开发语言·后端·golang·反射
Ciderw2 天前
LLVM编译器简介
c++·golang·编译·编译器·gcc·llvm·基础设施
朗迹 - 张伟2 天前
Golang连接使用SqlCipher
开发语言·后端·golang