当前位置: 首页 > news >正文

如何使用 Python 实现 UDP 通信?

1. UDP通信基础

UDP(用户数据报协议)是一种无连接的传输层协议,它提供了一种不可靠的数据传输服务,但具有较低的延迟和较小的开销。在Python中,可以使用socket模块来实现UDP通信。

2. 实现UDP服务端
import socketdef start_server(host='127.0.0.1', port=65432):"""启动一个UDP服务端:param host: 服务端监听的IP地址,默认为本地回环地址:param port: 服务端监听的端口"""with socket.socket(socket.AF_INET, socket.SOCK_DGRAM) as s:s.bind((host, port))print(f"Server listening on {host}:{port}")while True:data, addr = s.recvfrom(1024)  # 接收数据和客户端地址print(f"Received from {addr}: {data.decode()}")s.sendto(data, addr)  # 将接收到的数据发送回客户端if __name__ == "__main__":start_server()

代码解释

  • socket.socket(socket.AF_INET, socket.SOCK_DGRAM):创建一个UDP套接字。
  • s.bind((host, port)):绑定IP地址和端口。
  • s.recvfrom(1024):接收数据,最多1024字节,并返回数据和客户端地址。
  • s.sendto(data, addr):将数据发送到指定的客户端地址。
3. 实现UDP客户端
import socketdef start_client(host='127.0.0.1', port=65432):"""启动一个UDP客户端:param host: 服务端的IP地址:param port: 服务端的端口"""with socket.socket(socket.AF_INET, socket.SOCK_DGRAM) as s:while True:message = input("Enter a message to send: ")s.sendto(message.encode(), (host, port))data, _ = s.recvfrom(1024)  # 接收服务端发送的数据print(f"Received from server: {data.decode()}")if __name__ == "__main__":start_client()

代码解释

  • socket.socket(socket.AF_INET, socket.SOCK_DGRAM):创建一个UDP套接字。
  • s.sendto(message.encode(), (host, port)):发送数据到指定的服务端地址。
  • s.recvfrom(1024):接收服务端发送的数据,并返回数据和服务器地址。
4. 日常开发中的合理化使用建议
  1. 数据完整性:由于UDP是不可靠的,如果需要确保数据的完整性,应在应用层实现重传机制和校验和。
  2. 流量控制:UDP没有内置的流量控制机制,应根据网络状况和应用需求自行实现。
  3. 安全性:对于敏感数据的传输,应考虑使用DTLS(Datagram Transport Layer Security)进行加密。
  4. 广播和组播:UDP支持广播和组播,适用于需要向多个接收者发送数据的场景。
5. 实际开发过程中需要注意的点
  1. 资源管理:确保在通信结束后正确关闭套接字和其他资源,避免资源泄漏。
  2. 数据格式:在发送和接收数据时,应明确数据的格式(如JSON、XML等),并进行相应的序列化和反序列化操作。
  3. 错误处理:捕获和处理可能的异常,如网络错误、数据格式错误等。
  4. 性能优化:根据应用需求,优化数据包的大小和发送频率,以提高通信效率。
6. 错误处理示例
import socketdef start_server(host='127.0.0.1', port=65432):with socket.socket(socket.AF_INET, socket.SOCK_DGRAM) as s:s.bind((host, port))print(f"Server listening on {host}:{port}")while True:try:data, addr = s.recvfrom(1024)print(f"Received from {addr}: {data.decode()}")s.sendto(data, addr)except Exception as e:print(f"Error: {e}")if __name__ == "__main__":start_server()

代码解释

  • 使用try-except块捕获可能的异常,并打印错误信息。
7. 广播示例
import socketdef start_client(host='255.255.255.255', port=65432):with socket.socket(socket.AF_INET, socket.SOCK_DGRAM) as s:s.setsockopt(socket.SOL_SOCKET, socket.SO_BROADCAST, 1)  # 启用广播while True:message = input("Enter a message to send: ")s.sendto(message.encode(), (host, port))data, _ = s.recvfrom(1024)print(f"Received from server: {data.decode()}")if __name__ == "__main__":start_client()

代码解释

  • s.setsockopt(socket.SOL_SOCKET, socket.SO_BROADCAST, 1):启用广播功能。
