Go语言学习之并发

简介: Go语言学习之并发

01

概念


并发是指一个 Go 程序运行在多个 goroutine 中,每个 goroutine 中的事件执行先后顺序无法确定。


02

并发安全


并发安全是指一个可以在串行程序中正确执行的函数,它在并发调用时仍然可以正确执行,那么这个函数是并发安全的。


并发访问一个变量,保证变量并发安全的方法是限制变量只存在于一个 goroutine 中,或维护一个更高层的互斥不变量。


函数并发调用时,不能正常执行的原因主要有死锁、活锁和资源耗尽。


03

竞态


竞态是指一个 Go 程序在多个 goroutine 中按照某些交错顺序执行时,这个 Go 程序无法给出正确的执行结果。


其中数据竞态是竞态的一种,它发生于两个 goroutine 并发读写同一个变量并且至少其中一个 goroutine 是写入时。


避免数据竞态的方法:


  • 不修改变量。
  • 避免从多个 goroutine 访问同一个变量。
  • 允许多个 goroutine 访问同一个变量,但在同一时间只有一个 goroutine 可以访问这个变量。


04

互斥锁


在 Go 语言中,sync 包有一个单独的 Mutex 类型,它支持互斥锁模式。Mutex 类型的 Lock 方法用于获取 token,Unlock 方法用于释放 token。


定义的 Mutex 类型的变量称为互斥量,用来保护共享变量。被互斥量保护的变量声明应该紧接在互斥量的声明之后。


为了防止未执行 Unlock 方法,通常在 Lock 方法后,使用 defer 语句调用 Unlock 方法。


05

读写互斥锁


互斥锁严格锁定读和写,在一些场景中,允许只读操作可以并发执行,但写操作需要获得完全独享的访问权限,sync 包中的 RWMutex 类型包含 RLock 和 RUnlock 方法,可以提供这种功能。RLock 和 RUnlock 方法分别获取和释放一个读锁(共享锁)。


06

延迟初始化


sync 包中有一个 Once 类型,Once 类型只有一个 Do 方法,Once 类型包含一个 bool 变量和一个互斥量,bool 变量记录初始化是否已完成,互斥量负责保护这个 bool 变量和客户端的数据结构。


07

goroutine 与线程


goroutine 与线程的区别:


栈内存:线程的栈内存固定大小 2mb,goroutine 栈内存默认 2KB,但可按需增大和缩小,最大限制是 1GB。


调度:线程由系统内核调度,成本高,速度慢。goroutine 由 Go 调度器调度,Go 调度器只需要关心单个 Go 程序的 goroutine 调度问题,成本低。





目录
相关文章
|
9天前
|
存储 JSON 监控
Viper,一个Go语言配置管理神器!
Viper 是一个功能强大的 Go 语言配置管理库,支持从多种来源读取配置,包括文件、环境变量、远程配置中心等。本文详细介绍了 Viper 的核心特性和使用方法,包括从本地 YAML 文件和 Consul 远程配置中心读取配置的示例。Viper 的多来源配置、动态配置和轻松集成特性使其成为管理复杂应用配置的理想选择。
30 2
|
8天前
|
Go 索引
go语言中的循环语句
【11月更文挑战第4天】
19 2
|
8天前
|
Go C++
go语言中的条件语句
【11月更文挑战第4天】
21 2
|
13天前
|
Ubuntu 编译器 Linux
go语言中SQLite3驱动安装
【11月更文挑战第2天】
37 7
|
12天前
|
安全 Go
用 Zap 轻松搞定 Go 语言中的结构化日志
在现代应用程序开发中,日志记录至关重要。Go 语言中有许多日志库,而 Zap 因其高性能和灵活性脱颖而出。本文详细介绍如何在 Go 项目中使用 Zap 进行结构化日志记录,并展示如何定制日志输出,满足生产环境需求。通过基础示例、SugaredLogger 的便捷使用以及自定义日志配置,帮助你在实际开发中高效管理日志。
32 1
|
12天前
|
程序员 Go
go语言中的控制结构
【11月更文挑战第3天】
88 58
|
6天前
|
Go
go语言中的continue 语句
go语言中的continue 语句
16 3
|
11天前
|
监控 Go API
Go语言在微服务架构中的应用实践
在微服务架构的浪潮中,Go语言以其简洁、高效和并发处理能力脱颖而出,成为构建微服务的理想选择。本文将探讨Go语言在微服务架构中的应用实践,包括Go语言的特性如何适应微服务架构的需求,以及在实际开发中如何利用Go语言的特性来提高服务的性能和可维护性。我们将通过一个具体的案例分析,展示Go语言在微服务开发中的优势,并讨论在实际应用中可能遇到的挑战和解决方案。
|
7天前
|
安全 Go 调度
探索Go语言的并发模型:goroutine与channel
在这个快节奏的技术世界中,Go语言以其简洁的并发模型脱颖而出。本文将带你深入了解Go语言的goroutine和channel,这两个核心特性如何协同工作,以实现高效、简洁的并发编程。
|
12天前
|
存储 编译器 Go
go语言中的变量、常量、数据类型
【11月更文挑战第3天】
29 9