golang
已收录文章:14258篇
-
在Go语言中传递大对象时应使用指针传递以避免内存拷贝,具体做法包括:对大结构体使用指针传参、返回大对象时返回指针或通过参数修改原对象、为大结构体定义指针接收者方法、注意指针可能导致的逃逸和GC压力,并合理使用sync.Pool缓存对象,同时需知slice、map、string等引用类型本身轻量无需额外指针包装,综合这些技巧可显著提升性能且保持代码清晰。187 收藏
-
命令模式通过封装请求为对象实现调用者与接收者解耦,支持撤销、队列和扩展,适用于Go语言中的遥控操作、任务队列等场景。154 收藏
-
JWT认证是一种无状态的Token验证机制,核心在于安全生成和验证Token。使用Go语言可通过github.com/golang-jwt/jwt/v5库实现,定义包含用户信息的Claims结构体,如UserID、Username及过期时间等,并用HS256算法和密钥签名生成Token;验证时解析Token并校验签名和声明有效性。其优势在于无状态、易扩展、适合分布式系统,但缺点是Token一旦签发难以主动失效,需借助黑名单等机制弥补。敏感信息不应放入Claims,密钥必须通过环境变量或配置中心管理,避免硬122 收藏
-
Golang中处理HTTP表单数据需根据请求类型和Content-Type选择方法:GET请求通过r.URL.Query()获取url.Values类型的参数;POST请求则根据内容类型选择r.ParseForm()解析application/x-www-form-urlencoded数据,或r.ParseMultipartForm()处理multipart/form-data(含文件上传),前者将数据存入r.Form和r.PostForm,后者支持内存与磁盘结合的大文件处理;对于JSON或XML等非表单401 收藏
-
使用RunParallel可真实模拟多goroutine并发场景,暴露锁竞争与伸缩性问题。它通过pb.Next()协调所有goroutine共同完成b.N次操作,避免单goroutine串行测试的局限性。默认并行度为GOMAXPROCS,可结合不同CPU核心数测试性能变化,揭示高并发下真实瓶颈。249 收藏
-
使用Golang的net/rpc构建RPC服务的关键步骤是:1.定义符合func(tT)MethodName(argsArgs,reply*Reply)error签名的服务方法;2.服务端通过rpc.Register注册服务实例并监听TCP连接,使用rpc.ServeConn处理每个连接;3.客户端通过rpc.Dial连接服务端,并使用client.Call同步调用或client.Go异步调用远程方法;4.注意数据结构和字段需导出、方法名和服务名需匹配;5.在分布式应用中需自行实现超时控制、服务发现、负载408 收藏