Go语学习笔记 - 读写锁 | 从零开始Go语言

简介: Go语学习笔记 - 读写锁 | 从零开始Go语言

学习笔记,写到哪是哪。


读写锁是我们工作中常用的,说白了,可以同时读,但是不能同时写。


样例代码如下


package main
import (
  "fmt"
  "sync"
  "time"
)
var (
  rwCount  int
  myRWLock sync.RWMutex
  wg2      sync.WaitGroup
)
func ReadCount() int {
  myRWLock.RLock()
  fmt.Println("ReadCount readlock ")
  time.Sleep(time.Second)
  defer myRWLock.RUnlock()
  defer fmt.Println("ReadCount unreadlock ")
  return rwCount
}
func ReadCount1() int {
  myRWLock.RLock()
  fmt.Println("ReadCount1 readlock ")
  time.Sleep(time.Second)
  defer myRWLock.RUnlock()
  defer fmt.Println("ReadCount1 unreadlock ")
  return rwCount
}
func HandleCount() {
  myRWLock.Lock()
  fmt.Println("HandleCount writelock ")
  time.Sleep(time.Second)
  defer myRWLock.Unlock()
  defer fmt.Println("HandleCount unwritelock ")
  rwCount += 1
}
func main() {
  wg2.Add(3)
  go func() {
  defer wg2.Done()
  for i := 0; i < 11; i++ {
    fmt.Println("count1 -> ", ReadCount())
  }
  }()
  go func() {
  defer wg2.Done()
  for i := 0; i < 11; i++ {
    fmt.Println("count2 -> ", ReadCount1())
  }
  }()
  go func() {
  defer wg2.Done()
  for i := 0; i < 10; i++ {
    HandleCount()
    fmt.Println("count -> add 1")
  }
  }()
  wg2.Wait()
}

执行结果片段


ReadCount1 readlock

ReadCount readlock

ReadCount1 unreadlock

count2 ->  0

ReadCount unreadlock

count1 ->  0

HandleCount writelock

HandleCount unwritelock

count -> add 1

ReadCount readlock

ReadCount1 readlock

ReadCount1 unreadlock

count2 ->  1

ReadCount unreadlock

count1 ->  1


注意


1、可以看到两个读数据协程都可以获取到读锁。


2、使用了 sync.WaitGroup进行协程等待。


相关文章
|
6天前
|
网络协议 安全 Go
Go语言进行网络编程可以通过**使用TCP/IP协议栈、并发模型、HTTP协议等**方式
【10月更文挑战第28天】Go语言进行网络编程可以通过**使用TCP/IP协议栈、并发模型、HTTP协议等**方式
28 13
|
2天前
|
测试技术 Go
go语言中测试工具
【10月更文挑战第22天】
10 4
|
2天前
|
SQL 关系型数据库 MySQL
go语言中数据库操作
【10月更文挑战第22天】
12 4
|
2天前
|
缓存 前端开发 中间件
go语言中Web框架
【10月更文挑战第22天】
13 4
|
5天前
|
Go
go语言的复数常量
【10月更文挑战第21天】
18 6
|
5天前
|
Go
go语言的浮点型常量
【10月更文挑战第21天】
13 4
|
5天前
|
编译器 Go
go语言的整型常量
【10月更文挑战第21天】
16 3
|
5天前
|
Serverless Go
Go语言中的并发编程:从入门到精通
本文将深入探讨Go语言中并发编程的核心概念和实践,包括goroutine、channel以及sync包等。通过实例演示如何利用这些工具实现高效的并发处理,同时避免常见的陷阱和错误。
|
6天前
|
安全 Go 开发者
代码之美:Go语言并发编程的优雅实现与案例分析
【10月更文挑战第28天】Go语言自2009年发布以来,凭借简洁的语法、高效的性能和原生的并发支持,赢得了众多开发者的青睐。本文通过两个案例,分别展示了如何使用goroutine和channel实现并发下载网页和构建并发Web服务器,深入探讨了Go语言并发编程的优雅实现。
18 2
|
2天前
|
安全 测试技术 Go
Go语言中的并发编程模型解析####
在当今的软件开发领域,高效的并发处理能力是提升系统性能的关键。本文深入探讨了Go语言独特的并发编程模型——goroutines和channels,通过实例解析其工作原理、优势及最佳实践,旨在为开发者提供实用的Go语言并发编程指南。 ####