当前位置: 首页> 财经> 金融 > 国内免费plm_2024年5月疫情大爆发_百度竞价托管代运营_企业官网建站

国内免费plm_2024年5月疫情大爆发_百度竞价托管代运营_企业官网建站

时间:2025/7/14 11:57:13来源:https://blog.csdn.net/Coffeemaker88/article/details/144393962 浏览次数:0次
国内免费plm_2024年5月疫情大爆发_百度竞价托管代运营_企业官网建站

传统同步机制

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

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

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

package mainimport ("fmt""sync""time"
)type atomicInt struct {value intlock  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 atomicInta.increment()go func() {a.increment()}()time.Sleep(time.Millisecond)fmt.Println(a.get())
}

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

关键字:国内免费plm_2024年5月疫情大爆发_百度竞价托管代运营_企业官网建站

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: