嵌入式混合面试题.docx
《嵌入式混合面试题.docx》由会员分享,可在线阅读,更多相关《嵌入式混合面试题.docx(35页珍藏版)》请在冰豆网上搜索。
嵌入式混合面试题
一、ANSIC/C++方面的知识
一.1、简答题。
下面的题目必须全部答对才给分(20分):
1、如何在C中初始化一个字符数组。
2、如何在C中为一个数组分配空间。
3、如何初始化一个指针数组。
4、如何定义一个有10个元素的整数型指针数组。
5、s[10]的另外一种表达方式是什么。
6、GCC3.2.2版本中支持哪几种编程语言。
7、要使用CHAR_BIT需要包含哪个头文件。
8、对(-1.2345)取整是多少?
9、如何让局部变量具有全局生命期。
10、C中的常量字符串应在何时定义?
11、如何在两个.c文件中引用对方的变量。
12、使用malloc之前需要做什么准备工作。
13、realloc函数在使用上要注意什么问题。
14、strtok函数在使用上要注意什么问题。
15、gets函数在使用上要注意什么问题。
16、C语言的词法分析在长度规则方面采用的是什么策略?
17、a+++++b所表示的是什么意思?
有什么问题?
18、如何定义Bool变量的TRUE和FALSE的值。
19、C语言的const的含义是什么。
在定义常量时,为什么推荐使用const,而不是#define。
20、C语言的volatile的含义是什么。
使用时会对编译器有什么暗示。
一.2、问答题。
1、———————————————————–
“匈牙利命名法”有什么优缺点?
(2分)
2、———————————————————–
下面x,y,*p的值是多少,有什么问题?
(2分)
intx,y,z=2;
int*p=&z;
x=sizeof*p;
y=x/*p;/*x=?
*p=?
y=?
有什么问题?
*/
3、———————————————————–
下面的语句是什么意思?
如何声明或定义才使它们更易懂?
(10分)
int(*foo())();
int(*foo())[];
int(*foo[])();
(*(void(*)())0)();
void(*signal(int,void(*)(int)))(int);
4、———————————————————–
本题(2分)。
一般使用malloc时,需要进行强制类型转换,如:
char*s;s=(char*)malloc(31);
下面中?
?
?
该如何填写,才可以正确执行强制类型转换?
int(*monthp)[31];monthp=(?
?
?
)malloc(31);
5、———————————————————–
关于C语言运算符优先级的记忆技巧是什么?
(2分)
/*下面r的值是多少*/
inthi,low,r;
hi=7;low=3;
r=hi<<4+low;
6、———————————————————–
指针和数组的区别是什么?
用一个简单的声明把它们区分开。
(2分)
指针和数组的声明在什么情况下是相同的?
(2分)
7、———————————————————–
C语言的左值(lvalue)和右值(rvalue)的含义是什么?
(2分)
8、———————————————————–
为什么C语言可以实现printf(char*format,…)这样可变参数的调用形式?
这样有什么缺点?
(2分)
9、———————————————————–
说明C语言中术语”声明”"定义”"原型”的含义?
(2分)
10、———————————————————–
举一个例子,说明使用assert和防错代码的区别。
(5分)
11、———————————————————–
对语句ifelse与操作符?
:
使用场合的比较。
(2分)
12、———————————————————–
编写一个函数,输入一个的整型数字,可以选择按照8/10/16进制输出字符串。
注意边界值。
(5分)
13、———————————————————–
本题(2分)。
下面是一个16×16的黑白图标:
staticunsignedshortstopwatch[]={
0×07c6,
0×1ff7,
0×383b,
0×600c,
0×600c,
0xc006,
0xc006,
0xdf06,
0xc106,
0xc106,
0×610c,
0×610c,
0×3838,
0×1ff0,
0×07c0,
0×0000,
};
如何修改声明,可以使之在源代码中形象地表现出图形的模样。
14、———————————————————–
说出可以使用calendar[11][30]变量的四种类型定义。
(5分)
如:
intcalendar[12][31];/*二维数组*/
15、———————————————————–
使用strcmp,当字符串相同时会返回’\0′。
但’\0′一般作为逻辑假,因此下面的语句不容易理解:
if(!
strcmp(s,“string”))returnEQUATION;
如何经过简单修改,使之更易懂?
(2分)
16、———————————————————–
编写一个自己的完全C语言版本的memset函数,并且评价这个实现的性能和可移植性。
(5分)
17、———————————————————–
在树和图这些数据结构中,通常使用指针来组织数据。
如果我们要把这些数据保存到文件中,指针是没有意义的。
我们该如何解决这个问题。
(2分)
18、———————————————————–
用2种不同的方法计算long变量的”1″bit的个数。
(2分)
19、———————————————————–
任意给出一个C的基本数据类型,如何编码判断这个数据类型是有符号还是无符号的?
(2分)
不得上机实验,写出下面代码的输出。
解释这个行为是标准定义的,还是依赖实现的。
(2分)
inti;
for(i=0;i<10;i++){
intj=i;
printf(”%d\n”,j);
}
20、———————————————————–
列出5种以上你所看过的C编程的书籍,并写简要书评。
(5分)
对C的评价。
如果要你改造一把菜刀,使之更加安全,你是否会使用这样的菜刀,为什么?
(5分)
一.3、分析题。
本题(各5分)。
假设下面代码中的变量都是合法变量,调用外部的函数都是正确的。
回答几个问题:
这些代码意图要干什么?
是否有问题?
如果有问题,该如何修改,或者如何避免类似错误发生?
如果没有问题,如果代码有输出,输出是什么?
1、———————————————————–
intisvowel(charc)
{
returnc==’a'||c==’e'||c==’i'||c==’o'||c==’u';
}
2、———————————————————–
while(c==’\t’||c=’‘||c==’\n’)
c=getc(f);
3、———————————————————–
/*当x=2,y=3,z=?
*/
if(x==0)
if(y==0)
z=-1;
else
z=x+y;
4、———————————————————–
/*处理网络事件*/
voidprocess_network_code(intx,inty)
{
/*选择modes_pointer资源*/
switch(line){
caseTHING1:
/*处理异常1#,使用老的modes_pointer资源*/
doit1();
break;
caseTHING2:
/*处理异常2#,需要重新启动服务*/
if(x==STUFF){
/*重新申请modes_pointer资源,没有初始化*/
do_first_stuff();
/*在这种条件下,有些资源不用重新申请*/
if(y==OTHER_STUFF)
break;
/*申请剩下的资源,并初始化*/
do_later_stuff();
}
/*初始化modes_pointer资源*/
initialize_modes_pointer();
break;
default:
/*处理普通事件,使用老的modes_pointer资源*/
processing();
}
/*使用modes_pointer资源,处理事件*/
use_modes_pointer();
}
5、———————————————————–
intis_gb2312_char(charc1,charc2)
{
if(c1>=0xa1&&c2>=0xa1)
return1;
else
return0;
}
6、———————————————————–
下面x,y的值是多少,有什么问题?
intx=10,y=3;
x^=y;
y^=x;
x^=y;
/*x=?
y=?
*/
7、———————————————————–
intdays[]={31,28,31,30,31,30,31,31,30,31,30,31,};
intcalendar[12][31];
int(*monthp)[31];
int*dayp;
inti;
memset(calendar,0,sizeof(calendar));
i=0;
for(monthp=calendar;monthp<&calendar[12];monthp++){
for(dayp=*monthp;dayp<&(*monthp)[31];dayp++){
if(dayp-*monthp*dayp=i++%7+1;
}
}
}
8、———————————————————–
voidprintnum(longn)
{
if(n<0){
putchar(’-');
n=-n;
}
if(n>=10){
printnum(n/10);
}
putchar(”0123456789″[n%10]);
}
9、———————————————————–
void*memchr(void*pv,unsignedcharch,size_tsize)
{
unsignedchar*pch=(unsignedchar*)pv;
unsignedchar*pchEnd=pch+size;
while(pchif(*pch==ch)
return(pch);
pch++;
}
returnNULL;
}
10、———————————————————–
void*memchr(void*pv,unsignedcharch,size_tsize)
{
unsignedchar*pch=(unsignedchar*)pv;
unsignedchar*pchPlant=pch+size;
unsignedcharchSave=*pchPlant;
*pchPlant=ch;
while(pch!
=ch){
pch++;
}
*pchPlant=chSave;
return((pch==pchPlant)?
NULL:
pch);
}
11、———————————————————–
voidUnsToStr(unsignedshortintu,char*str)
{
char*pch;
assert(u<=65535);
pch=&str[5];
*pch=‘\0′;
do{
*–pch=u%10+‘0′;
}while((u/10)>0);
strcpy(str,pch);
}
12、———————————————————–
void*memmove(void*pvTo,voidpvFrom,size_tsize)
{
char*pbTo=(char*)pvTo;
char*pbFrom=(char*)pvFrom;
((pbTotailmove:
headmove)(pbTo,pbFrom,size);
return(pvTo);
}
13、———————————————————–
void*memcpy(void*pvTo,voidpvFrom,size_tsize)
{
char*pbTo=(char*)pvTo;
char*pbFrom=(char*)pvFrom;
while(size–>0);
*pbTo++=*pbFrom++;
return(pvTo);
}
14、———————————————————–
#include
intmain(intargc,char*argv[])
{
chars[]=”0123456789″;
inti=0;
do{
printf(”%c”,i++[s]);
}while(s?
1:
printf(”\n”)-1);
return0;
}
15、———————————————————–
intfibonacci(intx)
{
if(x==1||x==2)
return1;
returnfibonacci(x-2)+fibonacci(x-1);
}
16、———————————————————–
这里有一个程序cdecl.c。
写出它的工作流程。
写出它的使用方法。
给出一个典型输入用例,记录下它的输出。
一.4、综合编程题。
要求:
1、完成需求,程序运行正确。
2、工作原理文档,使用文档完整。
3、代码规整优美。
注释得当。
4、运行速度足够快。
5、用工具分析出是哪些代码或函数造成速度瓶颈。
1、———————————————————–
编写一个排序程序。
被排序的文件有8MB大小,一行一个随机整数(ASCII格式)。
要求对这些整数进行排序,并计算平均值,打印出排序所需的时间。
(20分)
2、———————————————————–
用dummyheader技巧实现一个链表DEMO。
要求具有create,insert,delete,search功能。
编写一个应用程序,使用上面的函数。
使用dummyheader技巧有什么优点。
(20分)
3、———————————————————–
用heapsort算法实现优先队列。
要求具有create,insert,delete功能。
编写一个应用程序,使用上面的函数。
使用heapsort算法有什么优点。
(20分)
用trie(一种多叉树)实现一个字典。
要求具有create,insert,delete,search功能。
编写一个应用程序,使用上面的函数。
使用trie树有什么优点。
(20分)
二、POSIX方面的知识。
二.1、简答题。
下面的题目必须全部答对才给分:
(5分)
1、在UNIX环境中,编译流程是什么?
2、ABI,ELF的英文全称是什么
3、一般UNIX的程序有多少段,举一个实际的例子说明。
4、如何在kernel二进制代码中找一个字符串。
5、段地址F000:
FFF0转换为线形地址的值是多少(16进制表达)。
6、在一个UNIX文件系统中,文件的唯一性标志是什么?
二.2、问答题。
1、———————————————————–
写一些代码。
如何用文件实现信号灯?
要求如果程序崩溃了,这个文件也将自动被删除
。
为什么可以这样实现信号灯?
(5分)
传统的signal函数信号处理为什么是不可靠的,信号和系统调用有何关系?
(5分)
在图形库系统中往往提供timer的功能,除了使用ALARM信号外,你还可以使用什么系统调用来实现timer?
(5分)
2、———————————————————–
写一些代码,演示如何正确使用write系统调用。
注意看好手册再回答。
(2分)
如果一个文件以rw模式打开,在进行read/write操作转换时,需要进行什么操作。
(2分)
3、———————————————————–
解释终端结构termios.c_cc的MIN/TIME数值变化的带来read/write的特性。
(5分)
如何理解终端、控制终端、虚拟终端、控制台、tty等类同的概念?
(5分)
4、———————————————————–
解释计算机中Copy-On-Write的概念。
(2分)
调用fork之后,子进程没有继承父进程的属性有哪些?
(5分)
解释为什么每个程序在装入执行之后,总是已经预先打开了stdout、stdin、stderr?
(2分)
在fork之前,父进程打开了一个文件。
在fork之后,如果子进程移动了文件指针,父进程的文件指针有什么变化;如果子进程关闭了文件,父进程有什么变化?
为什么会这样?
(5分)
标准输入、输出和错误输出分别是什么类型的缓冲,这些缓冲在用户空间还是在核心空间?
怎样关闭他们的缓冲?
如果父进程关闭了缓冲,在fork之后建立的子进程是否也关闭了缓冲?
(5分)
vfork和fork相比,有什么特色?
(2分)
system函数是否等同于fork+exec?
(2分)
wait系统调用有多少种条件可以退出?
(2分)
5、———————————————————–
系统调用和库函数调用有什么区别。
(2分)
在linux2.4.x上的glibc和newlib(一种嵌入式C库)的系统调用有什么不同?
(2分)
在linux2.4.x上,对系统调用execve如果调用成功,它返回的值是多少。
(2分)
6、———————————————————–
列出你所知道的2个内存跟踪库。
(2分)
设计一个内存跟踪方案,为什么选择这个方案(5分)
二.3、综合编程题。
要求:
1、完成需求,程序运行正确。
2、工作原理文档,使用文档完整。
3、代码规整优美。
注释得当。
4、运行速度足够快。
1、———————————————————–
这里有一个8MB的文件,编写一个copy程序,拷贝这个文件,并计算所需时间。
用工具分析出是哪些代码或函数造成速度瓶颈。
提示:
如果只是使用read/write调用,不是一个好的实现。
(20分)
2、———————————————————–
Linux系统中,什么时候会出现类似Y2K的问题。
写一个程序证明。
(20分)
3、———————————————————–
编写一个程序,测试系统最小的睡眠时间间隔。
(20分)
4、———————————————————–
编写一个pipe程序,测试有N个管道,size大小的buffer情况下,pipe的传输性能是多少?
(20分)
5、———————————————————–
在ext2文件系统上,单个文件最大可以达到多少?
写一个程序获得这方面的限制。
(20分)
三、Linux编程基本使用知识。
三.1、命令和shell
1)编写一个脚本,统计一个目录下面所有C代码的行数。
(2分)
2)编写一个sed脚本,去除HTML文件中的HTML标记。
(2分)
3)编写一个脚本获得当前系统eth0的IP地址。
(2分)
4)编写一个脚本以交互的方式,进行DNS的设定。
(2分)
5)使用ls命令编写一个脚本,实现ls-R,递归列出当前目录下的所有目录、文件。
(2分)
6)———————————————————–
在一个目录下,找soft-linkfiles,用下面的命令,原理是可行的,但无法操作,
该如何解决?
要2种方法。
(2分)
ls-l|grep->
7)———————————————————–
如何把标准错误输出,重定向到标准输出上。
(2分)
8)———————————————————–
我们的系统中的软件包是使用RPM管理的。
要求下面的问题写出shell命令和运行结果。
(5分)
如何知道系统中安装了几个软件包。
如何知道系统中安装了哪几类(group)软件包。
如何知道kernel软件包的简述。
如何知道kernel软件包的Changelog。
如何知道kernel软件包有几个文件。
如何知道kernel软件包安装后有多大。
三.2、编辑工具的使用。
(各2分)
1)如何使用vi进行块拷贝、粘贴、删除的操作
2)如何设置Tab的长度,以及自动缩进的长度
3)如何使用tag进行代码阅读
4)如何在1~10行,有确认的进把所有的RedHat改为RedFlag
5)在SourceNavigator中,如何跳到一个变量的声明处?
如何得知光标当前的位置在那个函数体内?
三.3、编译器与调试器。
(各2分)
1)如何使用gcc得到宏展开的中间代码
2)如何通过gcc在命令行中传入宏定义
3)在那一级优化的情况下,内联函数才真正的内联到代码中
4)gdb的watch命令如何使用,有何缺点
5)gdb中使用什么命令可以显式调用的栈帧,如何查看某个栈帧上的局部变量
6)如何使用gdb调试多进程
7)如何使能/禁止coredump?
三.4、库。
(各2分)
1)如何知道XSetIMValues这个符号在那个X的库文件中
2)如何读取C++的符号名,更具可读性
3)请解释动态库的soname概念
4)解释在链接时rpath选项的含义
三.5、Makefile。
(10分)
如果有一个简单的Test项目目录如下:
#treeTest
Test
|–common.h
|–main.cpp
|–test.cpp
`–test.h
1)使用wildcard、patsubst函数编写一个C++项目的Makefile文件
2)使用automake、autoconfig编写一个支持configure选项的configure.in脚本
三.6、CVS。
(10分)
1)如果一个CVS项目中,甲添加了一个子目录模块,那么乙在update时是否会自动检出这个新添加的子模块?
如果不能,那么你有什么好的解决方案?
2)如何在一个CVS项目中添加一个二进制文件,这个二进制文件可以进行增量的版本管理吗?
3)如何检出标记(tag)为milestone-1的版本,如何创建以milestone-1为基础的分支milestone-1-b1,并如何把分支的修改合并到milestone-1的主分支上
三.7、Linux/GNU编程基本知识
1、———————————————————–
Linux2.4.x有多少种类型的设备文件?
分别写出来。
(2分)
2、———————————————————–
glibc动态库的搜寻次序是什么?
(2分)
glibc2.1.x与2.2.x的动态库的搜寻次序有什么不同?
为什么会采用现在的方案?
(2分)
三.3、综合编程题。
要求:
1、完成需求,程序运行正确。
2、工作