嵌入式面试题(3)

2019-03-29 12:37

119端口:119端口是为“Network News Transfer Protocol”(网络新闻组传输协议,简称NNTP)开放的。

135端口:135端口主要用于使用RPC(Remote Procedure Call,远程过程调用)协议并提供DCOM(分布式组件对象模型)服务。

137端口:137端口主要用于“NetBIOS Name Service”(NetBIOS名称服务)。 139端口:139端口是为“NetBIOS Session Service”提供的,主要用于提供Windows文件和打印机共享以及Unix中的Samba服务。

143端口:143端口主要是用于“Internet Message Access Protocol”v2(Internet消息访问协议,简称IMAP)。

161端口:161端口是用于“Simple Network Management Protocol”(简单网络管理协议,简称SNMP)。

443端口:43端口即网页浏览端口,主要是用于HTTPS服务,是提供加密和通过安全端口传输的另一种HTTP。

554端口:554端口默认情况下用于“Real Time Streaming Protocol”(实时流协议,简称RTSP)。

1024端口:1024端口一般不固定分配给某个服务,在英文中的解释是“Reserved”(保留)。

1080端口:1080端口是Socks代理服务使用的端口,大家平时上网使用的WWW服务使用的是HTTP协议的代理服务。

1755端口:1755端口默认情况下用于“Microsoft Media Server”(微软媒体服务器,简称MMS)。

4000端口:4000端口是用于大家经常使用的QQ聊天工具的,再细说就是为QQ客户端开放的端口,QQ服务端使用的端口是8000。

5554端口:在今年4月30日就报道出现了一种针对微软lsass服务的新蠕虫病毒——震荡波(Worm.Sasser),该病毒可以利用TCP 5554端口开启一个FTP服务,主要被用于病毒的传播。

5632端口:5632端口是被大家所熟悉的远程控制软件pcAnywhere所开启的端口。 8080端口:8080端口同80端口,是被用于WWW代理服务的,可以实现网页浏览。 46、物理地址转换成IP地址的协议?反之?

地址解析协议(ARP)的作用是将IP地址转换成物理地址;反地址解析协议(RARP)则负责将物理地址转换成IP地址。

47、WLAN:无线局域网络:利用射频技术进行数据传输的系统。

WLAN是指应用无线通信技术将计算机设备互联起来,构成可以互相通信和实现资源共享的网络体系。无线局域网本质的特点是不再使用通信电缆将计算机与网络连接起来,而是通过无线的方式连接,从而使网络的构建和终端的移动更加灵活。

48、已知数组table,用宏求元素个数。

COUNT(table) (sizeof(table)/sizeof(table[0])); 49、定义一个两个参数的标准宏MAX,总是输出最大值。 #define MAX(a,b) ((a)>(b)?(a):(b)) 50、什么是平衡二叉树?

当且仅当两个子树的高度差不超过1时,这个树是平衡二叉树。 51、全局变量和局部变量的区别。

全局变量,储存在静态区.进入main函数之前就被创建.生命周期为整个源程序; 局部变量,在栈中分配.在函数被调用时才被创建.生命周期为函数内。 52、数组与链表的区别。

数组中的数据在内存中的按顺序存储的,而链表是随机存储的!

要访问数组中的元素可以按下标索引来访问,速度比较快,如果对他进行插入操作的话, 就得移动很多元素,所以对数组进行插入操作效率很低!由于连表是随机存储的,

链表在插入,删除操作上有很高的效率(相对数组),如果要访问链表中的某个元素的话, 那就得从链表的头逐个遍历,直到找到所需要的元素为止, 所以链表的随机访问的效率就比数组要低 53、死锁的四个条件及处理方法。

(1)互斥条件:一个资源每次只能被一个进程使用。

(2) 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放。 (3)不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺。 (4)循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。 解决死锁的方法分为死锁的预防,避免,检测与恢复三种 54、进程调度策略。

先进先出算法,最短CPU运行期优先调度算法,轮转法,多级队列方法 55、Linux驱动程序流程及功能。 设备驱动程序的功能: 对设备初始化和释放

把数据从内核传送到硬件和从硬件读取数据

读取应用程序传送给设备文件的数据和回送应用程序请求的数据 检测和处理设备出现的错误 56、时间换空间、空间换时间的例子。 冒泡排序 --- 时间换空间

快速排序,堆排序 --- 空间换时间 57、MAC层通信协议有哪些? ISO2110,IEEE802,IEEE802.2

58、关键字static的作用是什么?

*在函数体内,一个被声明为静态的变量在这一函数被调用过程中维持其值不变(该变量存放在静态变量区)。

*在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。 它是一个本地的全局变量。

*在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。 那就是,这个函数被限制在声明它的模块的本地范围内使用。 59、参数的传递方式有几种? 1、值传递 2、指针传递

严格来看,只有一种传递,值传递,指针传递也是按值传递的,复制的是地址。 60、局部变量能否和全局变量重名?

答:能,局部会屏蔽全局。要用全局变量,需要使用 \局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。

