嵌入式linux面试题

基础试题(C语言) 

一、ANSI C/C++方面的知识 
一.1、简答题。下面的题目必须全部答对才给分(20分): 
1、 如何在C中初始化一个字符数组。 
       char s[100]={' '};
2、 如何在C中为一个数组分配空间。 
       char s[10];
        s=malloc(10*sizeof(char));
3、 如何初始化一个指针数组。
       int *pt[10]={NULL}; 
4、 如何定义一个有10个元素的整数型指针数组。 
      int *pt[10]={NULL}; 
5、 s[10]的另外一种表达方式是什么。 
       *(s+10);
6、 GCC3.2.2版本中支持哪几种编程语言。

C,C++,java,ada,fortran


7、 要使用CHAR_BIT需要包含哪个头文件。
#include 
#define CHAR_BIT 8
Description

CHAR_BIT is the number of bits for smallest object that is not a bit-field (byte).

Portability

CHAR_BIT conforms to ISO/IEC 9899:1990 (C90) and ISO/IEC 9899:1999 (C99).

一般计算机都把1字节定义为8位,但在有些老式的机器上有7位或者9位的情况,所以在编码的时候通常为了兼容性,把1字节的位数不直接用8而且是用CHAR_BIT宏定义来表示。


8、 对(-1.2345)取整是多少?
C语言有以下几种取整方法: 
1、直接赋值给整数变量。如: 
int i = 2.5; 或 i = (int) 2.5; 
这种方法采用的是舍去小数部分,可以用于你的问题。 
2、C/C 中的整数除法运算符“/”本身就有取整功能(int / int),而下面介绍的取整函数返回值是double。整数除法对正数的取整是舍去小数部分,可以用于你的问题。但是整数除法对负数的取整结果和使用的C编译器有关。 
3、使用floor函数。floor(x)返回的是小于或等于x的最大整数。如: 
floor(2.5) = 2 
floor(-2.5) = -3 
4、使用ceil函数。ceil(x)返回的是大于x的最小整数。如: 
ceil(2.5) = 3 
ceil(-2.5) = -2 
floor()是向负无穷大舍入,floor(-2.5) = -3;ceil()是向正无穷大舍入,ceil(-2.5) = -2。floor函数可以用于你的问题。 

9、 如何让局部变量具有全局生命期。 
    在变量前加static关键词
10、C中的常量字符串应在何时定义? 
      在不允许程序改变字符串内容时。
11、如何在两个.c文件中引用对方的变量。 
       使用extern声明变量。
12、使用malloc之前需要做什么准备工作。 
     定义一个指针指向所分配的空间。
13、realloc函数在使用上要注意什么问题。
extern void *realloc(void *mem_address, unsigned int newsize);
功能:先按照newsize指定的大小分配空间,将原有数据从头到尾拷贝到新分配的内存区域,而后释放原来mem_address所指内存区域,同时返回新分配的内存区域的首地址。即重新分配存储器块的地址。

14、strtok函数在使用上要注意什么问题。
char *strtok(char *s, const char *delim);
strtok()用来将字符串分割成一个个片段。参数s指向欲分割的字符串,参数delim则为分割字符串,当strtok()在参数s的字符串中发现到参数delim的分割字符时则会将该字符改为\0 字符。在第一次调用时,strtok()必需给予参数s字符串,往后的调用则将参数s设置成NULL。每次调用成功则返回被分割出片段的指针。

15、gets函数在使用上要注意什么问题。
注意:本函数可以无限读取,不会判断上限,所以程序员应该确保buffer的空间足够大,以便在执行读操作时不发生溢出。如果溢出,多出来的字符将被写入到堆栈中,这就覆盖了堆栈原先的内容,破坏一个或多个不相关变量的值,为了避免这种情况,我们可以用gets_s()来替换gets()。这个事实导致gets函数只适用于玩具程序。

16、C语言的词法分析在长度规则方面采用的是什么策略?
?? 

17、a+++++b所表示的是什么意思?有什么问题?
编译时会出现问题,显示无效的增量值,编译器无法判断++的顺序,可以改成(a++)+(++b);
等价于
++b;
temp = a+b;
a++;


