golang
已收录文章:13890篇
-
io.Copy默认使用中间缓冲区导致多次内存拷贝,而sendfile可实现零拷贝。io.Copy默认使用32KB缓冲区在用户空间中转数据,造成文件内容从磁盘到用户空间再到socket的多次复制;sendfile系统调用则直接在内核态完成文件传输,跳过用户空间,降低CPU和内存开销;Go标准库如net/http在静态文件服务等条件下会自动使用sendfile;手动触发可通过syscall.Sendfile实现,但需满足源为普通文件、目标支持sendfile等条件;适用场景包括大文件传输、静态资源服务和高并发157 收藏
-
Golang的encoding/json库可用于解析和生成JSON数据。1.使用json.Unmarshal可将JSON字符串解析为结构体,结构体字段需可导出并可通过标签匹配字段名。2.使用json.Marshal或json.MarshalIndent可将结构体序列化为JSON字符串,通过omitempty标签可忽略空值字段。3.对于不确定结构的JSON数据,可用map[string]interface{}接收,访问时需进行类型断言。4.通过实现json.Marshaler和json.Unmarshale157 收藏
-
减少Golang锁竞争的核心是避免不必要的锁操作。1.使用atomic包进行原子操作,如atomic.AddInt64,适用于计数器等简单场景,避免Mutex的系统调用开销;2.利用sync.Pool复用对象,减少内存分配与GC压力,间接降低锁竞争;3.缩小锁粒度,仅保护必要临界区;4.读多写少场景使用sync.RWMutex,允许多个读并发执行;5.通过channel替代共享内存通信,避免锁的使用。不同场景应选择合适机制:atomic适合简单操作,RWMutex适合读多写少,channel适合gorou157 收藏
-
defer在Golang中用于延迟执行函数,常用于资源清理和错误处理。1.使用defer可确保函数返回前执行如关闭文件等操作,避免资源泄露;2.结合命名返回值,可在defer中捕获panic并设置错误信息;3.多个defer需按顺序处理错误,防止覆盖;4.defer性能影响较小,现代编译器已优化;5.最佳实践包括避免修改返回值、注意执行顺序、不过度使用。157 收藏
-
NATSStreaming通过消息持久化和可靠传递保障Golang应用消息不丢失,核心步骤包括:1.用Docker部署NATSStreaming服务器;2.安装stan.go客户端库;3.使用stan.Connect()建立连接并指定唯一客户端ID;4.通过Publish()发布消息,支持同步与异步模式;5.使用Subscribe()实现广播、QueueSubscribe()实现负载均衡消费;6.通过持久化ID实现断线重连后消息续传。尽管NATSStreaming仍用于部分存量系统,新项目建议优先评估Je157 收藏
-
Go语言通过defer、panic和recover实现错误恢复机制:panic触发运行时恐慌,中断当前流程;defer延迟执行函数,确保recover有机会捕获panic;recover仅在defer中有效,用于捕获panic值并恢复执行,防止程序崩溃。该机制常用于Web服务或goroutine中保护关键逻辑,避免单个错误导致整个服务失效。注意recover无法跨goroutine捕获,且应避免滥用panic,常规错误应通过error返回。157 收藏