嵌入式软件工程师面试(2)

1、

int main(void)
{
   unsigned int a = 6;
   int b = -20;
   char c;
   (a+b>6)?(c=1):(c=0);
}

则c=1,但a+b=-14;如果a为int类型则c=0。

原来有符号数和无符号数进行比较运算时(==,<,>,<=,>=),有符号数隐式转换成了无符号数(即底层的补码不变,但是此数从有符号数变成了无符号数),比如上面 (a+b)>6这个比较运算,a+b=-14,-14的补码为1111111111110010。此数进行比较运算时,
 被当成了无符号数,它远远大于6,所以得到上述结果。


2、给定一个整型变量a,写两段代码,第一个设置a的bit3,第二个清除a的bit,在以上两个操作中, 要保持其它位不变。

#define BIT3 (0x1<<3)

static int a;
void set_bit3(void)
{
  a |= BIT3;
}

void clear_bit3(void)
{
   a &= ~BIT3;
}

3、要求设置一绝对地址为0x67a9的整型变量的值为0xaa66。

unsigned int *ptr;
ptr = (unsigned int *)0x67a9;
*ptr = 0xaa66;

4、中断是嵌入式系统中重要的组成部分,这导致了很多编译开发商提供一种扩展—让标准C支持中断。 具代表性的是,产生了一个新的关键字__interrupt。下面的代码就使用了__interrupt关键字去定义了一个中断服务子程序(ISR),请评论一下这段代。

__interrupt void compute_area (void) 
 { 
   double area = PI * radius * radius; 
   printf(" Area = %f", area); 
   return area; 
 } 
  • ISR不可能有参数和返回值的!
  •  ISR尽量不要使用浮点数处理程序,浮点数的处理程序一般来说是不可重入的,而且是消耗大量CPU时间的!!
  •  printf函数一般也是不可重入的,UART属于低速设备,printf函数同样面临大量消耗CPU时间的问题!

5、评价下面的代码片断:

unsigned int zero = 0;
unsigned int compzero = 0xFFFF;
/*1's complement of zero */

对于一个int型不是16位的处理器为说,上面的代码是不正确的。应编写如下:

unsigned int compzero = ~0;

6、解析下面代码

main()
{
    char *ptr;
   if ((ptr = (char *)malloc(0)) == NULL)
       puts("Got a null pointer");
    else
       puts("Got a valid pointer");
}

 该代码的输出是“Got a valid pointer”。

将代码改为:

char *ptr;
if(int pp = (strlen(ptr=(char *)malloc(0))) == 0)
    puts("Got a null pointer");
else
    puts("Got a valid pointer");

或者:

char *ptr;
if(int pp = (sizeof(ptr=(char *)malloc(0))) == 4)
    puts("Got a null pointer");
else
    puts("Got a valid pointer");

如果求ptr的strlen的值和sizeof的值,该代码的输出是"Got a null pointer"。

注意:此时malloc(0)返回了一个可用于free()释放的唯一指针(非NULL),而且将它传给strlen(),返回值为0,这样看来,它用'\0'进行填充的(即内容是NULL而非指针指向NULL)。


7、Typedef 在C语言中频繁用以声明一个已经存在的数据类型的同义字。也可以用预处理器做类似的事。例如,思考一下下面的例子:

#define dPS struct s *
typedef struct s * tPS;

以上两种情况的意图都是要定义dPS 和 tPS 作为一个指向结构s指针。哪种方法更好呢?(如果有的话)为什么?

这是一个非常微妙的问题,任何人答对这个问题(正当的原因)是应当被恭喜的。答案是:typedef更好。思考下面的例子:

  dPS p1,p2;
  tPS p3,p4;

  第一个扩展为:
  struct s * p1, p2;
  上面的代码定义p1为一个指向结构的指,p2为一个实际的结构,这也许不是你想要的。第二个例子正确地定义了p3 和p4 两个指针。
 


8、

int a = 5, b = 7, c;
c = a+++b;

c=12,由贪心法此式子可以解析成a++ + b,由于++在a的后面,先计算后再执行自加。


9、

int main()
{
   int j=2;
   int i=1;
   if(i = 1) j=3;
   if(i = 2) j=5;
   printf("%d",j);
} 

 输出为5,注意看清楚题目。


10、宏定义是在预编译阶段被处理的。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值