基于Udp(收发信息使用同一个socket)网络通信编程

想要实现网络通信那么就要有一个客户端一个服务器

客户端发送数据,服务器接收数据并返回数据

网络通信就是进程通信

所以我们用两个程序来分别编写客户端和服务器

服务器

1,设置端口号,

2、ip可以固定位127.0.0.1来用于本地测试,但一般不固定,而是让他自己获取本机的ip

3、创建套接字socket

这里的创建只相当于打开网卡文件,设置进去了网络通信的方式(个人理解),就相当于创建了一个文件,返回了他的文件描述符。

4、

服务器的话要手动把socket文件和网络套接字绑定:

首相要把网络套接字结构填充好(还没有绑定):

绑定:bind网络系统库调用:

现在这个服务器程序就有了自己网络通信的套接字(ip port)

5、接收数据:

6,发送消息,他在接收消息的时候也接收了发消息的那个客户端的套接字,就相当于知道了客户端的ip 和port,那么他就可以把消息发送回客户端

到这服务器程序就写好了:直接运行服务器:

客户端

1.客户端想要实现网络通信也要创还能socket文件:

2、不同的是客户端并不用手动代码把socket文件和字节套网络通信结构体关联,

因为在客户端发送消息的时候,系统会自动分配端口号和ip给他

3、但是他要发送消息就要知道要发送给的那个服务器的套接字(ip port),所以还是需要填写一个套接字结构体来把服务器的 ip port填写进去

以供发送

4、他也可以接收服务器发来的消息

到这就基本实现了服务器和客户端网络通信的测试了

详细代码:

Udp_socket

升级版本:多人聊天界面的实现

服务器收到消息后支持多线程发送给多个客户端(线程池),客户端收发信息才用多线程实现(互不干扰),收的时候可以发,发的时候也可以在收。

1、服务器:

创建一个用户列表里面保存着给这个服务器发过消息的客户端信息:方便之后给多个客户端都发消息。只要服务器收到消息就去判断是否要把这个用户插入到列表(用户是否登录过服务器)

然后把收到的消息,客户端的addr,和服务器自身的socket都打包作为参数,传给我们的进程池,进程池中的线程去竞争锁,然后执行发送任务
需要注意的是收消息的主线程和发消息的线程,他们后悔访问用户列表,所以要把用户列表用锁保护起来

客户端:客户端如果只是单线程的话,在发消息时就不能收信息,所以把客户端改为多线程,主线程负责创建socket,和构建服务器套接字结构,和最后的等待子线程。

然后构建两个子线程,一个负责发,一个负责收,且互不干扰:

最终就可以实现,多客户端去访问服务器,然后给服务器发消息,其他发过消息的客户端也能收到。

这样就实现了多个客户端之间的通信

相关推荐
IpdataCloud2 小时前
金融风控管理如何借助IP离线库提升效率?多语言工程实践
网络·网络协议·tcp/ip
聚铭网络8 小时前
聚铭网络成功入围徐州市大数据集团2026年业务类合作供应商名录(第一批次)
大数据·网络
hy____12310 小时前
Linux_网络基础3
linux·服务器·网络
Striver-Diligent10 小时前
GenNP: 一种低门槛且功能强大的网络性能数据生成器
网络·计算机网络·并行·网络仿真·网络性能估计·离散事件仿真
我是唐青枫13 小时前
C#.NET ReadOnlySequence 深入解析:多段内存遍历与零拷贝协议解析
网络·c#·.net
带娃的IT创业者15 小时前
WeClaw 心跳与重连实战:指数退避算法如何让 WebSocket 在弱网环境下的连接成功率提升 67%?
python·websocket·网络协议·算法·fastapi·实时通信
Insist75315 小时前
案例二---集群修改物理IP和VIP
运维·网络·数据库
qq_4112624216 小时前
在建立udp连接的时候,有时候能成功,有时候AT 指令返回+ERRNO:0x70
网络·网络协议·udp
专家大圣16 小时前
告别智能家居品牌壁垒✨ Home Assistant+cpolar 让远程控家更省心
网络·docker·智能家居·内网穿透·cpolar
上海云盾-小余17 小时前
出海业务高可用方案:全球节点 + 智能清洗,让 DDoS 与网络故障不再影响业务
网络·安全·web安全·ddos