golang
已收录文章:460篇
-
Go语言支持跨平台交叉编译,通过设置GOOS和GOARCH环境变量可生成目标平台可执行文件。例如在macOS上编译LinuxARM64程序:GOOS=linuxGOARCH=arm64gobuild-omyappmain.go。常见组合包括Windows64位(GOOS=windowsGOARCH=amd64)、macOSIntel(GOOS=darwinGOARCH=amd64)和LinuxARMv7(GOOS=linuxGOARCH=armGOARM=7),其中ARM架构需额外设置GOARM版本,M1113 收藏
-
使用context.Context可安全传递请求ID和元数据,通过WithValue存值、goroutine间传递Context、Value取值,并结合自定义键类型避免冲突,适用于中间件、超时取消等场景。112 收藏
-
协程优化需控制数量、减少阻塞、合理调度与资源复用。1.用workerpool和缓冲channel限制并发,避免无限创建;2.防止channel无配对读写、网络无超时等阻塞问题;3.利用sync.Pool缓存对象,减少GC压力;4.结合pprof、trace等工具监控协程行为,定位瓶颈。111 收藏
-
Go语言中类型转换需显式进行,不可隐式转换。1.数值类型通过T(v)语法转换,小范围转大范围安全,大范围转小范围可能溢出;整型与浮点互转时截断小数部分。2.字符串与数值转换依赖strconv包,Atoi、ParseInt等用于字符串转数字并处理错误,Itoa、FormatFloat等用于数字转字符串,也可用fmt.Sprintf实现通用转换但性能较低。3.接口类型转换使用类型断言,推荐安全形式value,ok:=i.(Type)以避免panic,是实现多态的关键。掌握这三类转换可覆盖多数开发场景。110 收藏
-
使用bufio.Scanner可高效按行读取文件,适合文本处理;Scanner默认按行分割,Text()获取字符串,适用于日志等场景。108 收藏
-
提升Golang网络请求处理速度需优化HTTP客户端配置、控制并发、复用连接并减少资源开销。通过自定义Transport启用长连接、限制空闲连接数、设置超时;使用带缓冲channel控制goroutine数量,避免过度并发;结合sync.Pool缓存对象、分批处理大批量请求;采用流式解析降低内存占用,并用pprof分析性能瓶颈,平衡并发与系统稳定性。108 收藏