golang
已收录文章:320篇
-
中介者模式通过引入协调者集中管理对象交互,降低耦合度。在Go中,定义Mediator接口和参与者User,由ChatRoom实现消息转发,使用户间通信解耦,新增用户无需修改现有逻辑,符合开闭原则,适用于复杂交互场景。367 收藏
-
使用bufio.Scanner和bufio.Reader可高效读取大文件。推荐通过bufio.NewScanner配合os.File逐行读取,自动处理换行符;对超大文件,应设置合理缓冲区大小(如64KB)以平衡内存与性能;可通过scanner.Split自定义分隔符,支持空字符或单词分割等场景;避免使用已弃用的ReadLine方法,优先用strings.Builder减少拼接开销,并结合bufio.Writer提升写入效率。367 收藏
-
首先安装GoSDK并配置环境变量,再在GoLand中设置GOROOT和GOPATH,接着创建或导入使用GoModules的项目,然后配置运行调试选项,最后安装必要工具如dlv完成开发环境搭建。366 收藏
-
调用外部API时需处理网络错误、HTTP状态码异常和响应解析失败,使用http.Client注意检查StatusCode,封装自定义APIError类型便于错误分类,设置超时与重试机制避免阻塞,结合结构化日志与监控提升可观测性。366 收藏
-
Go语言通过流式处理实现大文件上传,避免内存溢出。首先前端设置enctype="multipart/form-data",后端调用r.ParseMultipartForm(maxMemory)解析请求,maxMemory仅控制表单字段内存使用,文件部分自动写入临时文件。获取文件句柄后,使用file.Open()得到multipart.File(实现io.Reader接口),再通过io.Copy或分块读取(如32KB缓冲区循环read/write)将数据写入目标文件。关键在于避免一次性加载整个文件,采用固定366 收藏
-
使用strings.Builder可高效拼接字符串,避免+操作符导致的频繁内存分配。它通过可变缓冲区累积内容,支持WriteString、WriteByte等方法,最后调用String()获取结果,性能优于O(n²)的+拼接,适用于日志、HTTP响应等场景。365 收藏