18、如何定义Bool变量的TRUE和FALSE的值。
bool a;
a=1;
a=0;
或者
a=true;
a=false;
bool 变量不支持加减运算。
19、C语言的const的含义是什么。在定义常量时,为什么推荐使用const,而不是#define。
const可以进行类型检查,#define只是单纯替换,在上下文语境不同的时候可能会有歧义,使用const更加安全。
 
20、C语言的volatile的含义是什么。使用时会对编译器有什么暗示。 
表明变量是易变的,编译器不可对其进行优化,每次读取变量时都要从存放他的地址读取,而不是读取它保存在栈中的值
一.2、问答题。 
1、----------------------------------------------------------- 

"匈牙利命名法"有什么优缺点?(2分) 
匈牙利命名法是一种编程时的命名规范。基本原则是:变量名=属性+类型+对象描述,其中每一对象的名称都要求有明确含义,可以取对象名字全称或名字的一部分。命名要基于容易记忆容易理解的原则。保证名字的连贯性是非常重要的。
 
 
2、----------------------------------------------------------- 

下面x, y, *p的值是多少,有什么问题?(2分) 
int x, y, z = 2; 
int *p=&z;      //正确
x=sizeof*p;    //正确
y=x/*p;             //(*p),一定要加括号
 /* x=?, *p=?, y=?, 有什么问题?*/
//sizeof(类型说明符, 数组 名或表达式); 或 sizeof 变量名
*p=2,x=4,y=2;

3、----------------------------------------------------------- 

下面的语句是什么意思?如何声明或定义才使它们更易懂?(10分) 
int (*foo())(); //声明一个函数foo,他的返回值为一个int(*)()函数指针
int (*foo())[]; //声明一个foo函数,其返回值类型为int(*)[];指向二维数组的某一列。
int (*foo[])();  //foo 是一个指针数组,其元素指向int (void)的函数。       
 //    typedef int(*F)();    F foo();
int (*foo())()  
foo是一个函数,返回值是一个函数指针 int(*)() 
int (*foo[])() 
foo数组,元素类型是函数指针 int(*)()
int (*foo())() ---> 参数为空的foo函数返回类型是一个指向参数为空返回值类型为int的函数指针 
int (*foo[])() ---> foo数组元素的类型是一个指向参数为空返回值类型为int的函数指针
 
http://www.cppblog.com/luliang/archive/2008/09/15/61863.html?opt=admin
4、----------------------------------------------------------- 

本题(2分)。一般使用malloc时,需要进行强制类型转换,如: 
char *s; s = (char *)malloc(31); 
下面中???该如何填写,才可以正确执行强制类型转换? 
int (*monthp)[31]; monthp = (int (*)[31])malloc(31); 
指向一个含有31个元素的数组,可以是一维的也可以是二维的。注意一维数组和二维数组赋地址的区别即可。
5、----------------------------------------------------------- 

关于C语言运算符优先级的记忆技巧是什么?(2分) 
/* 下面r的值是多少 */ 
int hi, low, r; 
hi=7;low=3; 
r=hi<<4+low;       //hi<<(4+low)
1)先(括号)内层,后(括号)外层。
解释:有扩号时,最内层的括号中的东西先算,再一层层向外。

(2)先函数,后运算。
解释:式中有函数,例如sqrt(),fabs(),sin()之类,先算函数。

(3)先算术,后关系,再逻辑。
解释:逻辑表达式中,混有算术运算,要先算算术(加减乘除,函数)运算,再算关系(大小,等不等)运算。最后算逻辑(或与非),得到真假。 

(4)先乘除,后加减。
解释:同算术一样,先做乘除,后做加减。
逻辑运算符“与”又叫逻辑乘,逻辑运算符“或”,又叫逻辑加,按先乘除,后加减,“与”比“或”优先。

(5)先左,后右
解释:同级运算,先做左边的,后做右边的。

(6)搞不清,加括号。
解释:自己写算术表达式和逻辑表达式时,搞不清运算符优先级,可以加括号,括号里的总是先。

6、----------------------------------------------------------- 

指针和数组的区别是什么?用一个简单的声明把它们区分开。(2分)
在两种情况下指针与数组名是不同的:1.sizeof  2.&

 数组要么在静态存储区被创建(如全局数组),要么在栈上被创建。数组名对应着(而不是指向)一块内存,其地址与容量在生命期内保持不变,只有数组的内容可以改变。

