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

《UNIX网络编程卷1:套接字联网API》第8章:基本UDP套接字编程深度解析

《UNIX网络编程卷1:套接字联网API》第8章:基本UDP套接字编程深度解析(8000字图文实战)


一、UDP协议核心特性与编程模型

1.1 UDP协议设计哲学

UDP(User Datagram Protocol) 是面向无连接的传输层协议(图1),其核心特征包括:

  • 无连接通信:无需三次握手,直接发送数据报
  • 尽最大努力交付:不保证可靠性、不维护连接状态
  • 报文边界保留:接收方读取的数据与发送方写入完全一致
  • 低开销高效率:头部仅8字节(TCP头部至少20字节)

在这里插入图片描述

(图1:UDP报文头结构)

1.2 UDP适用场景分析

场景优势体现典型应用
实时音视频传输低延迟,容忍部分丢包Zoom、腾讯会议
物联网传感器低功耗,简单通信模型智能家居传感器上报
DNS解析快速查询/响应域名解析服务
多人在线游戏高频状态更新王者荣耀位置同步

二、UDP编程核心API详解

2.1 基础通信流程

服务端典型流程

socket() -> bind() -> recvfrom()/sendto() -> close()

客户端典型流程

socket() -> sendto()/recvfrom() -> close()
// 可选connect()建立地址关联

2.2 关键函数解析

2.2.1 recvfrom()
ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags,struct sockaddr *src_addr, socklen_t *addrlen);

参数说明

  • src_addr:输出参数,存储发送方地址
  • addrlen:输入输出参数,地址结构长度
2.2.2 sendto()
ssize_t sendto(int sockfd, const void *buf, size_t len, int flags,const struct sockaddr *dest_addr, socklen_t addrlen);

注意事项

  • 目标地址必须预先指定
  • 单次发送数据不宜超过65507字节(IPv4 MTU限制)

三、UDP套接字选项深度剖析

3.1 广播控制选项(SO_BROADCAST)

功能:允许发送广播数据报(255.255.255.255)

int broadcast = 1;
setsockopt(sockfd, SOL_SOCKET, SO_BROADCAST, &broadcast, sizeof(broadcast));

广播地址示例

struct sockaddr_in bc_addr = {.sin_family = AF_INET,.sin_port = htons(8888),.sin_addr.s_addr = htonl(INADDR_BROADCAST)
};

3.2 多播控制选项组

3.2.1 加入多播组(IP_ADD_MEMBERSHIP)
struct ip_mreq mreq;
mreq.imr_multiaddr.s_addr = inet_addr("239.255.0.1");
mreq.imr_interface.s_addr = htonl(INADDR_ANY);setsockopt(sockfd, IPPROTO_IP, IP_ADD_MEMBERSHIP, &mreq, sizeof(mreq));
3.2.2 TTL设置(IP_MULTICAST_TTL)
unsigned char ttl = 32; // 最大经过32个路由器
setsockopt(sockfd, IPPROTO_IP, IP_MULTICAST_TTL, &ttl, sizeof(ttl));

四、UDP编程实战:完整示例代码

