golang
已收录文章:14153篇
-
Go语言文件I/O性能优化需合理使用缓冲、减少系统调用并选择合适读写模式。1.使用bufio.Reader/Writer可减少系统调用,建议小数据写入用bufio.Writer并及时Flush,逐行读取用bufio.Scanner;2.根据场景调整缓冲区大小(如32KB~64KB),避免默认4KB瓶颈;3.大文件避免ioutil.ReadFile,应采用流式处理或mmap随机访问;4.并发读写同一文件需谨慎,磁盘I/O为顺序操作,过多goroutine反降性能,多文件处理可并行利用多核;5.系统级优化包括183 收藏
-
指针在Go的JSON序列化中会自动解引用,非nil输出值,nil输出null;反序列化时根据JSON值自动分配或设为nil,需注意判空、区分缺失与null及手动设置默认值。183 收藏
-
合理控制Goroutine并发数并配置HTTP连接池可提升系统稳定性。通过带缓冲Channel限制并发、使用自定义Transport优化连接复用、结合ants等协程池降低调度开销,并启用pprof监控Goroutine数量与连接状态,有效避免资源耗尽,提升吞吐量。183 收藏
-
使用自定义bridge网络提升Go微服务通信效率,仅对外暴露必要端口,高并发场景可选host网络模式,并结合HTTPKeep-Alive与超时控制优化性能。183 收藏
-
结构图: 为什么? var data [][]int for _, rangeSlice := range [][]int{{1}, {2}, {3}} { data = append(data, rangeSlice[:]) } fmt.Printf("%v", data) // 输出 [[1] [2] [3]] var data [][]int for _, rangeArray := range [][1]int{{1}, {2}, {3}} {182 收藏
-
sync.Mutex Go中使用sync.Mutex类型实现mutex(排他锁、互斥锁)。在源代码的sync/mutex.go文件中,有如下定义: // A Mutex is a mutual exclusion lock. // The zero value for a Mutex is an unlocked mutex. // // A Mutex must not be copi182 收藏