Go 源码之 gorm 框架
看源码先看底层核心数据结构
在 Go 语言的数据库开发领域,GORM(Go Object Relational Mapping)框架绝对是绕不开的核心工具。
它以“简洁的 API、完整的 ORM 能力、多数据库适配”三大优势,成为开发者连接 MySQL、PostgreSQL 等数据库的首选。
看源码先看底层核心数据结构
在 Go 语言的数据库开发领域,GORM(Go Object Relational Mapping)框架绝对是绕不开的核心工具。
它以“简洁的 API、完整的 ORM 能力、多数据库适配”三大优势,成为开发者连接 MySQL、PostgreSQL 等数据库的首选。
在 Go 并发编程中,协程(goroutine)的管理一直是核心难点——如何优雅地传递全局信息(如用户 ID、日志 ID)、控制协程退出、处理超时或取消信号?context 包正是为解决这些问题而生的。它作为协程间的“上下文载体”,贯穿多个协程的生命周期,实现信息传递和状态管控。
写在前面:先写个结论,让大家对该结构的源码有个大概了解,之后再一步一步解析源码:
gin.New()初始化一个实例:gin.engine,该实例实现了http.Handler接口。实现了ServeHTTP方法
写在前面:先写个结论,让大家对该结构的源码有个大概了解,之后再一步一步解析源码。
chan 提供了一种在 goroutine 之间进行数据交换和同步的方式。通道可以用于控制并发访问和共享数据,从而减少竞态条件和死锁问题,并且可以自然地处理异步事件和信号。如果你的应用程序需要在 goroutine 之间传递数据或消息,那么通道是一个不错的选择
写在前面:先写个结论,让大家对该结构的源码有个大概了解,之后再一步一步解析源码:
type RWMutex struct {
w Mutex // 写锁
writerSem uint32 // 缓冲信号量,获取写锁的阻塞等待信号队列
readerSem uint32 // 缓冲信号量,获取读锁的阻塞等待信号队列
readerCount int32 // 当前持有读锁的 goroutine 数量,负数表示有个写锁在执行
readerWait int32 // 获取写锁时,如果之前还有 readerWait 数量的读锁在执行,则需要等待执行完才能获取写锁
}w
写在前面:先写个结论,让大家对该结构的源码有个大概了解,之后再一步一步解析源码:
锁不可复制:拷贝互斥锁同时会拷贝锁的状态,容易造成死锁
不是可重入锁,并且一个协程上锁,可以由另外一个协程解锁