C# TCP/IP Socket编程核心是使用System.Net.Sockets命名空间下的Socket类及封装类TcpClient/TcpListener;服务器用TcpListener监听并处理连接,客户端用TcpClient连接收发数据,需注意异步通信、资源释放与异常处理。
C# 中 TCP/IP Socket 编程的核心是使用 System.Net.Sockets 命名空间下的 Socket 类,配合 TcpClient 和 TcpListener(更高级、更简洁的封装)来实现客户端与服务器通信。关键在于理解连接建立、数据收发和资源释放的流程,避免阻塞主线程或内存泄漏。
推荐初学者优先使用 TcpListener,它封装了底层 Socket 的复杂性,代码更清晰、不易出错。
IPAddress.Any)和端口(如 8080)Start() 开始监听;用 AcceptTcpClient() 阻塞等待连接(或用 BeginAcceptTcpClient 异步)TcpClient 实例,通过其 GetStream() 获取 NetworkStream 进行读写TcpClient 和 NetworkStream,防止句柄泄漏示例片段(控制台服务器):
TcpListener listener = new TcpListener(IPAddress.Any, 8080);
客户端逻辑更简单:创建 TcpClient → 调用 Connect() 连接服务器 → 用 GetStream() 发送/接收数据。
BeginConnect + AsyncWaitHandle,或新建线程+取消令牌)Encoding.UTF8);接收时注意流可能未一次性返回全部数据,需循环读取或按协议解析长度头Read() 就能读完所有内容——TCP 是字节流,无消息边界示例片段(简单客户端):
TcpClient client = new TcpClient();实际应用中,服务器不能只处理一个客户端,也不能让 Accept 或 Read 阻塞整个程序。
TcpListener.BeginAcceptTcpClient + 回调,或 C# 5.0+ 推荐的 await listener.AcceptTcpClientAsync()
TcpClient 启动独立任务(Task.Run)或使用 NetworkStream.ReadAsync/WriteAsync 实现非阻塞 I/OIOException、ObjectDisposedException 都要捕获并安全清理资源当需要精细控制(如设置 SocketOptionName、使用 UDP、重用地址、绑定特定网卡等),才直接操作 Socket 类。
Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp) → Bind → Listen → Accept
Connect → Send/Receive
socket.Blocking = false 或改用 BeginXXX/EndXXX 方法做异步TcpClient 更灵活,但也更容易写出 bug,不推荐新手从这里起步基本上就这些。用好 TcpClient 和 TcpListener 足以覆盖大多数 C# 网络通信场景。重点不在“怎么写”,而在于“怎么安全、稳定、可扩展地写”——关注连接生命周期、异常恢复、线程安全和协议设计。