嵌入式笔试题(答案有待讨论)

 海康嵌入式笔试题

1. 请问 TCP/IP 协议分为哪几层? FTP 协议属于哪一层?

答:可以分为 物理层,数据链路层,网络层,传输层,应用层

应用层: 应用程序间沟通的层,如简单电子邮件传输( SMTP)、

文件传输协议( FTP)、网络远程访问协议( Telnet )等。

传输层: 在此层中,它提供了节点间的数据传送,应用程序之间的通信服务,

主要功能是数据格式化、数据确认和丢失重传等。

如传输控制协议( TCP)、用户数据报协议( UDP)等,TCP 和 UDP给数据包加入传输数据并把它传输到下一层中,这一层负责传送数据,并且确定数据已被送达并接收。

互连网络层: 负责提供基本的数据封包传送功能,让每一块数据包都能够到达目

的主机(但不检查是否被正确接收),如网际协议( IP)。如 ARP 是地址解析协议,

在这一层的时候吧 IP 地址转换为物理地址

网络接口层(主机 -网络层): 接收 IP 数据报并进行传输,从网络上接收物理帧,

抽取 IP 数据报转交给下一层, 对实际的网络媒体的管理, 定义如何使用实际网络(如

Ethernet 、 Serial Line 等)来传送数据。

另外补充一下 OSI 的七层所对应的协议:

应用层(Application) :

应用程序网关( application gateway ) Telnet: 远程登录 (在应用层连接两部分应用程序)

FTP (File Transfer Protocol ):文件传输协议

HTTP (Hyper Text Transfer Protocol ):超文本传输协议

SMTP ( Simple Mail Transter Protocol ):简单邮件传输协议

POP3 ( Post Office Ptotocol ):邮局协议

SNMP ( Simple Network Mangement Protocol )简单网络管理协议

DNS ( Domain Name System ):域名系统

传输层(Transport ):

传输网关( transport gateway )

TCP ( Transmission Control Potocol) :传输控制协议(在传输层连接两个网络)

UDP (User Data Potocol ):用户数据协议

网络层(Internet ):

多协议路由器( multiprotocol router )

IP (Internet Protocol ):网络协议 (在异构网络间转发分组)

ARP ( Address Resolution Protocol ):地址解析协议

RARP ( Reverse Address Resolution Protocol) :逆地址解析协议

ICMP ( Internet Control Message Protocol ):因特网控制消息协议

IGMP ( Internet Group Manage Protocol ):因特网组管理协议

BOOTP ( Bootstrap ):可选安全启动协议

数据链路层( Data Link ):

网桥(bridge )交换机(switcher )

HDLC (High Data Link Control ):高级数据链路控制 (在 LAN 之

间存储 -转发数据链路针)

SLIP (Serial Line IP):串行线路 IP

PPP ( Point-to-Point Protocol ):点到点协议 802.2 等

物理层(Physical ):

中继器(repeater ) 集线器(hub )

(放大或再生弱的信号,在两个电缆段之间复制每一个比特)

再回过头来看, ftp 是用 tcp 写的一个文件传输协议,明显就是在应用层了

====================================================================

2. 在网络应用中, 函数 htons , htonl , ntohs ,ntohl 的作用?

htons : 把短整型的主机字节顺序转变为网络字节顺序其它依次类推htons 一般用来转变端口, htonl 一般用来转 IP网络字节顺序是先高位字节,再低位字节;主机字节顺序则视 cpu 而定

干脆扩展一点

#include<unistd.h>

#include<stdio.h>

#include<stdlib.h>

#include< string .h>

#include<netinet/ in .h>

#include<sys/socket.h>

#include<sys/types.h>

int main()

{

char str[]= "255.255.255.255" ;

in_addr_t r1,r2,r3;

struct in_addr inp;

r1=inet_addr(str);

if (r1== - 1)

{

printf( "inet_addr return -1 when 255.255.255.255\n" );

}

else

{

printf( "inet_addr:ip=%lu\n" ,ntohl(r1));

}

r2=inet_network(str);

if (r2== - 1)

{

printf( "inet_network return -1 when 255.255.255.255\n" );

}

else

{

printf( "inet_network:ip=%lu\n" ,r2);

}

r3=inet_aton(str,&inp);

if (r3==0)

{

printf( "inet_aton return -1 when 255.255.255.255\n" );

}

else

{

printf( "inet_aton:ip=%lu\n" ,ntohl(inp.s_addr));

}

return 0;

}

====================================================================

3. 在 c 语言中, static 函数与普通函数有什么区别?

1. 全局静态变量

在全局变量之前加上关键字 static,全局变量就被定义成为一个全局静态变量。

1)内存中的位置:静态存储区(静态存储区在整个程序运行期间都存在)。

