A、C#大端模式和小端模式。
小端(little-endian)模式:低地址上存放低字节,高地址上存放高字节。
如0x11223344→ byte[] numBytes = new byte[]{ 0x44,0x33,0x22,0x11};
numBytes[0] = 0x44; //低地址存放低字节
numBytes[3] = 0x11; //高地址存放高字节
反之,高字节在前,低字节在后,则为大端模式。
反转示例:
short num = 12;
byte[] bytes = BitConverter.GetBytes(s);
Array.Reverse(bytes); //bytes转换为倒序(反转),可实现大端小端的转换
B、大端模式和小端模式。原文地址:https://blog.csdn.net/qqliyunpeng/article/details/68484497
作者: 李云鹏(qqliyunpeng@sina.cn)
版本号: 20170330
更新时间: <2017-04-06>
原创时间: <2017-03-30>
版权: 本文采用以下协议进行授权,自由转载 - 非商用 - 非衍生 - 保持署名 | Creative Commons BY-NC-ND 3.0,转载请注明作者及出处.
1. 概念简介
不同的系统在存储数据时是分大端(bit-endian)小端(little-endian)存储的,比如,Inter x86、ARM核采用的是小端模式,Power PC、MIPS UNIX和HP-PA UNIX采用大端模式
小端模式用文字描述是,低地址上存放低字节,高地址上存放高字节。
假如有一个32位的数据 0x11223344,则在小端模式上的机器上存储为如下的形式:
【1】0x11223344这个数中 0x11 是高字节(MSB),0x44是地字节(LSB)
【2】讨论大小端的时候最小单位是字节
【3】内存的画法中采用的是向上增长的
【3】可以将数据比作方向盘,顺时钟旋转得到的在内存中的布局是小端存储
至于大端模式用文字描述是,低地址上存放高字节,高地址上存放低字节。
2. 如何判断
判断的方法有很多种,下面将简单的列举几种:
第一种方法:
- /*
- * 1: little-endian
- * 0: big-endian
- */
- int checkEndian()
- {
- int a = 1;
- char *p = (char *)&a;
- return (*p == 1);
- }
【1】如果是大端,*p的结果是0
第二种方法:
- /*
- * 1: little-endian
- * 0: big-endian
- */
- int checkEndian()
- {
- union w
- {
- int a;
- char b;
- } c;
- c.a = 1;
- return (c.b == 1);
- }
函数中打印方法: