news 2026/3/24 16:41:18

【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/3/24 5:04:41

企业架构之TOGAF 方法论入门与实战指南(2)

在当今数字化转型的浪潮中&#xff0c;企业 IT 系统变得越来越复杂。系统之间不仅要打通&#xff0c;还要灵活应对业务的快速变化。作为技术管理者或架构师&#xff0c;我们经常面临这样的灵魂拷问&#xff1a;如何确保 IT 建设不偏离业务战略&#xff1f;如何避免系统重复建设…

作者头像 李华
网站建设 2026/3/15 8:53:21

12月18号阿里云ACP线上考试成绩单~

&#x1f5d3;先说一下&#xff1a;2025年剩最后一次阿里云ACP线上考试&#xff08;12月25号&#xff09;&#xff0c;准备在2025年前拿证同学们抓紧时间报名喽~12月18号考试仍然稳定发挥&#xff1a;✅10位同学参加ACP云计算考试&#xff0c;全部通过&#xff08;7位同学在90分…

作者头像 李华
网站建设 2026/3/20 7:03:39

Xgboost-shap模型解释分析:揭开模型黑箱的面纱

Xgboost-shap模型解释分析&#xff0c;Xgboost有分类器和回归器两种&#xff0c;shap用于对各种特征重要性可视化&#xff0c;用于对机器模型的解释分析 自带数据集在机器学习领域&#xff0c;我们常常使用各种模型来进行预测和分析。然而&#xff0c;很多时候这些模型就像一个…

作者头像 李华
网站建设 2026/3/15 10:27:15

NPM_配置的补充说明

原来的registry.npm.taobao.org已替换为registry.npmmirror.com npm config set registry https://registry.npmmirror.com确认配置已经生效 npm config get registry若需要恢复默认的官方源&#xff0c;可以执行以下命令 npm config set registry https://registry.npmjs.o…

作者头像 李华