大端还是小端

//way 1union
{
   unsigned long biths;  unsigned char bytes[4];
} theValue;

//way 2ndtypedef char* bytePointer;void showBytes(bytePointer p, int len){  int i;

  for(i = 0; i < len; ++i)    printf("%.2x -> %p", p[i], p+i);}

void showShort(short svar){  showBytes((bytePointer) &svar, sizeof(short));}

int main(){  theValue.bytes[0] = 0;  theValue.bytes[1] = 1;  theValue.bytes[2] = 0;  theValue.bytes[3] = 0;  int isLittleEndian;  isLittleEndian = theValue == 256;//为真则为小端,否则为大端

  short svar = 01;  showShort(svar);//按字节地址从低地址到高地址打印字节内容

}

1.关于字节序列

2.以上倒很清楚,要注意的是一个字节占据8个位。printf格式输出如果不熟悉的话(像我现在就不太熟悉),会有潜在的误会。

例如256.是占据第二个字节的最低位。因为第一个字节各位全为0.

十进制: 1, 2, 4, 8; 16, 32, 64, 128; 256 .... 1依次在二进制各位的十进制数的大小。

二进制: 0000 0000 0001 0000

十六进制:0       0       1     0

最终showBytes()中printf的%x是按照十六进制的方式输出。

3.首先要肯定自己是对的,就是这些基础知识是掌握了的。不要随意推翻自己。

本人有点自卑的习惯。这个毛病要改掉。慢慢改掉。

4.但是我用的是苹果电脑,我一直预想输出是大端的样子。可殊不知,我才想到苹果支持intel,用了它的cpu:

dogdot$ sysctl machdep.cpu

machdep.cpu.max_basic: 13

machdep.cpu.max_ext: 2147483656

machdep.cpu.vendor: GenuineIntel

machdep.cpu.brand_string: Intel(R) Core(TM) i5-4278U CPU @ 2.60GHz

时间: 2024-10-13 06:53:30

大端还是小端的相关文章

大端和小端(big endian little endian)

一.大端和小端的问题 对于整型.长整型等数据类型,Big endian 认为第一个字节是最高位字节(按照从低地址到高地址的顺序存放数据的高位字节到低位字节):而 Little endian 则相反,它认为第一个字节是最低位字节(按照从低地址到高地址的顺序存放据的低位字节到高位字节). 例如,假设从内存地址 0x0000 开始有以下数据:  0x0000         0x0001       0x0002       0x0003  0x12            0x34          

大端和小端(Big endian and Little endian)

一.大端和小端的问题 对于整型.长整型等数据类型,Big endian 认为第一个字节是最高位字节(按照从低地址到高地址的顺序存放数据的高位字节到低位字节):而 Little endian 则相反,它认为第一个字节是最低位字节(按照从低地址到高地址的顺序存放据的低位字节到高位字节). 例如,假设从内存地址 0x0000 开始有以下数据:  0x0000         0x0001       0x0002       0x0003  0x12            0x34          

1、打印二进制机器码,程序内存分析,大端序小端序,指针数组,数组指针,数组的三种访问方式,typedef,#if-0-#endif,求数组大小,括号表达式

 1.打印二进制机器码(分别表示32位的和64位的) #include <stdio.h> /*按照8位的长度打印一个数值*/ void dis8bit(char val) { int bit = 8; while(bit--) { if(1<<bit&val){ printf("1"); } else { printf("0"); } if(!(bit%4)) printf(" "); } putchar(1

【转】轻松记住大端小端的含义(附对大端和小端的解释)

原文网址:http://www.cnblogs.com/wuyuegb2312/archive/2013/06/08/3126510.html 或许你曾经仔细了解过什么是大端小端,也动手编写了测试手头上的机器上是大端还是小端的程序,甚至还编写了大端小端转换程序:但过了一段时间之后,当你再看到大端和小端这两个字眼,你的脑中很快浮起了自己曾经做过的工作,却总是想不起究竟哪种是大端.哪种是小端,然后又去查以前写的记录?更让人不快的是,这种经历反反复复,让你十分困扰.如果你和以前的笔者一样,有过这种不快

【转】如何判断CPU是大端还是小端模式

原文网址:http://blog.csdn.net/ysdaniel/article/details/6617458 如何判断CPU是大端还是小端模式 http://blog.sina.com.cn/s/blog_66a61f310100i7m0.html MSB:Most Significant Bit  ------- 最高有效位    LSB:Least Significant Bit ------- 最低有效位 大端模式(big-edian) big-endian:MSB存放在最低端的地

如何判断主机是大端还是小端(字节序)

[转帖来自]:http://blog.csdn.net/forestlight/article/details/6933528 今天看<linux程序设计>中关于跨平台需要注意的事项,看到了大端小端的问题.突然想起实验室一同学的笔试题,如何判断主机的大端还是小端. 所谓大端就是指高位值在内存中放低位地址,所谓小端是指低位值在内存中放低位地址.比如0x12345678在大端机上是12345678,在小端机上是78564312,而一个主机是大端还是小端要看cpu类型以及运行在上面的操作系统.同一款

网络通信之 字节序转换原理与网络字节序、大端和小端模式

原文地址:http://www.cnblogs.com/fuchongjundream/p/3914770.html 一.在进行网络通信时是否需要进行字节序转换? 相同字节序的平台在进行网络通信时可以不进行字节序转换,但是跨平台进行网络数据通信时必须进行字节序转换. 原因如下:网络协议规定接收到得第一个字节是高字节,存放到低地址,所以发送时会首先去低地址取数据的高字节.小端模式的多字节数据在存放时,低地址存放的是低字节,而被发送方网络协议函数发送时会首先去低地址取数据(想要取高字节,真正取得是低

轻松记住大端小端的含义(附对大端和小端的解释)

在计算机里,对于地址的描述,很少用“大”和“小”来形容:对应地,用的更多的是“高”和“低”:很不幸地,这对术语直接按字面翻译过来就成了“大端”和“小端”,在裘宗燕翻译的<程序设计实践>里,这对术语并没有翻译为“大端”和小端,而是“高尾端”和“低尾端”,这就好理解了:如果把一个数看成一个字符串,比如11223344看成"11223344",末尾是个'\0','11'到'44'各占用一个存储单元,那么它的尾端很显然是44,前面的高还是低就表示尾端放在高地址还是低地址,它在内存中

判断大端与小端

//写一个程序判断编译器是大端还是小端 #include<stdio.h> #include<stdlib.h> int main() { int a = 0x11223344; char *p = (char*)&a; if (*p == 0x11) { printf("大端"); } else { printf("小端"); } system("pause"); return 0; } 大于一个字节的程序都存在

判断系统是大端还是小端的两种方法

#include <iostream> #include <stdio.h> #include <malloc.h> #include <string.h> using namespace std; //判断系统是大端还是小端:通过将&int转换为char* int fun() { int num = 1; // *((char*)&num)获得num的最低字节,为0x00,说明是大端 为0x01,说明是小端 return *((char*)