golang
已收录文章:290篇
-
指针保存变量地址,通过T声明、&取地址、解引用,可修改原值并用于函数传参;切片是数组封装,含指针、长度、容量,共享底层数组易致副作用,需copy或append创建副本;指针与切片结合可用于修改切片本身,但推荐返回新切片;nil切片无底层数组,空切片有底层数组但无元素,判断为空应使用len(s)==0。393 收藏
-
Go语言的switch语句支持表达式匹配、类型判断和fallthrough控制。score:=85时,switch无表达式默认匹配true,执行casescore>=80输出“B”。类型switch通过v:=value.(type)判断interface{}底层类型,如string或int。fallthrough强制执行下一case,i:=2时输出“2”和“3”,但需谨慎使用。建议避免滥用fallthrough,多值匹配可用逗号分隔,空switch替代复杂if-else,类型switch适用于JSO393 收藏
-
推荐使用路径版本控制,如/v1/users和/v2/users,结构清晰易维护;Gin等框架支持分组路由实现版本隔离,便于调试与文档生成。392 收藏
-
gotest支持多种参数以提升测试效率。使用-v可查看详细输出;-run配合正则表达式运行指定测试函数,如gotest-runLogin;-timeout设置超时时间,默认10分钟,例如gotest-timeout30s;-parallel控制并行测试的最大数量,需在代码中调用t.Parallel();-bench运行基准测试,如gotest-bench=.,可结合-cpu指定核心数;通过-coverprofile生成覆盖率报告,并用gotoolcover-html查看HTML报告。参数可组合使用,如同时390 收藏
-
合理利用并发、控制资源消耗可提升Gopipeline性能。通过goroutine与channel实现并行处理,CPU密集型任务以GOMAXPROCS为基准控制并发数,IO密集型可增加并发度;使用带缓冲channel减少阻塞,避免无限制创建goroutine;确保关闭channel防止泄漏,结合context与select实现取消和超时;用sync.Pool复用对象减少GC压力,传递指针降低拷贝开销;通过semaphore限流、context控制超时,并采集指标监控系统负载,保持稳定性。389 收藏
-
选用Kafka或NSQ作为消息中间件,通过定义统一消息格式与主题规则,封装生产者发送和消费者监听逻辑,利用发布/订阅模式实现微服务间可靠广播,解耦服务依赖。389 收藏