go语言并发编程:同时处理网络连接和终端输入
本文介绍如何构建一个Go语言服务器程序,实现同时监听新的网络连接和处理终端用户输入的功能。这对于开发交互式网络应用(例如终端聊天程序)至关重要。

许多初学者在编写此类程序时会遇到阻塞问题,导致终端输入无法响应。这是因为未能正确运用Go语言的并发机制和select语句。
问题通常源于以下两点:
立即学习“go语言免费学习笔记(深入)”;
- 未初始化channel: 用于接收终端输入和网络数据的channel未经初始化,导致程序无法正常运行。
-
单次
select执行:main函数中的select语句只执行一次,无法持续监听channel。
改进后的代码解决了这些问题。主要修改如下:
-
初始化channel: 使用
make函数初始化recvFromTerminalChan和recvFromNetChan。 -
循环监听: 将
select语句放入for循环中,持续监听来自终端和网络的输入。
改进后的代码框架如下(实际网络连接监听和处理需进一步完善,例如使用net.Listen和net.Conn):
package main
import (
"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的代码
}
这个改进版本利用goroutine和select语句实现了并发处理,有效避免了阻塞问题,从而能够同时响应网络连接和终端输入。 请注意,以上代码仅为基本框架,实际应用中需要补充完整的终端输入读取和网络连接处理逻辑。