2)初始化:未经初始化的全局静态变量会被程序自动初始化为 0(自动对象的值是任意的,除

非他被显示初始化)。

3)作用域:全局静态变量在声明他的文件之外是不可见的。准确地讲从定义之处开始到文件结

尾。

定义全局静态变量的好处:

<1> 不会被其他文件所访问,修改。

<2> 其他文件中可以使用相同名字的变量,不会发生冲突。

2. 局部静态变量

在局部变量之前加上关键字 static,局部变量就被定义成为一个局部静态变量。

1)内存中的位置:静态存储区。

2)初始化:未经初始化的全局静态变量会被程序自动初始化为 0(自动对象的值是任意的,除

非他被显示初始化)。

3)作用域: 作用域仍为局部作用域, 当定义它的函数或者语句块结束的时候, 作用域随之结束。

注:当 static 用来修饰局部变量的时候,它就改变了局部变量的存储位置,从原来的栈中存放改

为静态存储区。考试 ,大提示局部静态变量在离开作用域之后,并没有被销毁,而是仍然驻留在内存当中,直到程序结束,只不过我们不能再对他进行访问。

当 static 用来修饰全局变量的时候, 它就改变了全局变量的作用域 (在声明他的文件之外是不可见的),但是没有改变它的存放位置,还是在静态存储区中。

3. 静态函数

在函数的返回类型前加上关键字 static,函数就被定义成为静态函数。

函数的定义和声明默认情况下是 extern 的,但静态函数只是在声明他的文件当中可见,不能被

其他文件所用。

定义静态函数的好处:

<1> 其他文件中可以定义相同名字的函数,不会发生冲突。

<2> 静态函数不能被其他文件所用。

存储说明符 auto, register, extern, static,对应两种存储期:自动存储期和静态存储期。

auto 和 register 对应自动存储期。具有自动存储期的变量在进入声明该变量的程序块时被建立,

它在该程序块活动时存在,退出该程序块时撤销。

关键字 extern 和 static 用来说明具有静态存储期的变量和函数。用 static 声明的局部变量具有静

态存储持续期( static storage duration),或静态范围( static extent)。虽然他的值在函数调用之间

保持有效,但是其名字的可视性仍限制在其局部域内。静态局部对象在程序执行到该对象的声明处

时被首次初始化。

扩展分析:

术语 static 有着不寻常的历史 .起初, 在 C 中引入关键字 static 是为了表示退出一个块后仍然存在的局部变量。随后, static C 中有了第二种含义:用来表示不能被其它文件访问的全局变量和函数。

为了避免引入新的关键字,所以仍使用 static 关键字来表示这第二种含义。最后, C++重用了这个关键字,并赋予它与前面不同的第三种含义:表示属于一个类而不是属于此类的任何特定对象的变量和函数 (与 Java中此关键字的含义相同 )。

写个例子,比对一下

#include <stdio.h>

#include <stdlib.h>

extern int a;// 声明

static int b= 5;

a= 0;// 初始化

void func1()

{

printf( "a=%d;b=%d\n" ,a,b);

return ;

}

void func2()

{

static int i= 333;

i++;

printf( "i=%d\n" ,i);

return ;

}

int main()

{

a=20;

func1();

func2();

func2();

return 0;

}

输出为:

a=20;b=5

i=334

i=335

总的来说,静态的东西就是只在本文件中可见,而且在本文件中保持,它只初始化一次,存在静态

存储区中,再对它进行初始化不会引起错误,但是没有用了

====================================================================

4.请实现内存复制函数

void memcpy( void *dst,void *src,int size) ?

网上搜了一下

void *MyMemCopy(void *dest, const void *src,size_t count)

{char *pDest= static_cast< char * > (dest);

const char *pSrc= static_cast< const char *> (src);

if ( pDest>pSrc && pDest < pSrc + count )

{for (size_t i= count-1; i<=0; ++i)

{pDest[i]= pSrc[i];

}

}else

{for (size_t i=0; i< count; ++i)

{pDest[i]=pSrc[i];

}

}return pDest;

}

哎,搞 IT 真的没有前途,你看,人都这么聪明的?!就这还考虑到了,幸好,我还不是笨到家,还能看得懂稍微解释下:

如果是这个情况:

src --------------------dst --------------------------

说明两个在内存区有重叠的地方。如果用 dst[0]=src[0]那么说明 src 的某块会被弄脏掉,怎么办?从后面拷起就不会有问题, dst[size-1]=src[size-1]

如果没有重叠的话就从头拷起如程序所见

浙江大华嵌入式笔试题型

选择题

1:设float a=2, b=4, c=3;,以下C语言表达式与代数式 (a+b)c/2计算结果不一致的是
A.(a+b)*c/2
B.(1/2)*(a+b)*c
C.(a+b)*c*1/2
D.c/2*(a+b)