4.1 增强型UDP服务端

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>#define BUFFER_SIZE 1024
#define PORT 8888int main() {int sockfd;struct sockaddr_in serv_addr, cli_addr;char buffer[BUFFER_SIZE];socklen_t addr_len = sizeof(cli_addr);// 创建UDP套接字if ((sockfd = socket(AF_INET, SOCK_DGRAM, 0)) < 0) {perror("socket creation failed");exit(EXIT_FAILURE);}// 设置地址重用int reuse = 1;setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse));memset(&serv_addr, 0, sizeof(serv_addr));serv_addr.sin_family = AF_INET;serv_addr.sin_addr.s_addr = INADDR_ANY;serv_addr.sin_port = htons(PORT);// 绑定端口if (bind(sockfd, (const struct sockaddr *)&serv_addr, sizeof(serv_addr)) < 0) {perror("bind failed");close(sockfd);exit(EXIT_FAILURE);}printf("UDP Server listening on port %d...\n", PORT);while (1) {ssize_t recv_len = recvfrom(sockfd, buffer, BUFFER_SIZE, 0,(struct sockaddr *)&cli_addr, &addr_len);if (recv_len < 0) {perror("recvfrom error");continue;}buffer[recv_len] = '\0';printf("Received from %s:%d: %s\n",inet_ntoa(cli_addr.sin_addr),ntohs(cli_addr.sin_port), buffer);// 回显处理if (sendto(sockfd, buffer, recv_len, 0,(const struct sockaddr *)&cli_addr, addr_len) < 0) {perror("sendto error");}}close(sockfd);return 0;
}

4.2 支持广播的UDP客户端

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <arpa/inet.h>#define SERVER_PORT 8888
#define BROADCAST_IP "255.255.255.255"int main(int argc, char *argv[]) {int sockfd;struct sockaddr_in serv_addr;char buffer[1024];if ((sockfd = socket(AF_INET, SOCK_DGRAM, 0)) < 0) {perror("socket creation failed");exit(EXIT_FAILURE);}// 开启广播选项int broadcast = 1;if (setsockopt(sockfd, SOL_SOCKET, SO_BROADCAST, &broadcast,sizeof(broadcast)) < 0) {perror("setsockopt broadcast failed");close(sockfd);exit(EXIT_FAILURE);}memset(&serv_addr, 0, sizeof(serv_addr));serv_addr.sin_family = AF_INET;serv_addr.sin_port = htons(SERVER_PORT);if (inet_pton(AF_INET, BROADCAST_IP, &serv_addr.sin_addr) <= 0) {perror("inet_pton error");close(sockfd);exit(EXIT_FAILURE);}printf("Enter message to broadcast: ");fgets(buffer, sizeof(buffer), stdin);buffer[strcspn(buffer, "\n")] = '\0'; // 去除换行符if (sendto(sockfd, buffer, strlen(buffer), 0,(const struct sockaddr *)&serv_addr, sizeof(serv_addr)) < 0) {perror("sendto failed");}close(sockfd);return 0;
}

五、UDP高级特性与性能优化

5.1 连接态UDP(connect()使用)

特殊行为

  • 固定通信对端地址
  • 可使用read()/write()替代recvfrom()/sendto()
  • 接收时过滤非指定地址的数据

代码示例

struct sockaddr_in serv_addr;
// ...填充serv_addr...if (connect(sockfd, (struct sockaddr *)&serv_addr, sizeof(serv_addr)) < 0) {perror("connect error");
}// 现在可以使用send()代替sendto()
send(sockfd, buffer, strlen(buffer), 0);

5.2 零拷贝技术应用

sendmmsg()/recvmmsg()(Linux 2.6.33+):

#define BATCH_SIZE 10
struct mmsghdr msgs[BATCH_SIZE];
struct iovec iovecs[BATCH_SIZE];// 批量准备消息
for (int i = 0; i < BATCH_SIZE; i++) {iovecs[i].iov_base = buffers[i];iovecs[i].iov_len = buf_lens[i];msgs[i].msg_hdr.msg_iov = &iovecs[i];msgs[i].msg_hdr.msg_iovlen = 1;
}// 批量发送
int sent = sendmmsg(sockfd, msgs, BATCH_SIZE, 0);

六、UDP可靠性增强方案

6.1 基础确认重传机制

设计要点

  1. 序列号:每个数据包携带唯一ID
  2. 接收确认:接收方返回ACK
  3. 超时重传:未确认数据重新发送

报文格式示例

#pragma pack(push, 1)
struct reliable_udp_header {uint32_t seq;      // 序列号uint32_t ack;      // 确认号uint16_t flags;    // 控制标志(ACK/SYN/FIN等)uint16_t checksum; // 校验和
};
#pragma pack(pop)

