Linux 字节序
字节序不是由操作系统决定的,而是由cpu架构决定的,比如 x86 的是 little endian,而 PPC (PowerPC) 是big endian。 所以跑在 x86 上的 linux/windows 都是小端,而跑在 PPC 上的linux则是大端。 (PS: 实际上 PowerPC 是即支持大端也支持小端,但是由于历史原因默认用大端)
- 字节序分为大端字节序(big endian)和小端字节序(little endian)
- 大端字节序:一个整数的高位字节(23-31bit)存储在内存的低地址处,低位字节(0-7bit)存储在内存的高地址处。
- 小端字节序:一个整数的高位字节(23-31bit)存储在内存的高地址处,低位字节(0-7bit)存储在内存的低地址处。
#include<stdio.h>
int main()
{
union
{
short value;
char union_bytes[sizeof(short)];
}test;
test.value = 0x0102;
if((test.union_bytes[0]==1)&&(test.union_bytes[1]==2))
{
printf("big endian\n");
}
else if((test.union_bytes[0]==2)&&(test.union_bytes[1]==1))
{
printf("little endian\n");
}
else
{
printf("unkown...\n");
}
}
#include <stdio.h>
int main(int argc, char *argv[])
{
unsigned int a = 0x12345678;
unsigned char *p = (unsigned char *)&a; //只取一个字节
if(0x12 == *p){
printf("Big-Endian\n");
}else if(0x78 == *p){
printf("Little-Endian\n");
}
return 0;
}
#include <stdio.h>
#include <arpa/inet.h>
int main(int argc, char *argv[])
{
int a = 0x01020304;
short int b = 0x0102;
printf("htonl(0x%08x) = 0x%08x\n", a, htonl(a));
printf("htons(0x%04x) = 0x%04x\n", b, htons(b));
return 0;
}
htonl:
将主机的无符号长整形数转换成网络字节顺序。
htons:
将一个无符号短整型数值转换为网络字节序,即大端模式(big-endian)
https://blog.csdn.net/tennysonsky/article/details/45045549
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律