ImageVerifierCode 换一换
格式:DOCX , 页数:18 ,大小:82KB ,
资源ID:4449964      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/4449964.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(考查嵌入式C开发人员的最好的0x10道题.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

考查嵌入式C开发人员的最好的0x10道题.docx

1、考查嵌入式C开发人员的最好的0x10道题考查嵌入式C开发人员的最好的0x10道题考查一个初级嵌入式系统开发人员的C基本功,附有答案题目由资深嵌入式系统专家拟定,目的是考查入门级的嵌入式软件开发人员 Gavin Shaw提供详细解答编者按:非常基本关于C语言的问题,一个信息类(计算机,资讯工程,电子工程, 通信工程)专业的本科毕业生应该达到的水平。题目不难,全部都能快速地答完,当然也需要一定的知识储备。对于大多数人,我们预期你可能答错 3) 4) 15)题,所以答错3道以内的,我们认为你很棒答错5道题以内,我们认为你还不错(你还可能答错第9题)如果你有6道以上的题目不能答对,基本上我们都不好说什

2、么了.约定: 1) 下面的测试题中,认为所有必须的头文件都已经正确的包含了 2)数据类型 char 一个字节 1 byte int 两个字节 2 byte (16位系统,认为整型是2个字节) long int 四个字节 4 byte float 四个字节4 byet double 八个字节 8 byte long double 十个字节 10 byte pointer 两个字节 2 byte(注意,16位系统,地址总线只有16位)第1题: 考查对volatile关键字的认识#includestatic jmp_buf buf;main() volatile int b; b =3; if(se

3、tjmp(buf)!=0) printf(%d , b); exit(0); b=5; longjmp(buf , 1); 请问,这段程序的输出是(a) 3(b) 5(c) 0(d) 以上均不是第2题:考查类型转换main() struct node int a; int b; int c; ; struct node s= 3, 5,6 ; struct node *pt = &s; printf(%d , *(int*)pt); 这段程序的输出是:(a) 3(b) 5(c) 6(d) 7第3题:考查递归调用 int foo ( int x , int n) int val; val =1;

4、 if (n0) if (n%2 = 1) val = val *x; val = val * foo(x*x , n/2); return val; 这段代码对x和n完成什么样的功能(操作)?(a) xn (x的n次幂)(b) x*n(x与n的乘积)(c) nx(n的x次幂)(d) 以上均不是第4题:考查指针,这道题只适合于那些特别细心且对指针和数组有深入理解的人main() int a5 = 1,2,3,4,5; int *ptr = (int*)(&a+1); printf(%d %d , *(a+1), *(ptr-1) ); 这段程序的输出是:(a) 2 2(b) 2 1(c) 2

5、5(d) 以上均不是第5题:考查多维数组与指针void foo(int 3 ); main() int a 33= 1,2,3 , 4,5,6,7,8,9; foo(a); printf(%d , a21);void foo( int b3) + b; b11 =9; 这段程序的输出是:(a) 8(b) 9(c) 7(d)以上均不对第6题目:考查逗号表达式main() int a, b,c, d; a=3; b=5; c=a,b; d=(a,b); printf(c=%d ,c); printf(d=%d ,d);这段程序的输出是:(a) c=3 d=3(b) c=5 d=3(c) c=3 d

6、=5(d) c=5 d=5第7题:考查指针数组main() int a3 = 1,2,3 ,4,5,6; int (*ptr)3 =a; printf(%d %d ,(*ptr)1, (*ptr)2 ); +ptr; printf(%d %d ,(*ptr)1, (*ptr)2 );这段程序的输出是:(a) 2 3 5 6(b) 2 3 4 5(c) 4 5 0 0(d) 以上均不对第8题:考查函数指针int *f1(void) int x =10; return(&x);int *f2(void) int*ptr; *ptr =10; return ptr;int *f3(void) int