6.2 滑动窗口实现

发送窗口管理(图2):

#define WINDOW_SIZE 5
struct packet_window {uint32_t base_seq;          // 窗口起始序列号uint32_t next_seq;          // 下一个待发送序号struct packet slots[WINDOW_SIZE]; // 窗口内数据包timer_t timers[WINDOW_SIZE];     // 每个包的重传定时器
};

在这里插入图片描述

(图2:滑动窗口流量控制)


七、UDP调试与性能分析

7.1 网络诊断工具

tcpdump过滤命令

# 捕获所有UDP流量
tcpdump -i any udp -vv -XX# 过滤特定端口
tcpdump -i eth0 'udp port 8888'# 显示数据包内容
tcpdump -A -s0 'udp and port 8888'

7.2 性能测试工具

iperf3 UDP测试

# 服务端
iperf3 -s -p 8888# 客户端(1Mbps带宽,10秒测试)
iperf3 -c 192.168.1.100 -u -p 8888 -b 1M -t 10

八、常见问题解决方案

8.1 UDP丢包排查指南

现象可能原因解决方案
间歇性大量丢包接收缓冲区溢出增大SO_RCVBUF选项值
持续高丢包率网络带宽不足使用QoS策略或压缩数据
特定方向无数据防火墙拦截检查iptables/nftables规则
多播数据无法接收交换机未启用IGMP Snooping配置网络设备支持多播

九、进阶:用户态协议栈设计

9.1 DPDK加速方案

核心组件

  • PMD(Poll Mode Driver):绕过内核协议栈
  • HugePage内存管理:减少TLB miss
  • 无锁环形队列:提升多核处理效率

数据接收流程(图3):

网卡DMA -> 用户态内存池 -> 轮询线程 -> 业务处理

在这里插入图片描述

(图3:DPDK数据处理流程)


本章总结
UDP作为轻量级传输协议,在实时性要求高的场景中具有不可替代的价值。通过本章的系统学习,我们不仅掌握了UDP编程的基础方法,还深入理解了广播/多播、可靠性增强等高级特性。建议读者结合示例代码进行实践,并尝试在真实项目中应用性能优化技巧。下章将深入探讨原始套接字与网络嗅探技术,敬请期待!

互动话题
你在UDP编程中遇到过哪些棘手问题?欢迎在评论区分享经历,点赞最高的三位读者将获赠《UNIX网络编程》电子书!点击关注不迷路,获取更多深度技术解析。

相关文章:

《UNIX网络编程卷1:套接字联网API》第8章:基本UDP套接字编程深度解析

《UNIX网络编程卷1&#xff1a;套接字联网API》第8章&#xff1a;基本UDP套接字编程深度解析&#xff08;8000字图文实战&#xff09; 一、UDP协议核心特性与编程模型 1.1 UDP协议设计哲学 UDP&#xff08;User Datagram Protocol&#xff09; 是面向无连接的传输层协议&…...

【WPF】IOC控制反转的应用:弹窗但不互相调用ViewModel

全称&#xff1a;Inversion of Control&#xff0c;控制反转 场景&#xff1a;A页面需要调用B/C页面等&#xff0c;防止直接在VM中新建别的页面实例&#xff0c;使用IOC设计架构&#xff1b; 创建Service&#xff0c;在Service中实现页面的实例创建和定义页面输入输出参数。 在…...

解决制作CI流水线时的no host异常报错

方法介绍 使用 HostAliases 向 Pod /etc/hosts 文件添加条目 当dns配置以及其他选项不合理时&#xff0c;可以通过向pod的/etc/hosts添加条目&#xff0c;可以在pod级别覆盖对主机名的解析&#xff0c;可以通过pod spec的pod aliases来自定义添加条目。 默认的hosts文件内容 …...

