整型,长整型,无符号整型等 大端和小端(Big endian and Little endian)
一、大端和小端的问题
对于整型、长整型、无符号整型等数据类型,Big endian 认为第一个字节是最高位字节(按照从低地址到高地址的顺序存放数据的高位字节到低位字节);而 Little endian 则相反,它认为第一个字节是最低位字节(按照从低地址到高地址的顺序存放据的低位字节到高位字节)。
例如,假设从内存地址 0x0000 开始有以下数据:
0x0000 0x0001 0x0002 0x0003
0x12 0x34 0xab 0xcd
如果我们去读取一个地址为 0x0000 的四个字节变量,若字节序为big-endian,则读出结果为0x1234abcd;若字节序为little-endian,则读出结果为0xcdab3412。
如果我们将0x1234abcd 写入到以 0x0000 开始的内存中,则Little endian 和 Big endian 模式的存放结果如下:
地址 0x0000 0x0001 0x0002 0x0003
big-endian 0x12 0x34 0xab 0xcd
little-endian 0xcd 0xab 0x34 0x12
一般来说,x86 系列 CPU 都是 little-endian 的字节序,PowerPC 通常是 big-endian,网络字节顺序也是 big-endian还有的CPU 能通过跳线来设置 CPU 工作于 Little endian 还是 Big endian 模式。
对于0x12345678的存储:
小端模式:(从低字节到高字节)
地位地址 0x78 0x56 0x34 0x12 高位地址
大端模式:(从高字节到低字节)
地位地址 0x12 0x34 0x56 0x78 高位地址
二、大端小端转换方法
htonl() htons() 从主机字节顺序转换成网络字节顺序
ntohl() ntohs() 从网络字节顺序转换为主机字节顺序
Big-Endian转换成Little-Endian
#define BigtoLittle16(A) ((((uint16)(A) & 0xff00) >> 8) | (((uint16)(A) & 0x00ff) << 8)) #define BigtoLittle32(A) ((((uint32)(A) & 0xff000000) >> 24) | (((uint32)(A) & 0x00ff0000) >> 8) | \(((uint32)(A) & 0x0000ff00) << 8) | (((uint32)(A) & 0x000000ff) << 24))
三、大端小端检测方法
如何检查处理器是big-endian还是little-endian?
C程序:
int i = 1; char *p = (char *)&i; if(*p == 1) printf("Little Endian"); elseprintf("Big Endian");
大小端存储问题,如果小端方式中(i占至少两个字节的长度)则i所分配的内存最小地址那个字节中就存着1,其他字节是0.大端的话则1在i的最高地址字节处存放,char是一个字节,所以强制将char型量p指向i则p指向的一定是i的最低地址,那么就可以判断p中的值是不是1来确定是不是小端。
联合体union的存放顺序是所有成员都从低地址开始存放,利用该特性就可以轻松地获得了CPU对内存采用Little-endian还是Big-endian模式读写
/*return 1: little-endian, return 0: big-endian*/ int checkCPUendian() {union{unsigned int a;unsigned char b; }c;c.a = 1;return (c.b == 1); }
实现同样的功能,来看看Linux 操作系统中相关的源代码是怎么做的:
static union { char c[4]; unsigned long mylong; } endian_test = {{ 'l', '?', '?', 'b' } };#define ENDIANNESS ((char)endian_test.mylong)
转载于:https://www.cnblogs.com/lcawen/p/11463119.html
整型,长整型,无符号整型等 大端和小端(Big endian and Little endian)相关推荐
- 浅析无符号整型和有符号整型
整型包括长整型(long),短整形(short),整型(int),字符型(char).众所周知,char是字符类型.但其实char也是一个比较古怪的整型,长度为1字节 (默认是无符号类型). 然后我们 ...
- C语言 有符号整型和无符号整型的比较
C语言 有符号整型和无符号整型比较时,有符号整型自动转换成无符号整型,所以 10<-100 注意题给整数的范围,判断比较的整数类型
- 0 有符号和无符号整型数字
8位无符号整型:0 -> 255 11111111 255 ... 10000000 128 01111111 127 ... 00000000 0 8位有符 ...
- php无符号整数转有符号整数,PHP中把有符号整型转换为无符号整型方法_PHP教程...
PHP中把有符号整型转换为无符号整型方法 这篇文章主要介绍了PHP中把有符号整型转换为无符号整型方法,转换的方法很简单,本文直接给出转换方法,需要的朋友可以参考下 在一个短地址项目中,根据六位字符与I ...
- size_t 和int 无符号整型和有符号整型
size_t一般用来表示一种计数,比如有多少东西被拷贝等,例如sizeof操作符的结果类型是size_t,该类型保证能容纳实现所建立的最大对象的字节大小.他的意义大致是: 适于计量内存中可容纳的数据项 ...
- 有符号和无符号整型的临界点
在C++ primer plus 上的图 觉得好久copy下来了 关于有符号和无符号整型的重置点 .
- 【c语言学习课堂笔记第三天】:int函数有符号整型和无符号整型
int 函数 有符号整型: 概念:截图 sizeof函数可查看字节数量 声明变量技巧: 随堂笔记: #include <stdio.h> #include <stdlib.h> ...
- 无符号整型与有符号整型
最近对于有符号整型与无符号整型,感觉很是头疼,都不知道怎么一回事.先看例子 #include<stdio.h> int main(void) { unsigned a=2; ...
- 负数时的有符号整型和无符号整型的转换
目录 一.补码 二.负数时的有符号整型和无符号整型的转换 三.关于无符号的笔试题 一.补码 有符号数在计算机中存储,用数的最高位存放符号, 正数为0, 负数为1 例如:有符号数 1000 0011,其 ...
最新文章
- JS如何捆绑TypeScript声明文件
- Redis应用案例,查找某个值的范围(转)
- android gradle tools 3.X 中依赖,implement、api 和compile区别
- Silverlight+WCF 新手实例 象棋 主界面-事件区-求和认输(三十二)
- C++容器map可以排序吗?
- ubuntu 13.04 安装 GRUB customizer
- DJANGO,获取当前用户名,用户组名,用户组权限
- [转]Angular2 使用管道Pipe以及自定义管道格式数据
- C语言小案例_OA大典案例摘录【第1374篇】| 异常色块 规则 合集 | 爱普生喷墨打印机...
- eNSP教程 —— 物理机如何使用web登录到防火墙
- 国产操作系统中标麒麟v6
- 云栖号在线课堂—云服务器数据库快速入门特辑
- Work Breakdown Structure
- Python 读取文件夹中指定后缀的文件
- 【总结】1334- JS中Object的keys是无序的吗
- 第 12 章		武装飞船
- Java如何爬虫奥运奖牌榜数据,恭喜中国获得东京奥运会首金!
- for循环打印九九乘法表
- 小学生都看得懂的C语言入门(1): 基础/判别/循环
- 信息收集汇总(附网盘泄露工具)