2:为了向二进制文件尾部增加数据,打开文件的方式应采用
A.″ab″
B.″rb+″
C.″wb″
D.″wb+″

3:下述程序执行后的输出结果是
#include
main()
{
int x=’f';
printf(“%c\n”,’a'+(x-’a'+1));
}
A.g
B.h
C.i
D.j

4:C语言中,下列运算符优先级最高的是
A.!
B.%
C.>>
D.= =

5:数组定义为“ int a [ 4 ] ; ”,表达式 ( ) 是错误的。
A.*a
B.a [ 0 ]
C.a
D.a++

6:执行语句“ k=7>>1; ”后,变量 k 的当前值是
A.15
B.31
C.3
D.1

7:定义函数时,缺省函数的类型声明,则函数类型取缺省类型
A.void
B.char
C.float
D.int

8:若main()函数带参数,参数个数最多是
A.0
B.1
C.2
D.3

9:若有宏定义:#define MOD(x,y) x%y
则执行以下语句后的输出结果是
int a=13,b=94;
printf(″%d\n″,MOD(b,a+4));
A.5
B.7
C.9
D.11

10:下列各个错误中,哪一个不属于编译错误
A.改变 x 原值 3 为 5 ,写作“ x==5 ;”
B.花括号不配对
C.复合语句中的最后一条语句后未加分号
D.变量有引用、无定义

11:下列程序段运行后, x 的值是( )

a=1;b=2;x=0;
if(!( --a))x-- ;
if(!b)x=7;else ++x;
A.0
B.3
C.6
D.7

12:设
#define N 3
#define Y(n) ((N+1)*n)
则表达式2*(N+Y(5+1))的值是
A.42
B.48
C.54
D.出错

13:若定义了char ch[]={″abc\0def″},*p=ch;则执行printf(″%c″,*p+4);语句的输出结果是
A.def
B.d
C.e
D.0

14:下列转义字符中错误的是
A.′\000′
B.′\14′
C.′\x111′
D.′\2′

15:算术运算符,赋值运算符和关系运算符的运算优先级按从高到低依次为
A.算术运算、赋值运算、关系运算
B.算术运算、关系运算、赋值运算
C.关系运算、赋值运算、算术运算
D.关系运算、算术运算、赋值运算

16:设#define N 3
#define Y(n) ((N+1)*n)
则表达式2*(N+Y(5+1))的值是
A.42
B.48
C.54
D.出错

17:表达式 strcmp( “ 3.14 ”,“ 3.278 ” ) 的值是一个
A.非零整数
B.浮点数
C.0
D.字符

18:设struct
{ short a;
char b;
float c;
}cs;
则sizeof(cs)的值是
A.4
B.5
C.6
D.8

19:若变量已正确定义,表达式( j=3 , j++ )的值是
A.3
B.4
C.5
D.0

20:C 语言中运算对象必须是整型的运算符是
A.%
B./
C.!
D.**

简答题

21:打印一个N*N的方阵,N为每边字符的个数( 3〈N〈20 ),要求最外层为“X”,第二层为“Y”,从第三层起每层依次打印数字0,1,2,3,…
例子:当N =5,打印出下面的图形:
X X X X X
X Y Y Y X
X Y 0 Y X
X Y Y Y X
X X X X X

22:谈谈COM的线程模型。然后讨论进程内/外组件的差别。

23:多态类中的虚函数表是Compile-Time,还是Run-Time时建立的?

24:#include

  void main()

  { int c;

  while ((c=getchar())!= ′\ n ′ )

  switch(c – ′ 2 ′ )

  { case 0:

  case 1:putchar(c+4);break;

  case 2:putchar(c+4);break;

  case 3:putchar(c+3);break;

  default:putchar(c+2);break;

  }

  printf( ″\ n ″ );

  }

  运行时输入: 2473 ,输出结果:

25:用两个栈实现一个队列的功能?

26:写一语句实现x是否为2的若干次幂的判断。

27:解二次方程:a*x*x+b*x+c
int Quadratic( double a,double b,double c,double& x1,double& x2);
返回值:解的个数

28:如何判别一个数是unsigned。

29:执行下述程序的输出结果是__________________。
#include
char b[]=”ABCDEF”;
main()
{
char *bp;
for (bp=b;*bp;bp+=2)
printf(“%s”,bp);
printf(“\n”);
}

30:已知一个数组table,用一个宏定义,求出数据的元素个数。

参考答案:1. B2. A3. A4. A5. D6. C7. D8. C9. B10. A11. A12. B13. C14. C15. B16. B17. A18. D
19. A20. A

 

 

猜你喜欢

转载自blog.csdn.net/qq_37951246/article/details/82695260