西安电子科技大学《网络程序设计》试题
(2013年A卷)
考试时间 120 分钟 试卷编号
班级 学号 姓名 任课老师姓名 题号 得分 一 二 三 四 五 六 七 总 分
一、 单选题(10×2分=20分)
1.以下字段中,不属于IP首部的是 A. 协议类型 B. 生存时间 C. 源IP地址 D. 目的端口号
2.以下函数中,不会产生阻塞的是 A. send( ) B. sendto( ) C. connect( ) D. listen( )
3.进程A是进程B的父进程,当A正在运行时B退出,下列叙述中正确的是
A.进程A也将退出
B.进程A将收到SIGCHLD信号 D. 进程A将收到SIGKILL信号 D.进程A会成为僵尸进程
1
4.整数0x12345678在little-endian字节序主机内存中的存储形式是_________(注:内存由低到高) A. 12 34 56 78 C. 34 12 78 56
5.使用信号驱动I/O时哪一个不是必须要执行的操作 A.为信号SIGIO关联一个信号处理函数 B.设置套接字为非阻塞模式 C.设置套接字所有者
D.允许套接字进行信号驱动I/O
6.对使用UDP协议的套接字调用connect函数,下面叙述中正确的是 A.connect函数将阻塞
B.connect函数将导致3次握手操作
C.connect函数记录对方的IP地址和端口后立刻返回 D.不能对使用UDP协议的套接字描述符调用connect函数
7.对函数调用send(sockfd,“12xyz”,5,MSG_OOB)的描述中正确的是 A.只有字符z被写入发送缓冲区 B.只有字符串12xy被写入发送缓冲区
C.字符串12xyz中的每个字符都将作为带外数据发送 D.TCP协议发送的下一个报文段中URG标志将置位
8.在给网络地址附值时,程序如果使用“INADDR_ANY”,则表明 A.对于只有一个IP地址的主机,使用“127.0.0.1”地址 B.对于有多个网卡的主机,使用其中任意一个IP地址
C.对于有多个网卡的主机,表示所有IP地址,并处理所有地址的请求 D.以上均不对
B. 78 56 34 12 D. 56 78 12 34
2
9.请求建立连接时TCP包头中的_________标志位有效 A. SYN B. RST C. PSH D. URG
10.当通信的对方关闭其写通道时,TCP套接字的读函数read( )将_ __ A.返回大于0的整数 C.阻塞
B.返回小于0的整数 D.返回0
二、 判断下面命题的正确性,对不正确的命题,说明错误原因(5×2=10分)
1. 一般情况下,守护进程是在后台运行。
守护进程不考
2. Browse/Server模型主要事务在服务器端实现,一部分事务在前端实现。 正确
3.阻塞式I/O是套接字的默认模型。 正确
4.IP数据包首部中TTL=64表示数据包在网上的最大生存时间是64秒。
错误,TTL表示数据包在网上的最大生存时间,但单位不是秒,而是表示数据包可经过的最多的路由器数量,每经过一个路由器这个值-1。当这个值减为0时网络设备将抛弃这个包。
5.可以只用通信双方的IP地址来标识一条TCP网络连接。
错误,除了需要通信双方的IP地址外还需要通信双方的端口号。
3
三、 简答题(5×5分=25分)
1.请简述4种Linux系统中进程间的通信机制。 (1)管道(pipe)和命名管道(named pipe/FIFO) (2)信号(signal)
(3)消息队列(message queue)
(4)共享内存(share memory)和内存映像文件(memory mapped file) (5)信号量(semaphore) (6)UNIX域socket
2.套接字函数close( )与shutdown( )的差别?
shutdown操作连接通道,其他进程不能再使用已被关闭的通道;close操作描述符,其他进程仍然可以使用该socket描述符
close关闭应用程序与socket的接口,调用close之后进程不能再读写这个socket;shutdown可以只关闭一个通道,另一个通道仍然可以操作 3.请简述循环服务器模型和并发服务器模型的区别。 循环服务器:任一时刻只处理一个客户机请求,处理请求过程中下一请求等待,节省服务器资源,响应时间长,适合处理非耗时请求。
并发服务器:并发执行,每收到一个连接请求创建一个进程处理该连接,服务器继续等待下一连接,响应速度快,占用系统资源多。 4.怎样将阻塞式套接字转变为非阻塞式套接字? (1)函数fcntl int flags;
flag=fcntl(sockfd,F_GETFL,0);
fcntl(sockfd,F_SETFL,flag|O_NONBLOCK); (2)函数ioctl int on=1;
ioctl(sockfd,FIONBIO,&on);
5.Linux系统主要实现了哪几种输入/输出模型?请简述每种模型的特点。 阻塞式I/O模型-默认I/O模型
编程简单,在进程被阻塞期间不占用CPU时间,不影响其他进程的工作效率。但进程可能长期处于休眠状态,在此期间进程不能执行别的任务,进程自身的效率不高。 非阻塞式I/O模型
变成相对复杂,当I/O操作不能完成时,进程还可以执行后续的程序代码,提高了进程自身的工作效率。但进程一直处于运行状态,可能占用大量的CPU时间来检测I/O操作是否完成,从而影响其他进程的运行效率。 多路复用I/O模型
只检查一个socket描述符时和阻塞式I/O模型类似,只是阻塞的位置不同,
4
但效率低于阻塞式I/O模型,在多个socket描述符上进行I/O操作时效率高于阻塞式I/O
信号驱动I/O模型
等待I/O操作可以进行的过程中不用阻塞,可以执行其他操作,程序结构简单,更适用于UDP协议 四、 当服务器采用并发服务器进行有连接的通信时,采用以下程序段的编程
模式来处理应用,请将程序的空白处完善。(4×3分=12分) int sockfd,newsockfd;
if ((sockfd = socket(…)<0) Err_sys (“socket error.”);
if ( bind (sockfd,…)<0) Err_sys (“error.”);
if ( listen (sockfd,5)<0) Err_sys (“error.”); for( ; ; ) {
newsockfd = accept (sockfd,…); if (newsockfd < 0) Err_sys (“ error.”); if ( fork() = =0) {
close(sockfd); …
doit(newsockfd); //用newsockfd 处理具体连接请求 close(newsockfd); exit(0); }
close(newsockfd); }
…… 五、 阅读以下程序,详细说明该程序的功能。(10分) ……
void sigchld_handler(int); int main() { struct sigaction act;
5