-
Go默认不压缩HTTP响应,需手动介入或用中间件;gorilla/handlers.CompressHandler一行启用,自动处理Accept-Encoding协商并跳过小响应。
-
Sonic并非简单替换import即可加速,其性能优势依赖正确配置:需限制递归深度、禁用冗余指令集、避免map[string]interface{}泛型路径,并注意Unmarshal时nil指针、time.Time格式及错误类型差异。
-
Go接口中通过隐式实现定义行为,只需类型提供接口要求的方法即可。使用typeinterface定义接口,如Animal包含Speak()和Move()方法。Cat和Dog结构体通过实现这两个方法自动满足Animal接口。接口变量可存储任何实现该接口的类型,支持多态调用,如Perform函数处理不同动物行为。空接口interface{}可接受任意类型,常配合类型断言提取具体值。注意:若方法使用指针接收者,则只有指针类型能实现接口,值类型无法自动满足。
-
典型表现为pprof中goroutine数持续上涨或程序退出卡住,根本原因是worker未在select中监听ctx.Done()或未处理已接收任务;正确模式是select同时等待任务通道和ctx.Done()。
-
必须先调用reflect.Value.Elem()解引用指针才能修改其指向的值,否则CanSet()为false;若字段为nil指针需先reflect.New分配内存;未导出字段无法通过反射读写。
-
GoSSH远程连接核心三点:HostKeyCallback必须显式设置(生产用ssh.KnownHosts)、Session每次新建、传文件必须用SFTP;私钥格式和known_hosts路径拼接易出错。
-
用反射判断[]int是nil还是空切片,需先检查Kind()为reflect.Slice,再调用IsNil():true为nil切片,false时结合Len()==0判断是否为空切片。
-
net.LookupHost默认只返回IPv4地址(A记录),不返回IPv6(AAAA记录),因其设计为粗粒度主机名到IP字符串映射,且内部依赖系统解析器;需IPv6应改用net.LookupIP。
-
Go不支持const定义切片或map,因其为引用类型、编译期无法确定内存布局;推荐用unexported变量加封装函数模拟只读,或空struct封装提供不可变语义。
-
panic仅用于程序无法继续运行的致命错误,如初始化失败、逻辑错误或运行时越界;可预期的业务错误必须返回error,不可滥用panic或recover。
-
Go的goto只能跳转到同一函数内的标签,不能跨函数、进出闭包或跳过变量声明;标签须独占一行、区分大小写且不与变量同名;仅推荐用于错误清理,禁用作普通控制流。
-
Kafka、RabbitMQ、NSQ的选型取决于业务场景:高吞吐+日志留存优先Kafka,需注意sarama配置与消费者组参数;灵活路由/ACK选RabbitMQ,须规避连接非线程安全及ACK遗漏;轻量实时通知可选NSQ,但受限于消息大小、无原生消费者组及lookupd单点。
-
值类型在小数据结构时性能更优,指针类型在大数据或需修改原始数据时更具优势。1.值类型直接操作数据副本,避免指针解引用开销,适合小结构体,提升缓存命中率且不增加GC压力;2.指针类型减少大结构体复制成本,但引入缓存未命中风险并增加堆内存与GC负担;3.选择应基于数据大小、是否需修改原始数据、并发安全性及代码清晰度,并通过基准测试验证性能差异。
-
用text/template生成Ansiblehosts文件最稳妥,因其轻量可控、避免硬拼字符串错误;需用结构体匹配分组语义、安全输出变量、校验LF换行与0600权限,并通过ansible-inventory验证。
-
Golang凭借goroutines和net包实现高效TCP服务器,核心是监听端口、接受连接并为每个连接启动goroutine处理;通过defer关闭连接、设置读写超时、合理处理EOF和网络错误,可有效管理连接;结合日志、netstat、客户端模拟及pprof工具,能有效调试并发安全、阻塞操作和连接泄漏等问题。