7、 *ptr; ptr=(int*) malloc(sizeof(int); return ptr;上面这3个函数哪一个最可能引起指针方面的问题(a) 只有 f3(b) 只有f1 and f3(c) 只有f1 and f2(d) f1 , f2 ,f3第9题:考查自加操作(+)main() int i=3; int j; j = sizeof(+i+ +i); printf(i=%d j=%d, i ,j);这段程序的输出是:(a) i=4 j=2(b) i=3 j=2(c) i=3 j=4(d) i=3 j=6第10题:考查形式参数,实际参数,指针和数组void f1(int *, int);

8、 void f2(int *, int); void(*p2) ( int *, int);main() int a; int b; p0 = f1; p1 = f2; a=3; b=5; p0(&a , b); printf(%dt %dt , a ,b); p1(&a , b); printf(%dt %dt , a ,b);void f1( int* p , int q) int tmp; tmp =*p; *p = q; q= tmp;void f2( int* p , int q) int tmp; tmp =*p; *p = q; q= tmp; 这段程序的输出是:(a) 5 5

9、5 5(b) 3 5 3 5(c) 5 3 5 3(d) 3 3 3 3第11题:考查自减操作(-)void e(int ); main() int a; a=3; e(a);void e(int n) if(n0) e(-n); printf(%d , n); e(-n); 这段程序的输出是:(a) 0 1 2 0(b) 0 1 2 1(c) 1 2 0 1(d) 0 2 1 1第12题:考查typedef类型定义,函数指针typedef int (*test) ( float * , float*)test tmp;tmp 的类型是(a) 函数的指针,该函数以 两个指向浮点数(float)

10、的指针(pointer)作为参数(arguments) Pointer to function of having two arguments that is pointer to float(b) 整型(c) 函数的指针,该函数以 两个指向浮点数(float)的指针(pointer)作为参数(arguments),并且函数的返回值类型是整型 Pointer to function having two argument that is pointer to float and return int(d) 以上都不是第13题:数组与指针的区别与联系main() char p; char buf

11、10 = 1,2,3,4,5,6,9,8; p = (buf+1)5; printf(%d , p);这段程序的输出是:(a) 5(b) 6(c) 9(d) 以上都不对第14题: 考查指针数组的指针Void f(char*);main() char * argv = ab ,cd , ef ,gh, ij ,kl ; f( argv );void f( char *p ) char* t; t= (p+= sizeof(int)-1; printf( %s , t);这段程序的输出是:(a) ab(b) cd(c) ef(d) gh第15题:此题考查的是C的变长参数,就像标准函数库里print

12、f()那样,这个话题一般国内大学课堂是不会讲到的,不会也情有可原呵呵,#includeint ripple ( int , .);main() int num; num = ripple ( 3, 5,7); printf( %d , num);int ripple (int n, .) int i , j; int k; va_list p; k= 0; j = 1; va_start( p , n); for (; jn; +j) i = va_arg( p , int); for (; i; i &=i-1 ) +k; return k;这段程序的输出是:(a) 7(b) 6(c) 5(

13、d) 3第16题:考查静态变量的知识int counter (int i) static int count =0; count = count +i; return (count );main() int i , j; for (i=0; i 0) if (n%2 = 1) product = product*val; /*如果是奇数次幂, x(val) 要先乘上一次,; 偶数次幂,最后返回时才会到这里 乘以1*/ val = val* val; n = n/2; return product;/* 用二元复乘策略 */算法描述(while n0) if next most signific

14、ant binary digit of n( power) is one then multiply accumulated product by current val , reduce n(power) sequence by a factor of two using integer division . get next val by multiply current value of itself 第4题: (c)a的类型是一个整型数组,它有5个成员&a的类型是一个整型数组的指针所以&a + 1指向的地方等同于 a6所以*(a+1) 等同于a1ptr等同 a6, ptr-1就等同与a

15、5第5题: (b)题目自身就给了足够的提示b00 = 4b10 = 7第6题: (c)考查逗号表达式,逗号表达式的优先级是很低的,比 赋值(=)的优先级 低. 逗号表达式的值就是最后一个元素的值逗号表达式的还有一个作用就是分割函数的参数列表.E1, E2, ., En上面这个表示式的左右是,E1, E2,. En的值被分别计算出来,En计算出来的结构赋给整个逗号表达式 c=a,b; / *yields c=a* /d=(a,b); /* d =b */第7题: (a)ptr是一个数组的指针,该数组有3个int成员第8题: (c)f1显然有问题,它返回一个局部变量的指针,局部变量是保存在stac

16、k中的,退出函数后,局部变量就销毁了,保留其指针没有意义,因为其指向的stack空间可能被其他变量覆盖了f2也有问题, ptr是局部变量,未初始化,它的值是未知的,*ptr不知道指向哪里了,直接给*ptr赋值可能会覆盖重要的系统变量,这就是通常说的野指针的一种第9题: (b)sizeof 操作符给出其操作数需要占用的空间大小,它是在编译时就可确定的,所以其操作数即使是一个表达式,也不需要在运行时进行计算.( +i + + i )是不会执行的,所以i 的值还是3第10题: (a)很显然选a.f1交换*p 和 q的值,f1执行完后, *p 和 q的值的确交换了, 但 q的改变不会影响到 b的改变,

17、 *p 实际上就是 a 所以执行f1后, a=b=5这道题考查的知识范围很广,包括typedef自定义类型,函数指针,指针数组void(*p 2 ) ( int *, int);定义了一个函数指针的数组p,p有两个指针元素. 元素是函数的指针,函数指针指向的函数是一个带2个参数,返回void的函数,所带的两个参数是 指向整型的指针,和整型p 0 = f1; p 1 = f2 contain address of function .function name without parenthesis represent address of function Value and address

18、of variable is passed to function only argument that is effected is a (address is passed). Because of call by value f1, f2 can not effect b第11题: (a)考查-操作和递归调用,仔细分析一下就可以了第12题: (c)分析函数声明,建议不会的看看C专家编程这里介绍一个简单规则:从左往右,遇到括号停下来,将第一个括号里的东西看成一个整体 第13题: (c)考查什么时候数组就是指针.对某些类型T而言,如果一个表达式是 T (T的数组), 这个表达式的值实际上就是

19、指向该数组的第一个元素的指针.所以(buf+1)5实际上就是*(buf +6)或者buf6第14题: (b)sizeof(int)的值是2,所以p+=sizeof(int) 指向 argv2,这点估计大家都没有什么疑问(p+=sizeof(int)-1 指向 argv1,能理解吗,因为(p+=sizeof(int)-1 就相当于 (p+=2)-1 ,也就是(p+2-1)第15题: (c)在C编译器通常提供了一系列处理可变参数的宏,以屏蔽不同的硬件平台造成的差异,增加程序的可移植性。这些宏包括va_start、 va_arg和va_end等。 采用ANSI标准形式时,参数个数可变的函数的原型声明

20、是: type funcname(type para1, type para2, .) 这种形式至少需要一个普通的形式参数,后面的省略号不表示省略,而是函数原型的一部分。type是函数返回值和形式参数的类型。不同的编译器,对这个可变长参数的实现不一样 ,gcc4.x中是内置函数.关于可变长参数,可参阅 程序分析va_list p; /*定义一个变量 ,保存 函数参数列表 的指针*/va_start( p , n); /*用va_start宏 初始化 变量p, va_start宏的第2个参数n , 是一个固定的参数, 必须是我们自己定义的变长函数的最后一个入栈的参数 也就是调用的时候参数列表里的

21、第1个参数*/for (; jn; +j) /* j从1开始, 遍历所有可变参数 */ i = va_arg( p , int); /*va_arg取出当前的参数, 并认为取出的参数是一个整数(int) */ for (; i; i &=i-1 ) /*判断取出的i是否为0*/ +k; /* 如果i不为0, k自加, i与i-1进行与逻辑运算, 直到i 为0 这是一个技巧,下面会谈到它的功能*/当我们调用ripple函数时,传递给ripple函数的 参数列表的第一个参数n的值是3 .va_start 初始化 p士气指向第一个未命名的参数(n是有名字的参数) ,也就是 is 5 (第一个).每次

22、对 va_arg的调用,都将返回一个参数,并且把 p 指向下一个参数.va_arg 用一个类型名来决定返回的参数是何种类型,以及在 var_arg的内部实现中决定移动多大的距离才到达下一个 参数(; i; i&=i-1) k+ /* 计算i有多少bit被置1 */5用二进制表示是 (101) 27用二进制表示 (111) 3所以 k 返回 5(2+3),也即本题应该选c举个例子,就很好理解了令 i= 9 = 1001 i-1 = 1000 (i-1) +1 = i 1000 +1 1 001因为i与i-1的最右边的那位(最低位) 肯定是不同,如果i1,i-1肯定是0,反之亦然. i & i-1

23、 这个运算,在二相补的数字系统中,将会 消除最右边的1位第16题: (b)答案是(b)相传高斯小学一年级的时候就会做这类等比数列的题目了.这道题考查的是静态变量的知识,当每次调用完函数之后,静态变量的值不会丢失,这与栈中的临时局部变量明显不同的地方.所以,第一次调用counter(0)之后,count =0第二次调用counter(1)后 count = 0+1;第三次调用counter(2) count = 1+2; /* count = count +i */第四次调用counter(3) count = 3+3;第五次调用counter(4) count = 6+4;第六次调用count

24、er(5) count = 10+5;命题人信息 Ashok K. Pathak a member ( Research Staff ) at Bharat Electronics Limited (CRL) , Ghaziabad. He has been developing embedded application for the past five years .Ashok holds a M.E in computer science and engineering . Ashok recently completed a book about Advanced Test in C and Embedded System Programming , Published by BPB

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1