对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,

而那个局部变量的作用域就在那个循环体内。 61、如何引用一个已经定义过的全局变量?

答:extern 可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,

假定你将那个变量写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,

那么在编译期间不会报错,而在连接期间报错。

62、全局变量可不可以定义在可被多个.C文件包含的头文件中?为什么? 答:可以,在不同的C文件中以static形式来声明同名全局变量。 可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错 63、语句for( ;1 ;)有什么问题?它是什么意思? 答:和while(1)相同。

64、static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别? 全局变量(外部变量)的说明之前再加static 就构成了静态的全局变量。全局变量本身就是静态存储方式,

静态全局变量当然也是静态存储方式。 这两者在存储方式上并无不同。

这两者的区别虽在于非静态全局变量的作用域是整个源程序, 当一个源程序由多个源文件组成时,

非静态的全局变量在各个源文件中都是有效的。 而静态全局变量则限制了其作用域,

即只在定义该变量的源文件内有效。 从以上分析可以看出,把局部变量改变为静态变量后是改变了它的存储

方式即改变了它的生存期。把全局变量改变为静态变量后是改变了它的作用域,

限制了它的使用范围。static函数与普通函数作用域不同。仅在本文件。只在当前源文件中使用的函数应该说明为内部函数(static)

,内部函数应该在当前源文件中说明和定义。对于可在当前源文件以外使用的函数,应该在一个头文件中说明,

要使用这些函数的源文件要包含这个头文件 static全局变量与普通的全局变量有什么区别: static全局变量只初使化一次,防止在其他文件单元中被引用static局部变量和普通局部变量有什么区别:

static局部变量只被初始化一次,下一次依据上一次结果值; static函数与普通函数有什么区别: static函数在内存中只有一份,普通函数在每个被调用中维持一份拷贝

65、程序的局部变量存在于(堆栈)中,全局变量存在于(静态区 )中,动态申请数据存在于( 堆)中。

66、-1,2,7,28,,126请问28和126中间那个数是什么?为什么?

答案应该是4^3-1=63 规律是n^3-1(当n为偶数0,2,4)n^3+1(当n为奇数1,3,5) 67、用两个栈实现一个队列的功能?要求给出算法和思路! 设2个栈为A,B, 一开始均为空. 入队: 将新元素push入栈A; 出队: (1)判断栈B是否为空;

(2)如果不为空,则将栈A中所有元素依次pop出并push到栈B; (3)将栈B的栈顶元素pop出; 68、.软件测试都有那些种类? 人工测试:个人复查、抽查和会审

机器测试:黑盒测试(针对系统功能的测试 )和白盒测试 (测试函数功能,各函数接口) 69、堆栈溢出一般是由什么原因导致的? 没有回收垃圾资源。

70、写出float x 与“零值”比较的if语句。 if(x>0.000001&&x<-0.000001) 71、P地址的编码分为哪俩部分?

IP地址由两部分组成,网络号和主机号。不过是要和“子网掩码”按位与上之后才能区分哪些是网络位哪些 是主机位

72、写一个程序, 要求功能:求出用1,2,5这三个数不同个数组合的和为100的组合个数。 如:100个1是一个组合,5个1加19个5是一个组合。。。。 请用C++语言写。

答案:最容易想到的算法是:

设x是1的个数,y是2的个数,z是5的个数,number是组合数 注意到0<=x<=100,0<=y<=50,0<=z=20,所以可以编程为: number=0;

for (x=0; x<=100; x++) for (y=0; y<=50; y++) for (z=0; z<=20; z++) if ((x+2*y+5*z)==100) number++;

73、内存对齐问题的原因?

平台原因(移植原因):不是所有的硬件平台都能访问任意地址上的任意数据;

性能原因:数据结构(尤其是栈)应该尽可能地在自然边界上对齐,因为为了访问未对齐的内存,处理器需要做两次内存访问, 而对齐的内存访问仅需要一次。 74、比较一下进程和线程的区别?

(1)、调度:线程是CPU调度和分派的基本单位 (2)、拥有资源:

* 进程是系统中程序执行和资源分配的基本单位

* 线程自己一般不拥有资源(除了必不可少的程序计数器,一组寄存器和栈),但他可以去访问其所属进程的资源,

如进程代码,数据段以及系统资源(已打开的文件,I/O设备等)。 (3)系统开销:

* 同一进程中的多个线程可以共享同一地址空间,因此它们之间的同步和通信的实现也比较简单

* 在进程切换的时候,涉及到整个当前进程CPU环境的保存以及新被调度运行的进程的CPU环境的设置;

而线程切换只需要保存和设置少量寄存器的内容,并不涉及存储器管理方面的操作,从而能更有效地使用系统资源和 提高系统吞吐量。 75、main() {

int a[5]={1,2,3,4,5};

int *ptr=(int *)(&a+1);//&a相当于变成了行指针,加1则变成了下一行首地址 printf(\ }


嵌入式面试题(3).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:实验室生物安全测试题

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: