news 2026/2/3 2:49:48

【Linux网络基础】详解网络字节序与大小端模式 (Network Byte Order Endianness)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Linux网络基础】详解网络字节序与大小端模式 (Network Byte Order Endianness)

详解网络字节序与大小端模式 (Network Byte Order & Endianness)

本文详细讲解计算机系统中的字节序(Byte Order)概念,包括大端模式(Big-Endian)和小端模式(Little-Endian)的区别、内存布局,以及网络编程中必须遵守的网络字节序规则。


1. 什么是字节序 (Byte Order)?

在计算机中,数据是以**字节(Byte)**为单位存储的。一个字节包含8位(bit)。对于单字节的数据(如char),存储和处理都很简单,不存在顺序问题。

然而,对于多字节数据(如int,short,long等),它们占用多个字节。例如,一个 32 位的整数0x12345678占用 4 个字节。当我们要把这 4 个字节存储到内存中时,就涉及到一个顺序问题:是先把高位字节(0x12)存到低地址,还是先把低位字节(0x78)存到低地址?

这就引出了字节序的概念。

核心术语

  • MSB (Most Significant Byte): 最高有效字节。在0x12345678中,0x12是 MSB。
  • LSB (Least Significant Byte): 最低有效字节。在0x12345678中,0x78是 LSB。

2. 大端模式 (Big-Endian)

定义:数据的高位字节(MSB)存储在内存的低地址端,低位字节(LSB)存储在内存的高地址端。

特点

  • 符合人类的阅读习惯(从左到右)。
  • 也就是:高位在低地址

内存布局示意图

假设我们有一个 32 位整数0x12345678,存储在起始地址为A的内存中。

Mermaid 示意:

Memory
Address A+1 : 0x34
Address A+2 : 0x56
Address A : 0x12(MSB)
Address A+3 : 0x78(LSB)

3. 小端模式 (Little-Endian)

定义:数据的低位字节(LSB)存储在内存的低地址端,高位字节(MSB)存储在内存的高地址端。

特点

  • 符合计算机处理逻辑(低位先处理)。
  • 也就是:低位在低地址
  • 常见的 x86 架构(Intel, AMD)都是小端模式。

内存布局示意图

同样是 32 位整数0x12345678,存储在起始地址为A的内存中。

Mermaid 示意:

Memory
Address A+1 : 0x56
Address A+2 : 0x34
Address A : 0x78(LSB)
Address A+3 : 0x12(MSB)

4. 大端与小端的对比

特性大端模式 (Big-Endian)小端模式 (Little-Endian)
存储顺序MSB -> 低地址LSB -> 低地址
可读性好,符合人类阅读习惯差,逆序存储
典型架构PowerPC, IBM,网络协议x86 (Intel/AMD), ARM (默认)
判定口诀高尾端(高位在低地址)低尾端(低位在低地址)

5. 网络字节序 (Network Byte Order)

在网络通信中,不同的计算机可能采用不同的字节序(例如一台是大端机,一台是小端机)。为了保证数据在传输过程中的正确性,TCP/IP 协议规定了统一的网络字节序

规定网络字节序采用大端模式 (Big-Endian)

这意味着:

  1. 发送方主机在发送数据前,必须将数据从主机字节序 (Host Byte Order)转换为网络字节序
  2. 接收方主机在接收数据后,必须将数据从网络字节序转换为主机字节序

转换函数 (C/C++)

操作系统提供了一组标准函数来进行转换,通常在<arpa/inet.h><netinet/in.h>中。

  • h代表 host (主机)
  • n代表 network (网络)
  • s代表 short (16位,用于端口号)
  • l代表 long (32位,用于IP地址)
函数名作用解释
htons()Host to Network Short主机字节序 -> 网络字节序 (16位)
htonl()Host to Network Long主机字节序 -> 网络字节序 (32位)
ntohs()Network to Host Short网络字节序 -> 主机字节序 (16位)
ntohl()Network to Host Long网络字节序 -> 主机字节序 (32位)

6. 代码实战:检测当前系统的字节序

我们可以编写一段简单的 C 代码来检测当前机器是是大端还是小端。

方法一:使用联合体 (Union)

联合体的所有成员共享同一块内存。

#include<stdio.h>intcheck_endian_union(){union{inti;charc;}u;u.i=1;// 0x00000001// 如果是小端,内存中是 01 00 00 00,c 取低地址字节,为 1// 如果是大端,内存中是 00 00 00 01,c 取低地址字节,为 0return(u.c==1);}intmain(){if(check_endian_union()){printf("当前系统是:小端模式 (Little-Endian)\n");}else{printf("当前系统是:大端模式 (Big-Endian)\n");}return0;}

方法二:使用指针强制转换

#include<stdio.h>intcheck_endian_pointer(){inti=1;// 0x00000001// 将 int 指针强制转为 char 指针,指向最低地址的一个字节char*c=(char*)&i;// 如果 *c 是 1,说明低地址存的是 0x01 (低位),即小端return(*c==1);}intmain(){if(check_endian_pointer()){printf("当前系统是:小端模式 (Little-Endian)\n");}else{printf("当前系统是:大端模式 (Big-Endian)\n");}return0;}

7. 总结

  1. 字节序是多字节数据在内存中的存储顺序。
  2. 大端模式:高位在低地址(符合阅读习惯,网络标准)。
  3. 小端模式:低位在低地址(x86架构标准)。
  4. 网络通信:必须统一使用大端模式作为网络字节序。
  5. 编程实践:在涉及网络传输时,务必使用htons,htonl等函数进行转换,不要假设对方的机器字节序。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/30 14:11:53

Langchain-Chatchat与主流大模型集成的最佳实践

Langchain-Chatchat与主流大模型集成的最佳实践 在企业智能化转型的浪潮中&#xff0c;一个日益突出的问题浮出水面&#xff1a;通用大语言模型虽然“博学”&#xff0c;却对企业内部制度、项目文档、合规流程等私有知识一无所知。更令人担忧的是&#xff0c;将敏感文件上传至云…

作者头像 李华
网站建设 2026/1/29 20:10:09

基于YOLOv8/YOLOv10/YOLOv11/YOLOv12与SpringBoot的前后端分离疲劳驾驶识别检测系统(DeepSeek智能分析+web交互界面)

一、 系统引言 随着社会经济的快速发展&#xff0c;汽车已成为不可或缺的交通工具&#xff0c;但随之而来的道路交通安全问题也日益严峻。其中&#xff0c;疲劳驾驶是导致重大交通事故的主要因素之一&#xff0c;对驾驶员和公众的生命财产安全构成了严重威胁。统计表明&#x…

作者头像 李华
网站建设 2026/2/1 14:34:47

Langchain-Chatchat在政务知识库建设中的应用前景

Langchain-Chatchat在政务知识库建设中的应用前景 在政务服务日益智能化的今天&#xff0c;公众对政策咨询的期待早已超越了“能查到”&#xff0c;而是要求“秒懂、精准、可信赖”。然而现实是&#xff0c;大量群众面对冗长的法规条文和复杂的办事指南时仍感到无从下手。某市医…

作者头像 李华
网站建设 2026/1/30 14:52:55

Meta的 Mango「芒果」模型:看来AI视频生成要变天了

&#x1f4cc; 目录扎克伯格的「芒果」要炸场&#xff01;Meta神秘AI视频模型Mango曝光&#xff1a;4K/60帧秒出片&#xff0c;好莱坞都要慌了一、Meta的野心&#xff1a;不止超越Sora&#xff0c;要把AI视频搬进专业片场&#xff08;一&#xff09;Mango vs 现有AI视频工具&am…

作者头像 李华
网站建设 2026/2/1 6:16:31

moodycamel::ConcurrentQueue 清空队列的方法论

方法1&#xff1a;循环弹出元素 #include <concurrentqueue.h>// 如果存储的是指针类型 moodycamel::ConcurrentQueue<int*> queue; int* item nullptr; while (queue.try_dequeue(item)) {if (item) {delete item; // 如果需要释放内存item nullptr;} }// 如果…

作者头像 李华