指针可以随时指向任意类型的内存块,它的特征是“可变”,所以我们常用指针来操作动态内存。指针远比数组灵活,但也更危险。


指针和数组的声明在什么情况下是相同的?(2分) 
声明为  char a[]="Hello"; char * const p=a; 时等价,即指针为常亮。
7、----------------------------------------------------------- 

C语言的左值(lvalue)和右值(rvalue)的含义是什么?(2分)
左值就是在赋值中可以放在赋值操作符两边的值
右值则是只可以放在赋值操作符右边的值
 
8、----------------------------------------------------------- 

为什么C语言可以实现printf(char *format, ...)这样可变参数的调用形式?这样有什 

么缺点?(2分) 
因为c由相应的机制支持可变参数,可以通过list_va类函数实现操作。
9、----------------------------------------------------------- 

说明C语言中术语"声明""定义""原型"的含义?(2分) 
声明说明这个变量已经存在
定义则产生新的变量
10、----------------------------------------------------------- 

举一个例子,说明使用assert和防错代码的区别。(5分) 
assert(a=b);若赋值失败就直接退出程序。
11、----------------------------------------------------------- 

对语句 if else 与操作符 ? : 使用场合的比较。(2分) 
if else 实现的逻辑更加复杂,?:更适合简单逻辑,否则代码可读性会降低。
12、----------------------------------------------------------- 