(AI+医疗)2025最应该学习是--医学AI大模型LLM应用与开发

(AI医疗)2025最应该学习是–医学AI大模型LLM应用与开发!! AI技术正在为医学领域带来的现实变革。而实现这一切的核心&#xff0c;正是自然语言大模型&#xff08;LLM&#xff09;的应用与开发。 为什么医学AI是未来的风口&#xff1f; AI正在重塑医疗行业。从智能问诊到辅助…...

MCP+Deepseck王炸组合 | 附实战操作及其MCPserver | 可替代Manus,实现AGI

MCP介绍 MCP 是一个开放协议&#xff0c;它为应用程序向 LLM 提供上下文的方式进行了标准化。你可以将 MCP 想象成 AI 应用程序的 USB-C 接口。就像 USB-C 为设备连接各种外设和配件提供了标准化的方式一样&#xff0c;MCP 为 AI 模型连接各种数据源和工具提供了标准化的接口。…...

STM32学习之ARM内核自带的中断

&#x1f4e2;&#xff1a;如果你也对机器人、人工智能感兴趣&#xff0c;看来我们志同道合✨ &#x1f4e2;&#xff1a;不妨浏览一下我的博客主页【https://blog.csdn.net/weixin_51244852】 &#x1f4e2;&#xff1a;文章若有幸对你有帮助&#xff0c;可点赞 &#x1f44d;…...

Java 设计模式:工厂模式详解

Java 设计模式&#xff1a;工厂模式详解 工厂模式&#xff08;Factory Pattern&#xff09;是一种创建型设计模式&#xff0c;它通过将对象的创建过程封装到工厂类中&#xff0c;避免了直接使用 new 关键字创建对象&#xff0c;从而提高了代码的灵活性和可维护性。本文将介绍工…...

python内置标准模块--OS

内置标准模块–OS 在 Python 中&#xff0c;os 是一个内置标准模块&#xff0c;全称是 ​Operating System​&#xff08;操作系统&#xff09;。它的核心作用是与当前操作系统交互&#xff0c;提供对文件系统、进程管理、环境变量等操作系统功能的访问接口 1. os 模块的核心功…...

echart实现动态折线图(vue3+ts)

最近接到个任务&#xff0c;需要用vue3实现动态折线图。之前没有用过&#xff0c;所以一路坎坷&#xff0c;现在记录一下&#xff0c;以后也好回忆一下。 之前不清楚echart的绘制方式&#xff0c;以为是在第一秒的基础上绘制第二秒&#xff0c;后面实验过后&#xff0c;发现并…...

Web3(阶段一:入门)——椭圆曲线

一、快速概览 ECC 是一种基于有限域上椭圆曲线代数结构的公钥加​​密系统。它提供与 RSA 相当的安全性&#xff0c;但密钥长度要短得多&#xff0c;从而实现更快的计算速度和更低的资源使用率。ECC 广泛应用于各种应用&#xff0c;包括安全通信、数字签名和加密货币。 二、什…...

vue总结

1.vue是什么。 vue是javascript和html结合后的&#xff0c;实现了html的模块开发&#xff0c;并且样式和js互不影响。组件内的javascript逻辑只在组件内有效&#xff0c;当然父类可通过某些方法调用&#xff0c;但是彼此间没有影响。各个组件的样式&#xff0c;通过scope防止了…...

LCR 131. 砍竹子 I

