在处理客户端网络消息的代码中,作者遇到了一个问题:switch case 无法匹配从网络接收到的字符串。
代码如下:
func dealwithclientmsg(conn net.conn) { read := make([]byte, 2048) readtmp := make([]byte, 1024) num, err := conn.read(readtmp) if err != nil { log.println("接受客户端消息失败:", err.error()) } read = append(read, readtmp[:num]...) log.println("接收到客户端消息:", string(read)) contentlist := strings.split(string(read), ":") action := strings.trim(contentlist[0], " ") switch action { case "tunnelok": fmt.println("隧道打成功了") ...... } }
从代码中可以看出,action 变量的值是字符串,而 switch case 的 case 子句也是字符串。但是,即使 action 的值明明就是 "tunnelok",却无法匹配到 switch case。
经过分析,推测造成这个问题的原因可能是:
根据推测,可以采取以下解决方案:
代码修改如下:
action := strings.trimspace(contentlist[0])
read := []byte{} // 或 var read []byte
只要 action 变量的值确实是 "tunnelok",那么 switch case 就能够正常匹配。
Golang 函数如何进行并发处理
Go 框架生态系统概述和推荐
Debian日志级别设置对系统性能的影响
如何将数据库查询结果存储到变量中?
在Go语言中使用Redis Stream实现消息队列时,解决`user_id`类型转换问题可以按照以下步骤进行: 1. **数据类型定义**: 在Go语言中,通常会将`user_id`定义为`int64`类型,因为Redis Stream中的字段值是字符串格式,需要在写入和读取时进行类型转换。 ```go type UserMessage struct { UserID int64 `json:"user_id"` // 其他字段 } ```
Go语言如何与Kubernetes API交互以添加节点?