Unity网络开发记录(二):采用多线程处理服务端对客户端的连接和信息处理

在主线程处理对所有客户端的连接以及消息处理,是非常消耗时间的,所以对于监听客户端的连接,以及信息的接收,都额外开线程去处理,减轻主线程的压力

cs 复制代码
using System.Globalization;
using System.Net;
using System.Net.Sockets;
using System.Text;

namespace TechTcpServerTest
{
    internal class Program
    {
        static Socket socket;
        static Socket socketClient;
        static List<Socket> socketClients = new List<Socket>();
        static void Main(string[] args)
        {
            socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
            try
            {
                IPEndPoint ipPoint = new IPEndPoint(IPAddress.Parse("127.0.0.1"), 8080);
                socket.Bind(ipPoint);
            }
            catch (Exception)
            {
                return;                
            }
            socket.Listen(1024);

            Thread threadAccept = new Thread(AcceptClientConnect);
            threadAccept.Start();

            Thread threadResive = new Thread(ReceiveMsg);
            threadAccept.Start();

            while(true)
            {
                if (Console.ReadLine() != "Quit")
                {
                    return;
                }

                for(int i = 0; i < socketClients.Count; ++i)
                {
                    socketClients[i].Shutdown(SocketShutdown.Both);
                    socketClients[i].Close();
                }
                socketClients.Clear();
                Console.WriteLine("所有连接已断开,socket套接字关闭");
                break;
            }
            Console.ReadLine();
        }
        
        static void AcceptClientConnect()
        {
            while (true)
            {
                socketClient = socket.Accept();
                socketClients.Add(socketClient);
                if (socketClient.RemoteEndPoint != null)
                {
                    socketClient.Send(Encoding.UTF8.GetBytes($"{socketClient.RemoteEndPoint.ToString()}客户端已成功连接服务器"));
                }
            }
        }

        static void ReceiveMsg()
        {
            int i;
            int num;
            byte[] receiveBuffer = new byte[1024];
            while(true)
            {
                for(i = 0; i < socketClients.Count; ++i)
                {
                    if (socketClients[i].Available > 0)
                    {
                        num = socketClients[i].Receive(receiveBuffer);
                        ThreadPool.QueueUserWorkItem(HandleMsg, (socketClients[i], Encoding.UTF8.GetString(receiveBuffer, 0, num)));
                    }
                }
            }
        }

        static void HandleMsg(object obj)
        {
            (Socket s, string str)info = ((Socket s, string str))obj;
            if (info.s.RemoteEndPoint != null)
            {
                Console.WriteLine($"收到来次{info.s.RemoteEndPoint.ToString()}的消息:{info.str}");
            }
        }

    }
}

启动服务端,在unity中启动客户端,客户端最基本的代码在上一节,发现依旧可以正常连接,本节处理完毕

相关推荐
科技块儿1 小时前
如何使用IP数据云提升网络风控、减少业务欺诈
网络·网络协议·tcp/ip
fei_sun2 小时前
【计网】2025年真题
网络
Fnetlink12 小时前
中小企业网络环境优化与安全建设
网络·安全·web安全
爬山算法2 小时前
Netty(10)Netty的粘包和拆包问题是什么?如何解决它们?
服务器·网络·tcp/ip
Sleepy MargulisItG2 小时前
【Linux网络编程】应用层协议:HTTP协议
linux·服务器·网络·http
bruce_哈哈哈2 小时前
车载网络--soa总结--some/ip等认识
网络
logic_52 小时前
静态路由配置
运维·服务器·网络
门思科技3 小时前
企业级 LoRaWAN 网关远程运维方案对比:VPN 与 NPS FRP 的技术与安全差异分析
运维·网络·安全
kkk_皮蛋3 小时前
RTCP: 统计、同步与网络自适应
网络
suzhou_speeder3 小时前
企业数字化网络稳定运行与智能化管理解决方案
运维·服务器·网络·交换机·poe·poe交换机