golang
已收录文章:13842篇
-
select语句是Go语言处理多路通道通信的核心机制,它通过类似switch的结构监听多个通道操作,任一就绪即执行对应case,支持超时、非阻塞和动态禁用等模式,解决并发中多路复用、超时控制、优雅退出等问题,提升程序响应性与灵活性。196 收藏
-
自定义错误类型通过结构体实现error接口,可携带错误码、时间戳等额外信息,提升错误处理灵活性。270 收藏
-
答案:在Golang中实现订单状态跟踪需定义状态常量、构建带历史记录的结构体、通过方法控制合法状态迁移,并记录变更时间。使用iota定义StatusPending、StatusPaid等状态,结合Order结构体存储状态和History切片,TransitionTo方法调用isValidTransition验证流转合法性,避免如“待支付”直跳“已送达”的错误;每次变更记录From、To及ChangedAt,支持追溯;辅以StatusName方法返回状态名,便于展示;在HTTP服务中结合数据库事务持久化订单259 收藏
-
答案:一个用Golang编写的命令行工具,支持递归搜索指定目录下的文件,可按文件名模糊匹配(支持通配符),通过-path和-name参数指定搜索路径和模式,使用filepath.WalkDir遍历目录,filepath.Match进行模式匹配,输出符合条件的文件路径,具备错误处理机制,可扩展忽略大小写、排除目录、正则匹配和输出格式控制等功能。433 收藏
-
答案:Go语言通过net包实现UDP多客户端通信,利用无连接特性使服务端用单一UDPConn处理多个客户端。服务端监听地址后通过ReadFromUDP接收数据并获取客户端地址,再用WriteToUDP回复;客户端使用DialUDP建立虚拟连接发送消息并接收响应。为管理多个客户端状态,可将UDPAddr作为key维护映射表,并结合心跳机制与sync.Map保证并发安全。需注意数据包大小限制、丢包处理、广播支持及错误捕获等细节,确保高效稳定通信。387 收藏
-
<p>使用net/rpc实现Go的RPC调用,通过HTTP传输。1.定义共享结构体和方法(如Multiply);2.服务端注册实例并暴露HTTP服务;3.客户端连接后调用远程方法;4.运行服务端和客户端,输出7*8=56。需注意方法导出、参数规范及gob编码限制。</p>234 收藏