go 传统同步机制-mutex

package main

import (
	"fmt"
	"sync"
	"time"
)
/*传统的同步机制很少使用到,因为传统的同步机制都是用共享内存来交换数据的,所以才需要mutxt cond去保护*/
type atomicInt struct {
	value int
	lock sync.Mutex //锁
}
/*atomic 在多个goroutine之间是安全的*/
//互斥量


func (a *atomicInt) increment(){
	a.lock.Lock() //锁住数据
	defer  a.lock.Unlock()//做完之后解锁数据
	a.value ++

}

//将锁控制在一段代码区域中
func (a *atomicInt) incremenSafeSpace(){
	fmt.Println("safe space:start")
	func(){
		a.lock.Lock() //锁住数据
		defer  a.lock.Unlock()//做完之后解锁数据
		a.value ++
	}()
	fmt.Println("safe space:end")

}

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.incremenSafeSpace()
	}()
	time.Sleep(time.Second)
	//读
	//
	fmt.Println(a.get())



/* 在读的时候写,发生了冲突
go run -race atomic.go
==================
WARNING: DATA RACE
	Read at 0x00c000096008 by main goroutine:
	main.main()
	/Users/tao/go/src/learn/basic/channel10/atomic/atomic.go:31 +0xc5

	Previous write at 0x00c000096008 by goroutine 7:
	main.main.func1()
	/Users/tao/go/src/learn/basic/channel10/atomic/atomic.go:14 +0x51

	Goroutine 7 (finished) created at:
	main.main()
	/Users/tao/go/src/learn/basic/channel10/atomic/atomic.go:24 +0xaa
	==================
*/

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值