UDP学习笔记(一)为什么UDP需要先将数据转换为字节数组

ops/2025/3/10 1:56:20/

UDP 发送数据时需要先将数据转换为字节数组再发送,主要是因为计算机网络传输的最基本单位是“字节”(Byte)。让我们从以下几个方面来深入理解这个设计选择:


1. 计算机网络只能传输“字节”

在网络通信中,无论是 TCP 还是 UDP,最终传输的都是二进制数据。计算机不能直接传输字符串、整数或对象,而是需要转换为字节数组

📌 示例:发送字符串 "Hello"

kotlin">val data = "Hello".toByteArray() // 转换为字节数组
  • 计算机存储 "Hello" 不是存字符串,而是存储对应的 ASCII/UTF-8 字节
    H -> 72 (0x48)
    e -> 101 (0x65)
    l -> 108 (0x6C)
    l -> 108 (0x6C)
    o -> 111 (0x6F)
    
  • toByteArray() 生成的字节数组:
    kotlin">[72, 101, 108, 108, 111]
    
  • 这些字节才是真正可以通过 UDP 发送的数据

2. UDP 只是负责“搬运”字节数据

UDP 协议本质上是一个简单的“快递员”,它的任务是:

  1. 接收 一串二进制数据(字节数组)。
  2. 打包 数据,加上 IP 头、UDP 头(源端口、目标端口、数据长度等)。
  3. 发送 到网络。

UDP 不关心数据的类型,它只知道:

  • 这是一串二进制数据(字节数组)。
  • 需要发送到某个 IP 和端口。

这就像:

  • 快递员不管你寄的是书、本子还是手机,他们只在乎包装好的箱子(字节数组)。
  • UDP 也不管数据是不是字符串、图片或视频,它只是传输“字节”。

3. 统一格式,适用于所有数据类型

因为所有数据最终都能转换成字节数组,所以 UDP 传输时不需要关心数据格式。例如:

  • 字符串:转换为字节数组 toByteArray()
  • 整数:转换为字节数组 ByteBuffer.allocate(4).putInt(value).array()
  • 图片:JPEG/PNG 本质上也是字节数组
  • 音视频流:H.264/MP3 等数据流都是字节数组

不管是什么数据,只要能变成字节数组,UDP 就能传输

📌 示例:发送整数 1234

kotlin">val buffer = ByteBuffer.allocate(4).putInt(1234).array()
  • 结果是:
    kotlin">[0, 0, 4, 210] // 这是 1234 的二进制表示
    
  • 这个字节数组就可以通过 UDP 发送了。

4. 其他协议(如 TCP)也是传输字节

不仅是 UDP,所有网络协议最终传输的都是字节

  • HTTP 发送网页数据:HTML 文件也是字节数据。
  • FTP 传输文件:文件本质上也是字节流。
  • WebSocket 传输消息:消息数据同样要转换为字节数组。

无论是字符串、图片、视频、音频,在网络上传输时都必须转换为字节流,这样才能统一处理。


5. 提高数据传输的灵活性

如果 UDP 允许直接发送 字符串、整数、对象,那么:

  • 每种数据类型的发送方式都不同,协议设计会变得复杂。
  • 不同设备可能理解不了数据,比如一个 Java 设备发送 int,一个 Python 设备接收,它就可能无法解析。

字节数组是最通用的格式,不同设备(Windows、Linux、Android、iOS)都能理解字节数据,这样 UDP 就可以跨平台工作。


总结

  1. 计算机只能传输字节数据,所以 UDP 只能发送 字节数组
  2. UDP 只是一个“快递员”,它不关心数据类型,只搬运二进制数据。
  3. 所有数据都能转换为字节数组,所以 UDP 只需要支持 发送字节,而不用关心具体的数据类型。
  4. 网络上所有协议(HTTP、FTP、TCP、UDP)最终传输的都是字节数据,这样能兼容不同操作系统和设备。
  5. 这种设计让 UDP 更加通用和高效,无论是发送文本、图片还是音视频,都可以用 相同的方式 传输。

http://www.ppmy.cn/ops/164532.html

相关文章

ubuntu 20.04 C++ 源码编译 cuda版本 opencv4.5.0

前提条件是安装好了cuda和cudnn 点击下载: opencv_contrib4.5.0 opencv 4.5.0 解压重命名后 进入opencv目录,创建build目录 “CUDA_ARCH_BIN ?” 这里要根据显卡查询一下,我的cuda是11,显卡1650,所以是7.5 查询方法1&#xff1…

Windsuf 连接失败问题:[unavailable] unavailable: dial tcp...

问题描述 3月6日,在使用Windsuf 时,遇到以下网络连接错误: [unavailable] unavailable: dial tcp 35.223.238.178:443: connectex: A connection attempt failed because the connected party did not properly respond after a period of…

2025 年开源替代方案为何正在取代 OutSystems?技术自由度与成本优势深度解析

原文链接:https://www.nocobase.com/cn/blog/outsystems-open-source-alternatives OutSystems 的隐藏成本不只是金钱 OutSystems 是企业低代码开发领域的领军者。通过将生成式 AI 工具深度集成到软件生命周期,OutSystems 助力企业快速构建客户导向的门…

DeepSeek集成到VScode工具,让编程更高效

DeepSeek与VScode的强强联合,为编程效率树立了新标杆。 DeepSeek,一款卓越的代码搜索引擎,以其精准的索引和高速的检索能力,助力开发者在浩瀚的代码海洋中迅速定位关键信息。 集成至VScode后,开发者无需离开熟悉的编辑…

AI正逐渐进入科技+非科技的深水区

随着AI的快速发展,人工智能正逐渐进入一个融合科技与非科技领域的复杂系统。在传统上,AI主要依赖于科学技术,如算法、计算力和大数据等,来处理和分析信息,进行预测和决策。然而,随着AI的应用范围不断扩展&a…

用友 U8出入库查询SQL 连接UNION ALL

-- 销售出库单查询 SELECT 销售出库单 AS 单据类型, a.cCode AS 单号, a.dDate AS 日期, a.cMaker AS 制单人, a.cHandler AS 审核人, a.dVeriDate AS 审核日期, b.cInvCode AS 存货编码, b.iQuantity AS 数量, b.cBatch AS 批号, c.…

hbase集群archive目录过大问题处理

1.问题现象 现场反馈hbase集群/hbase/archive目录过大,大小约为1.52PB 现场集群已经清理掉2个月以前的snapshot文件,当前archive目录文件仍不能释放现场发现1T以上的archive子目录有211个查看集群hbase配置,hmaster堆栈大小20GB,hmaster清理周期5分钟查看hmaster进程分配内…

②EtherCAT转Modbus485RTU网关多路同步高速采集无需编程串口服务器

EtherCAT转Modbus485RTU网关多路同步高速采集无需编程串口服务器https://item.taobao.com/item.htm?ftt&id798036415719 网关 MS-A2-1021 产品功能 MS-A2-1021 网关通过 EtherCAT 协议与自由协议或 Modbus 协议的相互转换,可以将RS485 串口设备接入 EtherCA…