UDP(用户数据报协议)和 TCP(传输控制协议)

2024-08-23 19:12

本文主要是介绍UDP(用户数据报协议)和 TCP(传输控制协议),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

UDP(用户数据报协议)和 TCP(传输控制协议)是两种常用的传输层协议,各自适用于不同的应用场景。以下是对这两种协议及其常用函数和知识点的总结。

一、UDP(用户数据报协议)
UDP 是一种无连接、不可靠的传输协议,适用于需要快速传输且对可靠性要求不高的应用,如视频流、游戏等。

1. UDP 的特点:
- 无连接:UDP 发送数据时不需要建立连接。
- 不可靠传输:不保证数据到达和顺序,不提供重传机制。
- 面向消息:发送的消息是一个独立的包,不拆分也不合并。

 2. 常用函数:
- `socket()`:创建 UDP 套接字。
  
  int socket(int domain, int type, int protocol);
  
  - `domain`:协议族(如 AF_INET)。
  - `type`:套接字类型(UDP 使用 SOCK_DGRAM)。
  - `protocol`:通常为 0,系统自动选择协议。

- `bind()`:绑定套接字到本地地址和端口。
  
  int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
  
  - `sockfd`:套接字描述符。
  - `addr`:本地地址结构。
  - `addrlen`:地址结构的长度。

- `sendto()`:发送数据到指定的地址。
  
  ssize_t sendto(int sockfd, const void *buf, size_t len, int flags, const struct sockaddr *dest_addr, socklen_t addrlen);
  
  - `sockfd`:套接字描述符。
  - `buf`:要发送的数据。
  - `len`:数据长度。
  - `dest_addr`:目标地址结构。

- `recvfrom()`:从套接字接收数据。
  
  ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags, struct sockaddr *src_addr, socklen_t *addrlen);
  
  - `buf`:存放接收到的数据。
  - `src_addr`:发送方地址结构。

3. 使用 UDP 的流程:
1. 创建套接字 (`socket`)。
2. 对于服务器,绑定套接字到指定的地址和端口 (`bind`)。
3. 使用 `sendto` 发送数据或 `recvfrom` 接收数据。
4. 关闭套接字 (`close`)。

二、TCP(传输控制协议)
TCP 是一种面向连接、可靠的传输协议,适用于对数据传输可靠性要求较高的场景,如网页浏览、文件传输等。

1. TCP 的特点:
- 面向连接:通信前需要建立连接(三次握手)。
- 可靠传输:保证数据到达、顺序和完整性,提供重传机制。
- 流控和拥塞控制:确保网络的稳定性和高效性。

2. 常用函数:
- `socket()`:创建 TCP 套接字。

  int socket(int domain, int type, int protocol);

  - 与 UDP 类似,只是 `type` 使用 `SOCK_STREAM`。

- `bind()`:绑定套接字到本地地址和端口。
  - 与 UDP 中的 `bind` 相同。

- `listen()`:将套接字设置为被动监听模式,等待连接。
  
  int listen(int sockfd, int backlog);
  
  - `backlog`:未完成连接的队列大小。

- `accept()`:接受连接请求,创建新的套接字。
  
  int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
  
  - `addr`:存放客户端地址。
  - `addrlen`:地址结构的长度。

- `connect()`:客户端发起连接请求。
  
  int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
  
  - `addr`:服务器地址。

- `send()`:向已连接的套接字发送数据。
  
  ssize_t send(int sockfd, const void *buf, size_t len, int flags);
  

- `recv()`:从已连接的套接字接收数据。
  
  ssize_t recv(int sockfd, void *buf, size_t len, int flags);
  

3. 使用 TCP 的流程:
服务器端:
1. 创建套接字 (`socket`)。
2. 绑定套接字到指定的地址和端口 (`bind`)。
3. 设置套接字为监听模式 (`listen`)。
4. 接受客户端连接 (`accept`)。
5. 使用 `send` 和 `recv` 进行数据通信。
6. 关闭连接 (`close`)。

客户端:
1. 创建套接字 (`socket`)。
2. 连接到服务器 (`connect`)。
3. 使用 `send` 和 `recv` 进行数据通信。
4. 关闭连接 (`close`)。

三、UDP 与 TCP 的对比
- 连接:UDP 是无连接的,TCP 是面向连接的。
- 可靠性:UDP 不保证数据到达和顺序,TCP 保证数据的完整性和顺序。
- 速度:UDP 速度快,适合实时应用;TCP 较慢,但提供可靠的传输。
- 数据传输:UDP 是面向消息的,不拆分和重组;TCP 是面向字节流的,会根据需要进行拆分和重组。

这篇关于UDP(用户数据报协议)和 TCP(传输控制协议)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1100252

相关文章

Python在二进制文件中进行数据搜索的实战指南

《Python在二进制文件中进行数据搜索的实战指南》在二进制文件中搜索特定数据是编程中常见的任务,尤其在日志分析、程序调试和二进制数据处理中尤为重要,下面我们就来看看如何使用Python实现这一功能吧... 目录简介1. 二进制文件搜索概述2. python二进制模式文件读取(rb)2.1 二进制模式与文本

基于C++的UDP网络通信系统设计与实现详解

《基于C++的UDP网络通信系统设计与实现详解》在网络编程领域,UDP作为一种无连接的传输层协议,以其高效、低延迟的特性在实时性要求高的应用场景中占据重要地位,下面我们就来看看如何从零开始构建一个完整... 目录前言一、UDP服务器UdpServer.hpp1.1 基本框架设计1.2 初始化函数Init详解

C#实现将XML数据自动化地写入Excel文件

《C#实现将XML数据自动化地写入Excel文件》在现代企业级应用中,数据处理与报表生成是核心环节,本文将深入探讨如何利用C#和一款优秀的库,将XML数据自动化地写入Excel文件,有需要的小伙伴可以... 目录理解XML数据结构与Excel的对应关系引入高效工具:使用Spire.XLS for .NETC

MySQL数据目录迁移的完整过程

《MySQL数据目录迁移的完整过程》文章详细介绍了将MySQL数据目录迁移到新硬盘的整个过程,包括新硬盘挂载、创建新的数据目录、迁移数据(推荐使用两遍rsync方案)、修改MySQL配置文件和重启验证... 目录1,新硬盘挂载(如果有的话)2,创建新的 mysql 数据目录3,迁移 MySQL 数据(推荐两

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

MySQL中的DELETE删除数据及注意事项

《MySQL中的DELETE删除数据及注意事项》MySQL的DELETE语句是数据库操作中不可或缺的一部分,通过合理使用索引、批量删除、避免全表删除、使用TRUNCATE、使用ORDERBY和LIMI... 目录1. 基本语法单表删除2. 高级用法使用子查询删除删除多表3. 性能优化策略使用索引批量删除避免

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE

Linux服务器数据盘移除并重新挂载的全过程

《Linux服务器数据盘移除并重新挂载的全过程》:本文主要介绍在Linux服务器上移除并重新挂载数据盘的整个过程,分为三大步:卸载文件系统、分离磁盘和重新挂载,每一步都有详细的步骤和注意事项,确保... 目录引言第一步:卸载文件系统第二步:分离磁盘第三步:重新挂载引言在 linux 服务器上移除并重新挂p