golang
已收录文章:333篇
-
使用reflect.TypeOf()和.Kind()可判断变量类型。1.用reflect.TypeOf(x)获取类型并打印;2.通过类型比较判断是否为特定类型,如字符串;3.利用t.Kind()识别基础类型类别,如slice、struct;4.对结构体可遍历字段获取类型信息,适用于动态类型检查场景。455 收藏
-
二级指针用于在函数内修改传入的指针变量本身,使其指向新地址,解决Go值传递导致的外部指针无法更新问题,如链表头节点修改;其核心是通过**T传递指针的地址,实现对原始指针的“回写”,但需避免过度使用,优先考虑返回值或引用类型等更Go风格的方式。116 收藏
-
答案是使用Golang实现数据库迁移工具需通过版本控制与可重复执行机制。首先按时间戳命名迁移文件,如20240101120000_create_users_table.up.sql和.down.sql,存于migrations目录;创建schema_migrations表记录已执行版本。程序扫描目录解析版本号,读取数据库已应用版本,跳过旧迁移,对未执行的按升序运行.up.sql,并插入执行记录。核心逻辑包括:用database/sql连接数据库,读取文件、解析版本、排序并执行新增迁移,确保每步原子性与一致325 收藏
-
先通过reflect.TypeOf获取map类型对象,再调用Key()和Elem()方法分别获取键和值的类型信息,适用于处理interface{}类型的map并用于通用配置解析等场景。403 收藏
-
使用带缓冲通道控制并发数可有效优化高并发场景下的网络请求稳定性。通过定义最大并发量的信号量通道,每个请求前获取令牌,完成后释放,避免资源耗尽。185 收藏
-
微服务中事务管理需应对跨服务数据一致性难题,Golang通过Saga、TCC和消息队列方案实现分布式事务:1.Saga模式拆分事务为本地操作与补偿动作,适用于多步骤长流程;2.TCC通过Try-Confirm-Cancel三阶段协议保障强一致性;3.消息队列结合本地事务表确保最终一致性。工程实践中需结合context超时控制、幂等处理、链路追踪与日志记录,依据业务需求权衡一致性与复杂度,利用Golang并发优势构建可靠事务系统。441 收藏