golang
已收录文章:1322篇
-
在Go中使用指针切片可节省内存、共享数据和表达nil语义,适用于大对象或需修改原始值场景;声明如[]*int,初始化时注意避免循环变量地址陷阱,遍历时需判空防panic,正确管理指针生命周期以确保安全与性能。209 收藏
-
使用真实数据库或Mock进行Go语言数据库测试,关键在于连接管理、事务隔离与数据清理。建议用Docker启动PostgreSQL或SQLite做集成测试,通过TestMain初始化db,在事务中运行每个测试并回滚,避免数据污染;结合seed函数准备测试数据,使用testify/assert断言结果。对于单元测试,可借助go-sqlmock库模拟SQL执行过程,验证语句与参数。接口抽象有助于解耦逻辑与数据层,提升可测性。最终根据场景选择集成测试保真或mock测试提效,确保稳定性和速度兼顾。496 收藏
-
通过接口抽象和模拟实现,可高效测试Go中WebSocket依赖的业务逻辑。首先定义WebSocketConn接口替代直接使用*websocket.Conn,便于依赖注入;接着创建MockWebSocket结构体实现该接口,通过readData通道注入输入、writeData记录输出;在测试中预设消息并验证处理结果,实现无网络依赖的快速验证;还可通过设置ReadError等字段模拟连接中断或读写错误,确保程序能正确处理异常情况。这种方式提升了测试的稳定性和可维护性,避免外部环境干扰。359 收藏
-
答案:在Golang中,将指针与切片结合使用主要通过创建指针切片([]*T)来实现,用于修改原始数据、避免大结构体复制开销及支持多态性;相比值切片([]T)存储副本,指针切片存储指向原始对象的地址,可实现跨切片的数据共享与状态同步,适用于需修改外部数据、处理大型结构体或构建复杂数据结构的场景,但需注意循环变量地址陷阱和nil指针检查。418 收藏
-
答案:基于Golang的微服务权限控制方案包括JWT身份认证、RBAC访问控制、mTLS通信加密及注册中心元数据策略。1.使用JWT携带服务身份信息并验证签名;2.在中间件中解析JWT并检查service_id是否在允许列表内;3.启用mTLS确保双向证书认证与数据加密传输;4.在Consul或Etcd注册时附加权限元数据,结合配置中心动态更新策略。统一中间件与证书管理,提升安全性和可维护性。114 收藏
-
答案:使用Go的goroutine和channel实现TCP广播系统,通过net.Listen监听端口,Accept接收连接并启goroutine处理;用带锁的map维护客户端列表,新连接加入时广播上线,断开时删除并通知;遍历clients调用conn.Write实现消息群发,跳过发送者并处理写错。330 收藏