判断大小端

#include <stdio.h>

int main(void)
{
    union { 
        int  i;
        char c;
    } u = { 0x4200004c };

    printf("%c\n", u.c);

    return 0;
}
时间: 2024-10-04 02:26:57

判断大小端的相关文章

C++如何判断大小端

http://bbs.chinaunix.net/thread-1257205-1-1.html #include <stdio.h>#include <string.h>#include <stdlib.h> int main(void){        unsigned short v = 0x0102;        unsigned char *p = (unsigned char *)&v; if (*p == 0x01)               

判断大小端的方法(java和c++)

首先我们给出大小端的定义: 小端:较高的有效字节存放在较高的的存储器地址,较低的有效字节存放在较低的存储器地址. 大端:较高的有效字节存放在较低的存储器地址,较低的有效字节存放在较高的存储器地址. 将0x12345678写入到以1000h开始的内存中,这里0x12346578中0x12~0x78的地址是从高到低 如果,我们的机器是小端存储的话,结果为: 数据      地址0x78        1000H0x56        1001H0x34        1002H0x12      

Linux中判断大小端的一种方法

大小端的定义无需赘言,常用的方法有使用联合体和指针法,如: int checkCPU() { union w { int a; char b; }c; c.a = 1; return (c.b == 1); // 小端返回TRUE,大端返回FALSE } 实际上Linux操作系统的源码中,其判断更为简洁: static union { char c[4]; unsigned long mylong; } endian_test = {{ 'l', '?', '?', 'b' } }; #defi

[C/C++]_[初级]_[判断大小端序Little Endian Order]

场景: 1. 在读取硬盘数据和媒体数据时,需要根据读取的数据进行大小端序的转换,以正确识别数据.其中一个处理就是首先要判断cpu支持的大小端序情况才能转换. 2. Little Endian Order: 低地址存低位(整数的高低位)的数据. test.cpp #include <stdio.h> #include <iostream> using namespace std; //1.方法1,通过判断int的低位是否存储了数值. int IsLittleEndian1() { i

判断大小端序的C程序

概念 大端格式:字数据的高字节存储在低地址中,而字数据的低字节则存放在高地址中. 小端格式:与大端存储格式相反,在小端存储格式中,低地址中存放的是字数据的低字节,高地址存放的是字数据的高字节. 如5A6C中5A是高字节.6C是低字节,在大端序机器中,高字节位于低地址中,即在大端序中按照5A6C存储,在小端序中按照6C5A存储. 为什么存在这种模式 因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为8bit.但是在C语言中除了8bit的char之外,还有16bit的

简短程序判断大小端

先放代码: int check() { union { unsigned int a; unsigned char b; }c; c.a = 1; return 1 == c.b; } 再说原理: 上述程序,如果返回值为1则是小端,如果是0则大端,因为union类型共用一段内存,所以c占4个字节(假设是32位机器),把1赋给a,如果是小端则1会存放在低位,则取出b也是1,反之若是大端则1存放在高位,b即为0.

C语言判断大小端

1 #include <stdio.h> 2 typedef unsigned char BYTE; 3 int main(int argc, char* argv[]) 4 { 5 unsigned int num,*p; 6 p = &num; 7 num = 0; 8 *(BYTE *)p = 0xff; 9 if(num == 0xff) 10 { 11 printf("little\n"); 12 } 13 else //num == 0xff000000

C语言一个语句判断大小端

1 int isLittleEndian(void) 2 { 3 return *(char *)(int []){1} == 1; 4 } 关于Compound Literals,https://gcc.gnu.org/onlinedocs/gcc-3.3.1/gcc/Compound-Literals.html

CPU的大小端及如果判断

不同体系结构的CPU,数据在内存中存放的排列顺序是不一样的. 存储器中对数据的存储是以字节(Byte)为基本单位的,因此,字(Word)和半字(Half-Word)在存储器中就有两种次序,分别称为:大端模式(Big Endian)和小端模式(Little Endian). 大端存储模式是指字或半字的最高字节(Most Significant Bit,MSB)存放在内存的最低位字节地址上,而字数据的低字节则存放在高地址中.打个比方,有一个字为0×12345678,这个字由4个字节组成, 从高位到低