golang 锁bug 记录

例如 会先获取了读锁,协程里面有个写锁,如果整体还嵌套了读锁,直接出现死锁了 ,卡在all_lock_test.RLock() ,读锁永远也不能释放了

go 复制代码
package routes

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

var all_lock_test sync.RWMutex

func TestSendGiftInfo_SendBlind(t *testing.T) {
	if !all_lock_test.TryRLock() {
		return
	}
	defer all_lock_test.RUnlock()

	go func() {
		all_lock_test.Lock()
		defer all_lock_test.Unlock()
		fmt.Println("配置更新")
	}()
	time.Sleep(time.Second)
	rDeal()

}

func rDeal() {
	all_lock_test.RLock()
	defer all_lock_test.RUnlock()
	fmt.Println("处理业务完毕")
}
相关推荐
顾林海11 分钟前
深度解析LinkedList工作原理
android·java·面试
茶本无香11 分钟前
CompletableFuture:整合、超时、完成事件与批量处理
java·超时·future·completable·completion·任务整合
雷渊16 分钟前
分析@Autowired和@Resource的使用场景
java·后端·面试
whisperrr.16 分钟前
【spring02】Spring 管理 Bean-IOC,基于 XML 配置 bean
xml·java·spring
Cloud_.22 分钟前
Spring Boot整合Elasticsearch
java·spring boot·后端·elasticsearch·es
储悠然25 分钟前
Lisp语言的物联网数据分析
开发语言·后端·golang
ghostmen33 分钟前
基于Spring Boot的HTTP请求签名验证实现解析
java·spring·http
雷渊38 分钟前
深入分析spring中Bean的初始化过程
java·后端·面试
Plus-ultra39 分钟前
Java面试34-Kafka的零拷贝原理
java·分布式·面试·kafka
flzjkl43 分钟前
【Java并发】【ThreadLocal】适合初学体质的ThreadLocal
java·后端