1.大小端与其检测方法
大端(存储)模式:是指一个数据的低位字节序的内容放在高地址处,高位字节序存的内容放在低地址处。
小端(存储)模式:是指一个数据的低位字节序内容存放在低地址处,高位字节序的内容存放在高地址处。(可以总结为“小小小”即低位、低地址、小端)
注意这里说的都是含有字节序的类型的变量,比如int。 而char类型的变量就不能用来检测,因为它就一个字节,根本不存在字节序的概念,想检测也检测不了。例,一个int型数据0x12345678,它的大小端存放方式分别为:
地址 | 大端数据 | 小端数据 |
0x200000004 | 0x78 | 0x12 |
0x200000003 | 0x56 | 0x34 |
0x200000002 | 0x34 | 0x56 |
0x200000001 | 0x12 | 0x78 |
检测方法
方法1. 使用指针
#include <stdio.h>
int main()
{
int i = 1;
char *a = (char *)&i;
if(*a == 1)
printf("小端\n");
else
printf("大端\n");
return 0;
}
方法2. 使用联合体
int Check_Sys()
{
union
{
int i;
char c;
}un;
un.i = 1;
return un.c;//如果是小端返回1,如果是大端返回0
}
int main()
{
if(Check_Sys())
printf("小端\n");
else
printf("大端\n");
return 0;
}
2. 对寄存器某一位操作
嵌入式系统总是要用户对变量或寄存器进行位操作。给定一个整型变量a,写两段代码,第一个设置a的bit 3,第二个清除a 的bit 3。在以上两个操作中,要保持其它位不变。【程序员面试宝典】
对这个问题有三种基本的反应
1)不知道如何下手。该被面者从没做过任何嵌入式系统的工作。
2) 用bit fields。Bit fields是被扔到C语言死角的东西,它保证你的代码在不同编译器之间是不可移植的,同时也保证了的你的代码是不可重用的。我最近不幸看到 Infineon为其较复杂的通信芯片写的驱动程序,它用到了bit fields因此完全对我无用,因为我的编译器用其它的方式来实现bit fields的。从道德讲:永远不要让一个非嵌入式的家伙粘实际硬件的边。
3) 用 #defines 和 bit masks 操作。这是一个有极高可移植性的方法,是应该被用到的方法。最佳的解决方案如下:
#define BIT3 (0x1 << 3)
static int a;
void set_bit3(void)
{
a |= BIT3;
}
void clear_bit3(void)
{
a &= ~BIT3;
}
一些人喜欢为设置和清除值而定义一个掩码同时定义一些说明常数,这也是可以接受的。我希望看到几个要点:说明常数、|=和&=~操作。