go语言并发编程:同时处理网络连接和终端输入
本文介绍如何构建一个Go语言服务器程序,实现同时监听新的网络连接和处理终端用户输入的功能。这对于开发交互式网络应用(例如终端聊天程序)至关重要。
许多初学者在编写此类程序时会遇到阻塞问题,导致终端输入无法响应。这是因为未能正确运用Go语言的并发机制和select语句。
问题通常源于以下两点:
立即学习“go语言免费学习笔记(深入)”;
未初始化channel: 用于接收终端输入和网络数据的channel未经初始化,导致程序无法正常运行。单次select执行: main函数中的select语句只执行一次,无法持续监听channel。
改进后的代码解决了这些问题。主要修改如下:
初始化channel: 使用make函数初始化recvFromTerminalChan和recvFromNetChan。循环监听: 将select语句放入for循环中,持续监听来自终端和网络的输入。
改进后的代码框架如下(实际网络连接监听和处理需进一步完善,例如使用net.Listen和net.Conn):
package mainimport ( "fmt" "os")var recvFromTerminalChan = make(chan string)var recvFromNetChan = make(chan string)func main() { go readFromTerminal() // 读取终端输入的goroutine for { select { case str := <-recvFromTerminalChan: fmt.Println("Terminal Input:", str) // 处理终端输入 case str := <-recvFromNetChan: fmt.Println("Network Input:", str) // 处理网络输入 } }}func readFromTerminal() { // 此处需添加读取终端输入并发送到recvFromTerminalChan的代码}
登录后复制
本文来自互联网或AI生成,不代表软件指南立场。本站不负任何法律责任。