编写一个函数,输入一个的整型数字,可以选择按照8/10/16进制输出字符串。 
注意边界值。(5分) 
int main(int argc, char *argv[])
{
      char *s=(argv+1);
      char *p= (argv+2);
      int a,len;
      len=sizeof(*s);
     for(int i=0;i
    {
         a=a+(*(s+i)-'0')*10^i;
    }
      switch(*p)
      {
           case '8' :
              {
                    printf("%o",a);
              }
             
             case '10' :
              {
                    printf("%d",a);
              }
              
               case '16' :
              {
                    printf("%0x\n",a);
              }
      }
return 0;
}

13、----------------------------------------------------------- 

本题(2分)。下面是一个16x16的黑白图标: 
static unsigned short stopwatch[] = { 
0x07c6, 
0x1ff7, 
0x383b, 
0x600c, 
0x600c, 
0xc006, 
0xc006, 
0xdf06, 
0xc106, 
0xc106, 
0x610c, 
0x610c, 
0x3838, 
0x1ff0, 
0x07c0, 
0x0000, 
}; 
如何修改声明,可以使之在源代码中形象地表现出图形的模样。 
???
14、----------------------------------------------------------- 
说出可以使用calendar[11][30]变量的四种类型定义。(5分) 
如:int calendar[12][31]; /* 二维数组 */ 
       char*  calendar[12][31];
       int (* calendar[12][31])();
      
15、----------------------------------------------------------- 
使用strcmp,当字符串相同时会返回'\0'。但'\0'一般作为逻辑假, 
因此下面的语句不容易理解: 
if (!strcmp(s, "string")) return EQUATION; 
如何经过简单修改,使之更易懂?(2分) 
#define eq(a, b)  !strcmp(a, b);
if (eq(s, "string")) return EQUATION; 
16、----------------------------------------------------------- 
编写一个自己的完全C语言版本的memset函数,并且评价这个实现的性能和可移植性。(5 分) 
void mymemset( char *s, const char  a, const int len)
{
   if(s==null) return;
    for(int i=0;i
   {
      *s=a;
       ++s;
   }
   return;
}
17、----------------------------------------------------------- 
在树和图这些数据结构中,通常使用指针来组织数据。如果我们要把这些数据保存到文件 
中,指针是没有意义的。我们该如何解决这个问题。(2分) 
采用linux目录树的方式存储数据,通过某些特殊符号来表明其层次关系。
18、----------------------------------------------------------- 
用2种不同的方法计算long变量的"1"bit的个数。(2分) 
sizeof(long)*8;

19、----------------------------------------------------------- 
任意给出一个C的基本数据类型,如何编码判断这个数据类型是有符号还是无符号的?(2 分)
a=~(0);
if(a>0) printf("unsigned\n");
else printf("signed");
不得上机实验,写出下面代码的输出。解释这个行为是标准定义的,还是依赖实现的。( 

2分) 
int i; 
for (i = 0; i < 10; i++) { 
int j = i; 
printf ("%d\n", j); 

0,1,2,3,4,5,6,7,8,9
20、----------------------------------------------------------- 
列出5种以上你所看过的C编程的书籍,并写简要书评。(5分) 
对C的评价。如果要你改造一把菜刀,使之更加安全,你是否会使用这样的菜刀,为什么 ?(5分) 
<> <> <> < 一.3、分析题。 
本题(各5分)。假设下面代码中的变量都是合法变量,调用外部的函数都是正确的。回答 

几个问题: 
这些代码意图要干什么? 
是否有问题? 
如果有问题,该如何修改,或者如何避免类似错误发生? 
如果没有问题,如果代码有输出,输出是什么? 
1、----------------------------------------------------------- 

int isvowel (char c) 

return c=='a'||c=='e'||c=='i'||c=='o'||c=='u'; 

判断字符是不是a,e,i,o,u即元音字母,这样写没有问题,但是存在安全隐患,即当被比较对象不是char类型也可能返回正确答案,所以改为 return ‘a’==c||'e'==c||'i'==c||'o'==c||'u'==c; 更为安全。
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; 
Z保持原值。
4、----------------------------------------------------------- 

/* 处理网络事件 */ 
void process_network_code(int x, int y) 

/* 选择modes_pointer资源 */ 
switch (line) { 
case THING1: 
/* 处理异常1#, 使用老的modes_pointer资源 */ 
doit1(); 
break; 
case THING2: 
/* 处理异常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、----------------------------------------------------------- 

int is_gb2312_char(char c1, char c2) 

if (c1 >= 0xa1 && c2 >= 0xa1) 
return 1; 
else 
return 0; 


6、----------------------------------------------------------- 

下面x, y的值是多少,有什么问题? 
int x = 10, y = 3; 
x ^= y; 
y ^= x; 
x ^= y; 
/* x=3, y = 10 */ 

7、----------------------------------------------------------- 

int days[]={31,28,31,30,31,30,31,31,30,31,30,31,}; 
int calendar[12][31]; 
int (*monthp)[31]; 
int *dayp; 
int i; 

memset(calendar, 0, sizeof(calendar)); 
i = 0; 
for (monthp = calendar; monthp < &calendar[12]; monthp++) { 
for (dayp = *monthp; dayp < &(*monthp)[31]; dayp++) { 
if (dayp - *monthp < days[calendar - monthp]) { 
*dayp = i++ % 7 + 1; 




8、----------------------------------------------------------- 

void printnum(long n) 

if (n < 0) { 
putchar('-'); 
n = -n; 


if (n >= 10) { 
printnum(n/10); 


putchar ("0123456789"[n%10]); 


9、----------------------------------------------------------- 

void * memchr(void *pv, unsigned char ch, size_t size) 

unsigned char *pch = (unsigned char *) pv; 
unsigned char *pchEnd = pch + size; 

while (pch < pchEnd) { 
if (*pch == ch) 
return (pch); 
pch++; 


return NULL; 


10、----------------------------------------------------------- 

void * memchr(void *pv, unsigned char ch, size_t size) 

unsigned char *pch = (unsigned char *) pv; 
unsigned char *pchPlant = pch + size; 
unsigned char chSave = *pchPlant; 

*pchPlant = ch; 
while (pch != ch) { 
pch++; 

*pchPlant = chSave; 

return ((pch == pchPlant) ? NULL : pch); 


11、----------------------------------------------------------- 

void UnsToStr(unsigned short int u, 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, void pvFrom, size_t size) 

char *pbTo = (char *)pvTo; 
char *pbFrom = (char *)pvFrom; 

((pbTo < pbFrom) ? tailmove : headmove) (pbTo, pbFrom, size); 
return (pvTo); 


13、----------------------------------------------------------- 

void *memcpy(void *pvTo, void pvFrom, size_t size) 

char *pbTo = (char *)pvTo; 
char *pbFrom = (char *)pvFrom; 

while (size-- > 0); 
*pbTo++ = *pbFrom++; 
return (pvTo); 


14、----------------------------------------------------------- 

#include  

int main(int argc, char *argv[]) 

char s[]="0123456789"; 
int i = 0; 

do { 
printf ("%c", i++[s]); 
} while(s?1:printf("\n")-1); 

return 0; 


15、----------------------------------------------------------- 

int fibonacci(int x) 

if (x == 1 || x == 2) 
return 1; 
return fibonacci(x - 2) + fibonacci(x - 1); 


16、----------------------------------------------------------- 

这里有一个程序cdecl.c。写出它的工作流程。写出它的使用方法。 
给出一个典型输入用例,记录下它的输出。 

一.4、综合编程题。 
要求: 
1、完成需求,程序运行正确。 
2、工作原理文档,使用文档完整。 
3、代码规整优美。注释得当。 
4、运行速度足够快。 
5、用工具分析出是哪些代码或函数造成速度瓶颈。 

1、----------------------------------------------------------- 
编写一个排序程序。被排序的文件有8MB大小,一行一个随机整数(ASCII格式)。要求对 

这些整数进行 
排序,并计算平均值,打印出排序所需的时间。(20分) 

2、----------------------------------------------------------- 
用dummy header技巧实现一个链表DEMO。要求具有create, insert, delete, search功 

能。 
编写一个应用程序,使用上面的函数。使用dummy header技巧有什么优点。(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-link files,用下面的命令,原理是可行的,但无法操作, 
该如何解决?要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)如何使能/禁止core dump? 

三.4、库。(各2分) 
1)如何知道XSetIMValues这个符号在那个X的库文件中 
2)如何读取C++的符号名,更具可读性 
3)请解释动态库的soname概念 
4)解释在链接时rpath选项的含义 

三.5、Makefile。(10分) 
如果有一个简单的Test项目目录如下: 
# tree Test 
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分) 
glibc 2.1.x 与 2.2.x的动态库的搜寻次序有什么不同?为什么会采用现在的方案?(2 

分) 


三.3、综合编程题。 
要求: 
1、完成需求,程序运行正确。 
2、工作原理文档,使用文档完整。 
3、代码规整优美。注释得当。 
4、运行速度足够快。 

1、----------------------------------------------------------- 
本题(20分)。写一个程序,有三个功能: 
a)取得CMOS中的当前时间,按照YY:MM D:HH:MM:SS格式输出。 
b)取得物理内存的大小,格式化输出。 
c)取得从物理段地址F000:FFF0起,16个字节的值,每字节按照16进制格式输出。 

2、----------------------------------------------------------- 
本题(20分)。对串口编程,编写一对类似ping的程序,作用在串口上,了解serial的联 

通情况。 
定义协议 
要求: 
定义一个联通和响应协议。至少具有:发送、回复、超时三种状态。除超时状态外,所 

有 
状态的数据必须经过校验才可使用。 

ping_serial_client 
要求: 
1,发送数据包; 
2,等待回复数据包,直到超时; 
3,如果有回复数据包,对数据包进行校验; 
4,计算校验通过的数据包之间的时间差; 
5,重复直到用户退出; 
6,统计丢包率,时间。 
界面: 
bash# ping_serial_client /dev/ttyS0 baud_value 
??bytes from ttyS0, time=??ms 
...... 
^C 
--- ttyS0 ping statistics --- 
?? packets transmitted, ?? received, ??% loss 
time ??ms, min/avg/max = ??/??/?? ms 

ping_serial_server 
要求: 
1,等待对方的发送数据包; 
2,对发送数据包进行校验; 
3,校验通过则回复数据包; 
4,重复直到用户退出; 

界面: 
bash# ping_serial_server /dev/ttyS0 baud_value 

3、----------------------------------------------------------- 
编写一对socket程序,要求类似于network echo procotol。 
Client每隔1秒把自己的IP地址轮流循环发送给一个Server. 
Server接到IP后,在屏幕上打印对方IP;然后把自己的IP发送回去。 
Client收到回复后,在屏幕上打印对方IP。 
程序一直运行,直到用户退出。各自分类统计接收到的各IP的数据包的个数。 
注意:Client可以向多个Server发送请求,Server也可以接收多个Client请求。 
注意:输出信息的美观,和对错误的处理。 
----------------------------------------------------------- 

四、C++题目。 

----------------------------------------------------------- 

1。给定下面的代码: 

class Graph{ 
public: 
Graph() { s_gCount++; } 

virtual ~Graph() { s_gCount--;} 

virtual int drawOut() = 0; 

static int getTotalCount() { return s_gCount; } 

protected: 
int m_x; 
int m_y; 
static int s_gCount; 
};

你可能感兴趣的:(面试,笔试)