8. 组播示例
import socketdef start_client(host='224.0.0.1', port=65432):with socket.socket(socket.AF_INET, socket.SOCK_DGRAM) as s:group = socket.inet_aton(host)mreq = group + socket.inet_aton('0.0.0.0')s.setsockopt(socket.IPPROTO_IP, socket.IP_ADD_MEMBERSHIP, mreq)  # 加入组播组while True:message = input("Enter a message to send: ")s.sendto(message.encode(), (host, port))data, _ = s.recvfrom(1024)print(f"Received from server: {data.decode()}")if __name__ == "__main__":start_client()

代码解释

  • s.setsockopt(socket.IPPROTO_IP, socket.IP_ADD_MEMBERSHIP, mreq):加入指定的组播组。

相关文章:

如何使用 Python 实现 UDP 通信?

1. UDP通信基础 UDP(用户数据报协议)是一种无连接的传输层协议,它提供了一种不可靠的数据传输服务,但具有较低的延迟和较小的开销。在Python中,可以使用socket模块来实现UDP通信。 2. 实现UDP服务端 import socketd…...

MTK 配置文件梳理

文章目录 MTK 日常配置总结屏幕默认横竖屏显示ro.build.characteristics 属性修改修改点一:build\core\product_config.mk修改点二:build\make\core\main.mk修改是否成功,adb 验证 配置部分系统app handheld_product.mk配置系统属性、第三方应…...

论文笔记:Treat Visual Tokens as Text? But Your MLLM Only Needs Fewer Efforts to See

2024 10月的arxiv 1 主要idea 针对多模态大模型(如LLaVA),提出了一系列高效的剪枝策略 在显著降低计算开销(多达 88%)的同时,保持了模型在多模态任务中的性能表现 2 目前的问题 与文本 token 相比&…...

软考高级架构 —— 10.6 大型网站系统架构演化实例 + 软件架构维护

10.6 大型网站系统架构演化实例 大型网站的技术挑战主要来自于庞大的用户,高并发的访问和海量的数据,主要解决这类问题。 1. 单体架构 特点: 所有资源(应用程序、数据库、文件)集中在一台服务器上。适用场景: 小型网站&am…...

2024美赛数学建模C题:网球比赛中的动量,用马尔可夫链求解!详细分析

文末获取历年美赛数学建模论文,交流思路模型 接下来讲解马尔可夫链在2024年C题中的运用 1. 马尔科夫链的基本原理 马尔科夫链是描述随机过程的一种数学模型,其核心特征是无记忆性。 简单来说,系统在某一时刻的状态只取决于当前状态&#x…...

23种设计模式之状态模式