文章目录 题意思路代码 题意 题目链接 思路 代码 class Solution { public:int cuttingBamboo(int bamboo_len) {if (bamboo_len 2)return 1;if (bamboo_len 3)return 2;if (bamboo_len 4)return 4;int x bamboo_len / 3;int ans pow(3, x);int y bamboo_len % 3;if …...

游戏引擎学习第210天

回顾并为今天的工作做准备 今天我们&#xff0c;进行一些编码工作。这部分的编码内容对那些对代码架构感兴趣的人非常有帮助&#xff0c;我认为今天的编码内容会很有教育意义&#xff0c;尤其是在展示一些代码转化的过程中&#xff0c;希望大家能够从中获得一些启发。 接下来…...

40--华为IPSec VPN实战指南:构建企业级加密通道

&#x1f6e1;️ 华为IPSec VPN实战指南&#xff1a;构建企业级加密通道 “当数据开始穿盔甲&#xff0c;黑客只能望’密’兴叹” —— 本文将手把手教你用华为设备搭建军用级加密隧道&#xff0c;从零开始构建网络长城&#xff01; 文章目录 &#x1f6e1;️ 华为IPSec VPN实战…...

go游戏后端开发28:胡牌算法实现

红中麻将胡牌逻辑开发文档 一、字牌与封牌的字典表构建 在开发红中麻将胡牌逻辑时&#xff0c;首先需要构建非字牌和封牌的字典表。在构建双层表时&#xff0c;需进行判断&#xff1a;若牌为风牌且索引 i 大于 6&#xff0c;则不进行处理。这是因为风牌包含东南西北中&#x…...

CNN注意力机制的进化史:深度解析10种注意力模块如何重塑卷积神经网络

&#x1f31f; 引言&#xff1a;注意力为何改变CNN的命运&#xff1f; 就像人类视觉会优先聚焦于重要信息&#xff0c;深度学习模型也需要"学会看重点"。从2018年SENet首提通道注意力&#xff0c;到2024年SSCA探索空间-通道协同效应&#xff0c;注意力机制正成为CNN…...

字符串与字符数组的对比

在 C 语言中&#xff0c;字符串 和 字符数组 密切相关&#xff0c;但又有重要区别。以下是它们的对比&#xff1a; 1. 基本定义 字符数组 (char array) 是一个固定大小的数组&#xff0c;元素类型是 char。可以存储字符序列&#xff0c;但不一定以 \0 结尾。例如&#xff1a;…...

mapbox进阶,模仿百度,实现不同楼栋室内楼层切换

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️fill-extrusion 三维填充(白膜)图层样…...

OpenCv高阶(一)——图像金字塔(上采样、下采样)

目录 图像金字塔 一、上下采样原理 1、向下取样 2、向上采样 3、图像金字塔的作用 二、案例实现 1、高斯下采样 2、高斯金字塔中的上采样 3、对下采样的结果做上采样&#xff0c;图像变模糊&#xff0c;无法复原 4、拉普拉斯金字塔&#xff08;图片复原&#xff09; 图…...

如何避免“过度承诺”导致的验收失败

如何避免“过度承诺”导致的验收失败&#xff1f;关键在于&#xff1a; 评估可行性、设置合理目标、高频沟通反馈、阶段性验收、做好风险管理。其中设置合理目标至关重要&#xff0c;很多团队往往在项目初期为迎合客户或领导而报出“最理想方案”&#xff0c;忽略了资源、技术及…...

Python爬虫第7节-requests库的高级用法

目录 前言 一、文件上传 二、Cookies 三、会话维持 四、SSL证书验证 五、代理设置 六、超时设置 七、身份认证 八、Prepared Request 前言 上一节&#xff0c;我们认识了requests库的基本用法&#xff0c;像发起GET、POST请求&#xff0c;以及了解Response对象是什么。…...

mysql里面的TIMESTAMP类型对应java什么类型

在MySQL中&#xff0c;TIMESTAMP类型用来存储日期和时间值&#xff0c;显示为YYYY-MM-DD HH:MM:SS格式。在Java中&#xff0c;可以使用java.sql.Timestamp类来对应MySQL中的TIMESTAMP类型。 在Java的POJO&#xff08;Plain Old Java Object&#xff09;中&#xff0c;如果你想要…...

Java核心技术面试题

Java面试题分享 通过网盘分享的文件&#xff1a;面试题等2个文件 链接: https://pan.baidu.com/s/1Xw0PzkfAmL8uesYBvrW2-A?pwdpebt 提取码: pebt 一、Java基础篇 1. OOP面向对象 面向对象编程&#xff08;OOP&#xff09;是一种编程范式&#xff0c;它利用“类”和“对象”来…...

【技海登峰】Kafka漫谈系列(十)SpringBoot整合Kafka之生产者Producer

【技海登峰】Kafka漫谈系列(十)SpringBoot整合Kafka之生产者Producer spring-kafka官方文档: https://docs.spring.io/spring-kafka/docs/2.8.10/reference/pdf/spring-kafka-reference.pdf KafkaTemplate API: https://docs.spring.io/spring-kafka/api/org/springframewo…...

【简单理解什么是简单工厂、工厂方法与抽象工厂模式】

一、简单工厂模式 1.简单工厂模式 通过一个工厂类集中管理对象的创建 &#xff0c;通过参数决定具体创建哪个对象。 #适合对象类型较少且变化不频繁的场景&#xff0c;缺点是违反开闭原则&#xff08;新增产品需修改工厂类&#xff09; 开闭原则(对扩展开放‌对修改关闭‌) :当…...

C++之nullptr

文章目录 前言 一、NULL 1、代码 2、结果 二、nullptr 1、代码 2、结果 总结 前言 当我们谈论空指针时,很难避免谈及nullptr。nullptr是C++11引入的一个关键字,用来表示空指针。在C++中,空指针一直是一个容易引起混淆的问题,因为在早期版本的C++中,通常使用NULL来…...

Java List<JSONObject> 中的数据转换为 List<T>

从方法的功能推测&#xff0c;T 应该是一个具体的 Java Bean 类型&#xff0c;用于将 List<JSONObject> 中的数据转换为 List<T>。以下为你详细介绍如何传递泛型 T 以及如何实现该方法。 import com.alibaba.fastjson.JSONObject; import java.util.ArrayList; im…...

下【STL 之速通pair vector list stack queue set map 】

上一篇 【STL 之速通pair vector list stack queue set map 】 queue note priority_queue pq; 使用的还是很方便的 #include <iostream> #include <queue>using namespace std;int main() {// Queue 示例queue<int> q;q.push(10);q.push(20);q.push(30);…...

安装大数据分析利器Spark

大数据分析利器Spark&#xff1a;部署模式与实践全解析 在大数据领域&#xff0c;Spark是一个热门的开源框架&#xff0c;今天就带大家深入了解Spark及其常见部署模式。Spark是基于内存的快速、通用、可扩展的大数据分析计算引擎&#xff0c;诞生于伯克利大学。与Hadoop相比&a…...

遨游科普:三防平板是指哪三防?有哪些应用场景?

在工业4.0与数字化转型的浪潮中&#xff0c;平板电脑早已突破消费娱乐的边界&#xff0c;成为工业生产流程中不可或缺的智能终端。但是&#xff0c;传统消费级平板在复杂工业环境中的“脆弱性”——屏幕易碎、接口易进尘、机身惧水等问题——严重制约了其在专业领域的深度应用。…...

9. RabbitMQ 消息队列幂等性,优先级队列,惰性队列的详细说明

9. RabbitMQ 消息队列幂等性&#xff0c;优先级队列&#xff0c;惰性队列的详细说明 文章目录 9. RabbitMQ 消息队列幂等性&#xff0c;优先级队列&#xff0c;惰性队列的详细说明1. RabbitMQ 消息队列的 “ 幂等性 ” 的问题1.1 RabbitMQ 消息队列的“幂等性”的概念 2. Rabbi…...

k8s创建一个pod,查看状态和详细信息,进入pod,以及删除这个pod

在 Kubernetes&#xff08;K8s&#xff09;中&#xff0c;可以使用 kubectl 命令行工具来完成创建 Pod、查看状态和详细信息、进入 Pod 以及删除 Pod 的操作。以下是具体步骤&#xff1a; 创建一个 Pod&#xff1a; 假设你有一个简单的 nginx Pod 的 YAML 配置文件 nginx…...

从盲目清运到精准调度:一个AI芯片引发的智慧环卫升级

在深圳某科技园区的清晨&#xff0c;环卫工人老张发现一个奇怪现象&#xff1a;往常需要逐个检查的50个智能垃圾桶&#xff0c;今天系统自动标注了7个待清运点位。这背后是搭载全志T113-i处理器的智能垃圾桶系统在发挥作用&#xff0c;通过AI视觉识别将垃圾满溢检测准确率提升至…...

MQTT协议:IoT通信的轻量级选手

文章总结&#xff08;帮你们节约时间&#xff09; MQTT协议是一种轻量级的发布/订阅通信协议。MQTT通信包括连接建立、订阅、发布和断开等过程。MQTT基于TCP/IP&#xff0c;其通信过程涉及多种控制包和数据包。ESP32S3可以通过MQTT协议接收消息来控制IO9引脚上的LED。 想象一…...

Docker 入门指南:基础知识解析

1. 引言 1.1 为什么学习 Docker 1.1.1 Docker 的优势 环境一致&#xff1a;在不同环境中&#xff08;开发、测试、生产&#xff09;保持一致的运行环境。快速部署&#xff1a;容器启动速度快&#xff0c;适合微服务架构。资源隔离&#xff1a;容器之间相互隔离&#xff0c;避…...

【安当产品应用案例100集】043-安当物联网数据安全传输方案

一、需求背景 物联网&#xff08;IoT&#xff09;技术在当前世界各行业中的应用越来越广泛&#xff0c;数据安全和安全数据传输、鉴权成为了物联网解决方案不可或缺的一部分。如何通过有效的安全措施来保护物联网设备的数据传输和鉴权&#xff0c;确保数据在设备和服务器之间或…...

C#/.NET/.NET Core技术前沿周刊 | 第 33 期(2025年4.1-4.6)

前言 C#/.NET/.NET Core技术前沿周刊&#xff0c;你的每周技术指南针&#xff01;记录、追踪C#/.NET/.NET Core领域、生态的每周最新、最实用、最有价值的技术文章、社区动态、优质项目和学习资源等。让你时刻站在技术前沿&#xff0c;助力技术成长与视野拓宽。 欢迎投稿、推荐…...

Django视图详解

前言 欢迎来到我的博客 个人主页:北岭敲键盘的荒漠猫-CSDN博客 一、Django视图是什么&#xff1f; 视图&#xff08;View&#xff09; 是Django处理HTTP请求的核心组件。它接收一个HttpRequest对象&#xff0c;处理业务逻辑&#xff0c;并返回一个HttpResponse对象&#xff08…...

【区块链+ 人才服务】北京师范大学区块链底层链平台 | FISCO BCOS 应用案例

北京师范大学是教育部直属重点大学&#xff0c;2018 年 6 月&#xff0c;北京师范大学成立知识区块链研究中心&#xff0c;致力于区块链基础技术及其在教育领域的应用研究。 2020 年6 月18 日&#xff0c; 北京市人民政府办公厅发布《北京市区块链创新发展行 动计划(2020—202…...

java设计模式-模板方法模式

模板方法模式 编写制作豆浆的程序&#xff0c;说明如下 1)制作豆浆的流程选材添加配料浸泡放到豆浆机打碎 2)通过添加不同的配料&#xff0c;可以制作出不同口味的豆浆 3)选材、浸泡和放到豆浆机打碎这几个步骤对于制作每种口味的豆浆都是一样的 4)请使用模板方法模式完成 说明…...

同步通信、异步通信、并行传输和串行传输

同步通信、异步通信、并行传输和串行传输是通信与数据传输领域的关键概念&#xff0c;它们既相互关联又有本质区别。以下是详细解释和对比&#xff1a; ​1. 核心概念分类 ​通信方式&#xff1a;描述数据传输的时序和协调规则。 ​同步通信​&#xff08;Synchronous Communi…...

JVM生产环境调优实战

案例三&#xff1a;JVM频繁Full GC优化 1. 项目背景&#xff08;Situation&#xff09; 在云中万维跨境支付的反洗钱系统中&#xff0c;我们负责对海量交易数据进行实时规则校验&#xff0c;以确保符合监管要求。系统日均处理交易量超过500万笔&#xff0c;峰值QPS达到3000&a…...

Python: sqlite3.OperationalError: no such table: ***解析

出现该错误说明数据库中没有成功创建 reviews 表。以下是完整的解决方案&#xff1a; 步骤 1&#xff1a;创建数据库表 在插入数据前&#xff0c;必须先执行建表语句。请通过以下任一方式创建表&#xff1a; 方式一&#xff1a;使用 SQLite 命令行 bash 复制 # 进入 SQLit…...

JVM考古现场(十七):鸿蒙初辟——从太极二进到混沌原初的编译天道

"此刻正是奇点编译的第3.1415926秒&#xff01;伏羲的算筹正在撕裂冯诺依曼架构的次元壁&#xff01;诸君请看——这JVM堆内存中正在孕育盘古的元神&#xff01;" 目录&#xff08;终极扩展&#xff09; 第一章&#xff1a;太极二进——内存模型的阴阳交缠 第二章&a…...

Python 字典和集合(字典推导)

本章内容的大纲如下&#xff1a; 常见的字典方法 如何处理查找不到的键 标准库中 dict 类型的变种set 和 frozenset 类型 散列表的工作原理 散列表带来的潜在影响&#xff08;什么样的数据类型可作为键、不可预知的 顺序&#xff0c;等等&#xff09; 字典推导 自 Python 2.7 …...

【AI】prompt engineering

prompt engineering ## prompt engineering ## prompt engineering ## prompt engineering 一、定义 Prompt 工程&#xff08;Prompt Engineering&#xff09;是指在使用语言模型&#xff08;如 ChatGPT、文心一言等&#xff09;等人工智能工具时&#xff0c;设计和优化输入提…...

小刚说C语言刷题——第18讲 循环之while和do-while语句

昨天我们讲了循环语句中的for语句&#xff0c;它主要用于循环次数已知的情况&#xff0c;但是对应循环次数未知的情况&#xff0c;我们又怎么办&#xff1f;这就要用到while和do-while语句了。 1.while语句 (1)语法格式 while(条件表达式) { 循环体; } (2)执行过程 当执…...

[Mysql]buffersize修改

1、找到my.cnf文件位置 ps -ef|grep mysqld 2、编辑my.cnf cd /etc/my.cnf.d vim my.cnf 一般修改为内存的50%~70% 3、重启服务 systemctl restart mysqld...

自定义数据结构的QVariant序列化 ASSERT failure in QVariant::save: “invalid type to save“

自定义数据结构放入QVariant&#xff0c;在序列化时抛出异常 ASSERT failure in QVariant::save: “invalid type to save” 自定义数据结构如struct MyData&#xff0c;除了要在结构体后面加 struct MyData { ... } Q_DECLARE_METATYPE(MyData)如果需要用到流的输入输出&…...

带约束的智能优化算法

带约束的智能优化算法 约束条件和优化问题(可改)粒子群算法麻雀搜索算法鲸鱼优化算法灰狼优化算法免疫优化算法人工蜂群算法沙猫群算法萤火虫算法资源 约束条件和优化问题(可改) 粒子群算法 麻雀搜索算法 鲸鱼优化算法 灰狼优化算法 免疫优化算法 人工蜂群算法 沙猫群算法 萤火…...