利用union类型测试机器是大端还是小端(Big_endian or Little_endian)

#include<stdio.h>
int check_sys()
{
 union check
 {
  int i;
  char ch;
    }c;
 c.i = 1;
 return (c.ch == 1);
}
int main()
{
 int ret = check_sys();
 if (ret == 1)
  printf("Little_endian\n");
 else
  printf("Big_endian\n");
 system("pause");
 return 0;
}

时间: 2024-10-12 20:51:43

利用union类型测试机器是大端还是小端(Big_endian or Little_endian)的相关文章

两种方法实现判断当前机器是大端还是小端

大端:低位存高地址,高位存低地址 小端:低位存低地址,高位存高地址 <span style="font-size:18px;">//用联合的方式实现 #include<stdio.h> union UN { int a; char c; }; int main() { union UN un; un.a=1; if(un.c==1) printf("little\n"); if(un.c==0) printf("big\n"

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

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

我如何确定一个机器的字节顺序是大端还是小端?

通常的技巧是使用一个指针: int x = 1; if(*(char *)&x == 1) printf("little-endian\n"); else printf("big-endian\n"); 或者一个union: union { int i; char c[sizeof(int)]; } x; x.i = 1; if(x.c[0] == 1) printf("little-endian\n"); else printf(&qu

【转】如何判断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存放在最低端的地

大端法和小端法

引言 在计算机内存中,通常是以字节(Byte),也就是 8 个位(Bit)为基本存储单元(也有以 16 位为基本存储单元的).对于跨越多个字节的数据类型(比如 int 长 4 个字节),如何在内存中对这些字节进行排序有两种常见的方法:大端法(Big-endian)和小端法(Little-endian) [注]首先不管是大端法还是小端法存储,计算机在内存中存放数据的顺序都是从低地址到高地址,所不同的是首先取低字节的数据存放在低地址还是取高字节数据存放在低地址. 基本概念 高位放在低地址就是大端法

大端和小端(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          

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

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

用C语言,如何判断主机是 大端还是小端(字节序)

所谓大端就是指高位值在内存中放低位地址,所谓小端是指低位值在内存中放低位地址.比如 0x12345678 在大端机上是 12345678,在小端机上是 78564312,而一个主机是大端还是小端要看CPU类型以及运行在上面的操作系统.同一款CPU在不同的操作系统使用的大小端情况是不同的.当然我们通常使用的 x86 + windows是小端. 测试大小端一般使用 union的特性.union是一个联合体,所有变量公用一块内存,只是在不同的时候解释不同.其在内存中存储是按最长的那个变量所需要的位数来