目录 1. 简介2. 代码2.1 State (定义抽象状态接口)2.2 StartState (实现具体状态类)2.3 EndState (实现具体状态类)2.4 Context (定义上下文类)2.5 Test (测试类&#xf…...

Elasticsearch Serverless 中的数据流自动分片

作者:来自 Elastic Andrei Dan 在 Elastic Cloud Serverless 中,我们根据索引负载自动为数据流配置最佳分片数量,从而使用户无需摆弄分片。 传统上,用户会更改数据流的分片配置,以处理各种工作负载并充分利用可用资源。…...

YOLOv10改进,YOLOv10添加U-Netv2分割网络中SDI信息融合模块+GSConv卷积,助力小目标

理论介绍 完成本篇需要参考以下两篇文章,并已添加到YOLOv10代码中 YOLOv10改进,YOLOv10添加U-Netv2分割网络中SDI信息融合模块,助力小目标检测YOLOv10改进,YOLOv10添加GSConv卷积+Slim-neck,助力小目标检测,二次创新C2f结构下文都是手把手教程,跟着操作即可添加成功 目…...

xshell连接虚拟机,更换网络模式:NAT->桥接模式

NAT模式:虚拟机通过宿主机的网络访问外网。优点在于不需要手动配置IP地址和子网掩码,只要宿主机能够访问网络,虚拟机也能够访问。对外部网络而言,它看到的是宿主机的IP地址,而不是虚拟机的IP。但是,宿主机可…...

sql的where条件中使用case when

场景: 1、使用oracle数据库,数据类型为number,需要正无穷值。 2、数据表中有两个金额值,最大值和最小值, 如10~20, 30 ~40,40以上,数据库中这样设计 id name min max 1 j 10 20 2 …...

MacOS 上以源码形式安装 MySQL 5.7

以下是在 macOS 上从源码安装 MySQL 5.7 的步骤: 前置条件 安装 Homebrew:如果你还没有安装 Homebrew,可以在终端中运行以下命令进行安装: /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install…...

MySQL 事务隔离级别详解

一、事务的基本概念 (一)什么是事务 事务是一个逻辑工作单元,由一组数据库操作组成。这些操作要么全部成功执行,要么全部回滚,以确保数据库的一致性。事务具有以下四个特性,通常被称为 ACID 特性&#xff…...

C语言——高精度问题

1、高精度计算的本质&#xff1a;竖式计算&#xff1b; 2、适用解决超出long long int 范围的大整数计算 #include<stdio.h> #include<string.h> #define N 100 char str1[N4]{0},str2[N4]{0}; int arr1[N4]{0},arr2[N4]{0}; int ans[N5]{0};//将字符串转化成整型…...

aippt:AI 智能生成 PPT 的开源项目

aippt&#xff1a;AI 智能生成 PPT 的开源项目 在现代办公和学习中&#xff0c;PPT&#xff08;PowerPoint Presentation&#xff09;是一种非常重要的展示工具。然而&#xff0c;制作一份高质量的PPT往往需要花费大量的时间和精力。为了解决这一问题&#xff0c;aippt项目应运…...

【Qt之·类QSettings·参数保存】

系列文章目录 文章目录 前言一、概述1.1 QSetting是什么1.2 为什么学习QSetting是重要的 二、不同存储位置的优缺点三、 QSetting的高级用法四、实例演示总结 前言 在当今的应用程序开发中&#xff0c;设置管理是一个至关重要的方面。应用程序的设置包括用户偏好、配置选项和其…...

location重定向和nginx代理

文章目录 1 location重定向1.1 概述1.2 rewrite跳转1.3 用例1.4 实验1.4.1 基于域名的跳转1.4.2 基于ip的跳转1.4.3 基于后缀名的跳转 2 nginx的代理2.1 nginx内置变量2.2 正向代理2.2.1 固定正向代理2.2.2 自动代理 2.3 反向代理2.3.1 负载均衡的算法2.3.2 负载均衡的特点2.3.…...

iptables详解

华子目录 什么是防火墙分类netfilter&#xff08;数据包过滤&#xff09;定义netfilter分析内容 防火墙无法完成的任务netfilter策略管理工具netfilter的5类hook函数防火墙规则策略匹配原则iptablesiptables流量处理动作iptables表5种规则表 安装iptablesiptables策略文件 ipta…...

Edge SCDN深度解析,边缘安全加速的创新实践

边缘安全加速&#xff08;Edge Secure Content Delivery Network&#xff0c;SCDN&#xff09;是酷盾安全推出的边缘集分布式 DDoS 防护、CC 防护、WAF 防护、BOT 行为分析为一体的安全加速解决方案。通过边缘缓存技术&#xff0c;智能调度使用户就近获取所需内容&#xff0c;为…...

solidworks常见问题已解决

solidworks常见问题已解决 问题1&#xff1a;step总是提示默认模板无效。问题2&#xff1a;异型孔向导”时出现了“找不到标准数据库。问题3&#xff1a;找不到CalloutForm.txt文件&#xff0c;标注将由几何体定义。问题5&#xff1a;工程图显示文件损坏不能保存。问题6&#x…...

vCenter开启HA报错

昨天给客户开启vCenter开启HA功能报错,报错的内容比较多 博通官方给出解决办法 https://knowledge.broadcom.com/external/article/318929/error-vsphere-ha-agent-cannot-be-correct.html 常规的解决办法 1.关闭集群HA,再次开启HA 2.主机进入维护模式&#xff0c;再次加入…...

Phi-4-reasoning-vision-15B行业应用:银行手机银行截图→交易流程合规性审计

Phi-4-reasoning-vision-15B在银行手机银行截图合规审计中的应用实践 1. 银行业务合规审计的痛点与机遇 在银行业务数字化转型的浪潮中&#xff0c;手机银行已成为客户办理业务的主要渠道。然而&#xff0c;随之而来的是海量的交易截图和操作记录需要人工审核&#xff0c;以确…...

Apollo配置中心:从基础概念到实战应用全解析

1. Apollo配置中心初探&#xff1a;为什么我们需要它&#xff1f; 想象一下你正在开发一个电商系统&#xff0c;数据库连接地址、支付接口密钥、商品库存阈值等配置信息散落在20个不同的properties文件里。每次修改配置都需要重新打包部署&#xff0c;半夜三点被叫起来改生产环…...

前端集成实战:使用JavaScript与Vue调用国风美学模型生成动态页面素材

前端集成实战&#xff1a;使用JavaScript与Vue调用国风美学模型生成动态页面素材 最近在做一个国风主题的官网项目&#xff0c;设计师给了一堆精美的背景图、水印和装饰元素&#xff0c;但每次活动页需求一来&#xff0c;就得重新设计&#xff0c;沟通成本高&#xff0c;交付也…...

当Transformer遇上魔改鲸鱼:时序预测还能这么玩

GSWOA-Transformer多变量时序预测 Matlab代码 基于改进鲸鱼优化算法(GSWOA)优化Transformer的数据回归预测(可以更换为分类/单变量时序预测/回归&#xff0c;前私我)&#xff0c;Matlab代码&#xff0c;可直接运行&#xff0c;适合小白新手 程序已经调试好&#xff0c;无需更改…...

什么是 Harness Engineering?把 Prompt、Workflow、Eval 串成系统的那层骨架

点击上方 前端Q&#xff0c;关注公众号回复加群&#xff0c;加入前端Q技术交流群上一篇我们先把问题抛出来了&#xff1a; 为什么现在大家都在聊 Agent、Workflow、AI Coding&#xff0c;可真正决定系统上限的&#xff0c;往往不是模型本身&#xff0c;而是模型外那层工程骨架。…...

Shopee风控算法逆向 - Unidbg补环境实战解析

1. Shopee风控算法逆向分析入门 最近在研究Shopee的风控机制时&#xff0c;我发现他们的Native层加密算法特别有意思。作为一个常年和移动安全打交道的开发者&#xff0c;今天想和大家分享下使用Unidbg模拟执行Shopee风控算法的完整过程。 Shopee作为东南亚头部电商平台&…...

实时与非实时操作系统核心技术对比与应用解析

实时与非实时操作系统技术解析1. 操作系统分类概述现代计算机系统根据任务调度机制的不同&#xff0c;主要分为实时操作系统(RTOS)和分时操作系统两大类。这两类系统在任务调度、资源分配和响应机制等方面存在本质区别&#xff0c;适用于不同的应用场景。1.1 实时操作系统定义实…...

Seelen-UI桌面美化终极指南:5步打造个性化Windows工作环境

Seelen-UI桌面美化终极指南&#xff1a;5步打造个性化Windows工作环境 【免费下载链接】Seelen-UI The Fully Customizable Desktop Environment for Windows 10/11. 项目地址: https://gitcode.com/GitHub_Trending/se/Seelen-UI Seelen-UI是一个为Windows 10/11设计的…...

G-Helper:开源硬件控制工具的性能优化实践指南

G-Helper&#xff1a;开源硬件控制工具的性能优化实践指南 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops. Control tool for ROG Zephyrus G14, G15, G16, M16, Flow X13, Flow X16, TUF, Strix, Scar and other models 项目地址: http…...

告别C盘爆满!Windows 11下ESP-IDF 5.3.2环境安装与路径优化全攻略

告别C盘爆满&#xff01;Windows 11下ESP-IDF 5.3.2环境安装与路径优化全攻略 你是否经历过C盘空间告急的恐慌&#xff1f;当红色进度条填满磁盘图标时&#xff0c;那种窒息感堪比程序员面对满屏报错。对于嵌入式开发者而言&#xff0c;ESP-IDF环境安装往往成为C盘的"隐形…...