1、嵌入式面试试题嵌入式面试试题 一、ANSI C/C+方面的知识一.1、简答题。下面的题目必须全部答对才给分(20分):1、 如何在C中初始化一个字符数组。2、 如何在C中为一个数组分配空间。3、 如何初始化一个指针数组。4、 如何定义一个有10个元素的整数型指针数组。5、 s10的另外一种表达方式是什么。6、 GCC3.2.2版本中支持哪几种编程语言。7、 要使用CHAR_BIT需要包含哪个头文件。8、 对(-1.2345)取整是多少?9、 如何让局部变量具有全局生命期。10、C中的常量字符串应在何时定义?11、如何在两个.c文件中引用对方的变量。12、使用malloc之前需要做什么准备工作。
2、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分)int x, y, z
3、= 2;int *p=&z;x=sizeof*p;y=x3、下面的语句是什么意思?如何声明或定义才使它们更易懂?(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语言运算符优先级的记忆技
4、巧是什么?(2分)int hi, 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、对语句 if else 与操作符 ? : 使用场合的比较。(2分)12、编写一
5、个函数,输入一个的整型数字,可以选择按照8/10/16进制输出字符串。注意边界值。(5分)13、本题(2分)。下面是一个1616的黑白图标:static unsigned short stopwatch = 007c6,01ff7,0383b,0600c,0600c,0xc006,0xc006,0xdf06,0xc106,0xc106,0610c,0610c,03838,01ff0,007c0,00000,;如何修改声明,可以使之在源代码中形象地表现出图形的模样。14、说出可以使用calendar1130变量的四种类型定义。(5分)如:int calendar1231;15、使用strcmp,
6、当字符串相同时会返回0。但0一般作为逻辑假,因此下面的语句不容易理解:if (!strcmp(s, “string”) return EQUATION;如何经过简单修改,使之更易懂?(2分)16、编写一个自己的完全C语言版本的memset函数,并且评价这个实现的性能和可移植性。(5分)17、在树和图这些数据结构中,通常使用指针来组织数据。如果我们要把这些数据保存到文件中,指针是没有意义的。我们该如何解决这个问题。(2分)18、用2种不同的方法计算long变量的”1bit的个数。(2分)19、任意给出一个C的基本数据类型,如何编码判断这个数据类型是有符号还是无符号的?(2分)不得上机实验,写出下
7、面代码的输出。解释这个行为是标准定义的,还是依赖实现的。(2分)int i;for (i = 0; i = 0xa1 & c2 = 0xa1)return 1;elsereturn 0;6、下面x, y的值是多少,有什么问题?int x = 10, y = 3;x = y;y = x;x = y;7、int days=31,28,31,30,31,30,31,31,30,31,30,31,;int calendar1231;int (*monthp)31;int *dayp;int i;memset(calendar, 0, sizeof(calendar);i = 0;for (monthp
8、 = calendar; monthp &calendar12; monthp+) for (dayp = *monthp; dayp &(*monthp)31; dayp+) if (dayp - *monthp dayscalendar - monthp) *dayp = i+ % 7 + 1;8、void printnum(long n)if (n = 10) printnum(n/10);putchar (”0123456789n%10);9、void * memchr(void *pv, unsigned char ch, size_t size)unsigned char *pch
9、 = (unsigned char *) pv;unsigned char *pchEnd = pch + size;while (pch pchEnd) if (*pch = ch)return (pch);pch+;return NULL;对我有用0 丢个板砖0 引用 举报 管理 TOP 回复次数:47badhot等级:#1楼 得分:0回复于:2008-03-31 20:08:4910、void * memchr(void *pv, unsigned char ch, size_t size)unsigned char *pch = (unsigned char *) pv;unsigne
10、d 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 0);strcpy(str, pch);12、void *memmove(void *pvTo, void pvFrom, size_t size)
11、char *pbTo = (char *)pvTo;char *pbFrom = (char *)pvFrom;(pbTo 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) +
12、 fibonacci(x - 1);16、这里有一个程序cdecl.c。写出它的工作流程。写出它的使用方法。给出一个典型输入用例,记录下它的输出。一.4、综合编程题。要求:1、完成需求,程序运行正确。2、工作原理文档,使用文档完整。3、代码规整优美。注释得当。4、运行速度足够快。5、用工具分析出是哪些代码或函数造成速度瓶颈。1、编写一个排序程序。被排序的文件有8MB大小,一行一个随机整数(ASCII格式)。要求对这些整数进行排序,并计算平均值,打印出排序所需的时间。(20分)2、用dummy header技巧实现一个链表DEMO。要求具有create, insert, delete, sear
13、ch功能。编写一个应用程序,使用上面的函数。使用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的英文
14、全称是什么3、一般UNIX的程序有多少段,举一个实际的例子说明。4、如何在kernel二进制代码中找一个字符串。5、段地址F000:FFF0转换为线形地址的值是多少(16进制表达)。6、在一个UNIX文件系统中,文件的唯一性标志是什么?二.2、问答题。1、写一些代码。如何用文件实现信号灯?要求如果程序崩溃了,这个文件也将自动被删除。为什么可以这样实现信号灯?(5分)传统的signal函数信号处理为什么是不可靠的,信号和系统调用有何关系?(5分)在图形库系统中往往提供timer的功能,除了使用ALARM信号外,你还可以使用什么系统调用来实现timer?(5分)2、写一些代码,演示如何正确使用wr
15、ite系统调用。注意看好手册再回答。(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之后,如果子进程移动
16、了文件指针,父进程的文件指针有什么变化;如果子进程关闭了文件,父进程有什么变化?为什么会这样?(5分)标准输入、输出和错误输出分别是什么类型的缓冲,这些缓冲在用户空间还是在核心空间?怎样关闭他们的缓冲?如果父进程关闭了缓冲,在fork之后建立的子进程是否也关闭了缓冲?(5分)vfork和fork相比,有什么特色?(2分)system函数是否等同于fork+exec?(2分)wait系统调用有多少种条件可以退出?(2分)对我有用0 丢个板砖0 引用 举报 管理 TOP 精华推荐:嵌入式爱好者的学习笔记连载(二)badhot等级:#2楼 得分:0回复于:2008-03-31 20:09:485、系
17、统调用和库函数调用有什么区别。(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/w
18、rite调用,不是一个好的实现。(20分)2、Linux系统中,什么时候会出现类似Y2K的问题。写一个程序证明。(20分)3、编写一个程序,测试系统最小的睡眠时间间隔。(20分)4、编写一个pipe程序,测试有N个管道,size大小的buffer情况下,pipe的传输性能是多少?(20分)5、在ext2文件系统上,单个文件最大可以达到多少?写一个程序获得这方面的限制。(20分)三、Linux编程基本使用知识。三.1、命令和shell1)编写一个脚本,统计一个目录下面所有C代码的行数。(2分)2)编写一个sed脚本,去除HTML文件中的HTML标记。(2分)3)编写一个脚本获得当前系统eth0的
19、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软
20、件包的Changelog。如何知道kernel软件包有几个文件。如何知道kernel软件包安装后有多大。三.2、编辑工具的使用。(各2分)1)如何使用vi进行块拷贝、粘贴、删除的操作2)如何设置Tab的长度,以及自动缩进的长度3)如何使用tag进行代码阅读4)如何在110行,有确认的进把所有的RedHat改为RedFlag5)在SourceNavigator中,如何跳到一个变量的声明处?如何得知光标当前的位置在那个函数体内?三.3、编译器与调试器。(各2分)1)如何使用gcc得到宏展开的中间代码2)如何通过gcc在命令行中传入宏定义3)在那一级优化的情况下,内联函数才真正的内联到代码中4)gd
21、b的watch命令如何使用,有何缺点5)gdb中使用什么命令可以显式调用的栈帧,如何查看某个栈帧上的局部变量6)如何使用gdb调试多进程7)如何使能/禁止core dump?三.4、库。(各2分)1)如何知道XSetIMValues这个符号在那个X的库文件中2)如何读取C+的符号名,更具可读性3)请解释动态库的soname概念4)解释在链接时rpath选项的含义三.5、Makefile。(10分)如果有一个简单的Test项目目录如下:# tree TestTest| common.h| main.cpp| test.cpp test.h1)使用wildcard、patsubst函数编写一个C+
22、项目的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、
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1