【号外】你关注我了吗?

         亲爱的“粉丝”及即将成为粉丝的网友,我的微信公众号会持续更新。由于博客排版比较耗时(相对微信公众号而言,仅个人观点),So 更新会比较slow。

         ???为了不擦肩而过,动动手指头关注微信公众号“JustDoIT2CSA”。

### 三层结构下的TCP与UDP协议区别分析 #### 是否面向连接 TCP是一种面向连接的协议,在数据传输前必须通过三次握手建立连接,确保通信双方准备好进行数据交换。而UDP是无连接的协议,发送数据之前不需要建立连接,直接发送数据包即可[^2]。 #### 可靠性 TCP提供可靠的数据传输服务,它通过确认机制、重传机制以及流量控制等手段确保数据能够完整、有序地到达接收端。相比之下,UDP不保证数据的可靠传输,可能会出现丢包的情况,适用于对实时性要求较高的应用[^1]。 #### 数据传输方式 TCP采用流模式,即将数据视为连续的字节流进行处理,接收方接收到的数据与发送方发出的数据是一致的,但具体的数据分段由TCP自动完成。UDP则采用数据报模式,每个数据报独立发送,接收方接收到的是一个个独立的数据报,每个数据报都包含完整的源地址和目的地址信息[^1]。 #### 连接对象数量 由于TCP是面向连接的,因此在一次TCP连接中只能有两个通信实体参与,即客户端和服务端,无法实现广播或多播功能。UDP支持一对一、一对多、多对一和多对多的交互通信,非常适合于需要同时向多个目标发送相同信息的应用场景[^3]。 #### 对应用报文的处理 TCP对应用层提交的连续字节流会进行适当的划分,形成适合网络传输的小块数据,并为每个小块分配序号以便于接收端重组。UDP则是将应用层的数据作为一个整体来处理,不会对其进行分割或合并操作,保持了原始的应用层报文边界[^4]。 #### 提供的传输服务 TCP向上层提供了可靠的字节流服务,包括错误检测、丢失重传、延迟排序等功能,确保数据准确无误地送达。UDP提供的则是不可靠的数据报服务,仅负责将数据报从一个主机传送到另一个主机,不对数据的完整性做任何保证[^3]。 #### 首部格式 TCP首部相对复杂,除了基本的端口号外还包括序列号、确认号、窗口大小等多个字段,用以支持其复杂的控制功能。UDP首部非常简单,仅有8个字节长,包含四个两字节长度的字段:源端口、目的端口、长度和校验和,这使得UDP头部开销较小。 #### 系统资源消耗 TCP因为要维护连接状态、执行错误恢复等任务,所以相对于UDP来说需要更多的系统资源。对于资源有限的设备或者对性能有较高要求的应用场合,选择UDP可能更加合适[^1]。 #### 适用场景 综上所述,TCP更适合那些要求高可靠性且可以容忍一定延迟的应用,如网页浏览、文件下载等;而UDP则适用于那些更看重低延迟而非绝对可靠性的应用,例如在线视频会议、实时游戏等多媒体通信领域[^2]。 ```python # TCP Server Example import socket def start_server(): # 创建socket对象 server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 绑定IP地址和端口 server_socket.bind(('localhost', 9999)) # 开始监听 server_socket.listen(5) print("Server is listening on port 9999...") while True: # 接受连接 client_socket, addr = server_socket.accept() print(f"Connection from {addr}") # 接收数据 data = client_socket.recv(1024) print(f"Received: {data.decode()}") # 回复数据 client_socket.sendall(b'Hello Client') # 关闭连接 client_socket.close() if __name__ == '__main__': start_server() ``` ```python # TCP Client Example import socket def send_message(): # 创建socket对象 client_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 连接到服务器 client_socket.connect(('localhost', 9999)) # 发送数据 client_socket.sendall(b'Hello Server') # 接收响应 response = client_socket.recv(1024) print(f"Received: {response.decode()}") # 关闭连接 client_socket.close() if __name__ == '__main__': send_message() ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值