安徽工业大学linux网络,安工大Linux 网络程序设计历年试卷一

2024-01-05 10:50

本文主要是介绍安徽工业大学linux网络,安工大Linux 网络程序设计历年试卷一,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2015--2016 试卷(我的下载资源里有文档压缩包)

一、填空题(每空2分)

1.GNU是GNU's Not Unix的缩写

2.服务器端因为往往带有多个网络适配器,所以一般用通配地址为其IPV4地址,此通配地址为INADDR_ANY

3.Linux控制台中欲将进程以后台进程运行,可以在命令结尾处添加符号&,将指定后台进程变为前台进程可以用命令fg %number

4.Linux系统调用select可以用来实现I/O复用,其成功返回时的返回值表示准备就绪的文件描述符

5.用来通知父进程子进程结束的信号是SIGCHLD,若父进程等待指定子进程退出可以调用函数waitpid();等待任意子进程结束的系统调用是wait();

6.Linux中用来产生新进程的系统调用是fork(),这个系统调用有2个返回值

7.系统调用socketpair产生的管道是全双工

8.Linux线程语句:pthread_deatch(pthread_self());的作用是把自身的线程变为服务状态。

9.UNIX domain socket 主要用来进行同一台操作系统上的两个或多个进程进行数据通信,其地址类型为文件系统的路径名。

二、套接字含义

1.Socket、创建一个用于网络通信的描述符

2.bind、把一个本地协议地址赋予一个套接字

3.accept、用于从已完成连接队列队头返回下一个已完成连接。

4.send、用于向TCP连接的另一端发送数据

5.connect、TCP客户用于建立与TCP服务器的连接

6.Listen、把一个未连接套接字设置为被动套接字,并且规定了连接请求的队列长度

7.shutdown 在一个方向或两个方向终止TCP连接

三、简答题

1.列举两种解决超时通信的方案并简要解释

(1)、调用alarm,它在指定超时期满时产生SIGALRM信号。这个方法涉及信号处理,而信号处理在不同的实现上存在差异,而且可能干扰进程中现有的alarm调用。

(2)、在select中阻塞等待I/O(select有内置的时间限制),以此代替直接阻塞在read或write调用上

2.解释fd_set及其相关四个宏FD_SET,FD_ISSET,FD_CLR,FD_ZERO的作用

Fd_set:存放文件描述符的集合

FD_SET:把文件描述符添加到fd_set中。

FD_ISSET:判断某个文件描述符是否在fd_set中

FD_CLR:将某个文件描述符从fd_set集合中删除

FD_ZERO:将fd_set集合清空

3.什么是竞争条件(race condition)?Linux环境下编程有哪些机制避免竞争条件?相对于互斥量(mutex),条件变量机制的优势是什么?

当由于事件的次序异常而造成对同一资源的竞争,从而导致程序无法正常运行时,称为竞争条件;

Linux环境下编程避免竞争条件的机制有:加互斥锁和条件变量机制;

互斥锁花大量CPU时间等待QUEUE,只有两种状态:锁定、非锁定。条件变量是通过允许线程阻塞和等待另一个线程发送信号的方法弥补不足,提高效率

4.在预分配多进程服务器中多进程调用accept函数阻塞时会出现惊群现象。请解释惊群的含义,并给出解决方案。

对于socket描述符的accept操作,当多个用户进程/线程监听在同一个端口上时,由于实际只可能accept一次,因此就会产生惊群现象。

解决方案:解决办法:主线程负责监听,通过线程池方式处理连接。

5.简要解释进程与线程对主程序全局变量访问模式的区别。

找度娘就可以了

程序填空(1分/空)

1.concurrent server

Listenfd=socket(AF_INET,SOCKET_STREAM, 0);

Listen(listenfd,LISTENQ);

If((childpid = fork()) == 0)

Close(listenfd);

Str_echo(connfd);

Exit(0);

2.利用IO_multiplexing实现并发服务

listenfd =socket (AF_INET ,SOCK_STREAM , 0);

listen(listenfd, LISTENQ);

FD_SET(listenfd , &allset);

rset = allset;/*structure assignment*/

nready = select(maxfd+1,&ret,Null ,Null ,Null);

If(connfd >maxfd)

maxfd = connfd /for select/

If(--nready <= 0)

continue;/no more readable descriptors/

FD_CLR(sockfd , &allset);

3.进程后台化

If(setsid() < 0) /become session lender/

signal (SIGHUP, SIG_IGN);

chdir(“/”); /change working directory/

open(“/dev/null”, O_RDONLY);

open(“/dev/null”, O_RDWR);

open(“/dev/null”, O_RDWR);

2016--2017 试卷

一、填空题(每空2分)

1.为了匹配多个接口IP统配地址,网络服务器的本地IP会用宏__替代

2.Linux将C程序的源代码编译为可执行程序,需要用gcc -o

3.Linux控制台程序主函数main(int argc, char** argv)中参数argc作用是统计命令行参数个数,agrv的作用是用来存放命令行参数

4.用来通知父进程子进程结束的信号是SIGCHLD,若父进程等待指定子进程退出可以调用函数waitpid().

5.当一个进程成功调用execv函数族时,其进程描述符不变(变或不变)’

6.Linux中子进程欲获得自己的IP可以调用getpid()

7.如果要在进程间传递路径或文件描述符,必使用Unix域套接字

8.Linux的POSIX线程库中与系统调用wait作用类似的调用是pthread_join()

9.Socketpair函数所创建的一对套接字之间的通信是基于Unix域协议的

10.Epoll两种调用,水平触发和边缘触发

11.Fork()之后return=0该进程是子(父或子)进程,若获得PID,调用getpid()

二、socket套接字含义

1.Socket、创建一个用于网络通信的描述符

2.bind、把一个本地协议地址赋予一个套接字

3.accept、用于从已完成连接队列队头返回下一个已完成连接。

4.send、用于向TCP连接的另一端发送数据

5.connect、TCP客户用于建立与TCP服务器的连接

6.Listen、把一个未连接套接字设置为被动套接字,并且规定了连接请求的队列长度

三、简答题

1、解释fd_set及其相关四个宏FD_SET,FD_ISSET,FD_CLR,FD_ZERO的作用

Fd_set:存放文件描述符的集合

FD_SET:把文件描述符添加到fd_set中。

FD_ISSET:判断某个文件描述符是否在fd_set中

FD_CLR:将某个文件描述符从fd_set集合中删除

FD_ZERO:将fd_set集合清空

2、如何用alarm与sigaction函数处理超时?

调用alarm,它在指定超时期满时产生SIGALRM信号。这个方法涉及信号处理,而信号处理在不同的实现上存在差异,而且可能干扰进程中现有的alarm调用。

(2)、在select中阻塞等待I/O(select有内置的时间限制),以此代替直接阻塞在read或write调用上

3、Linux中可用条件变量机制(conditional variable)实现生产者和消费者之间的同步,线程A(生产),B(消费),欲在队列Q上利用条件变量实现同步,给出两线程的伪代码。

0978cf755b868b45f1168bbbfefb5da8.png

4、Linux下的Super Server可以为多个服务进程提供监听服务,简述其工作原理

对于socket描述符的accept操作,当多个用户进程/线程监听在同一个端口上时,由于实际只可能accept一次,因此就会产生惊群现象。

解决方案:解决办法:主线程负责监听,通过线程池方式处理连接。

5、在基于fork的并发服务器中主进程需要处理SIGCHLD信号,解释原因并给出SIGCHLD信号处理函数的定义。

为了避免僵尸进程。

定义:

54b387e4935ed4910e05f9b8b99cf767.png

6、Void my_lock_init(char *pathname){

1.int fd;

2.Pthread_mutexattr_t mattr;

3.Fd=open(“/dev/zero”,0_RDWR,0);

4.Mptr=mmap(0,sizeof (pthread_mutex_t),PROT_READ,PROT_WRITE,MAP_SHARED,fd,0);

5.Close(fd);

6.Pthread_mutexattr_init(&mattr);

7.Pthread_mutexattr_setpshared(&mattr,THREAD_PROCESS_SHARED);

8.Pthread_mutex_init(mptr,&mattr);

}

解释3~8行

3.使用/dev/zero设备创建共享内存

4.使用 mmap 函数将 /dev/zero 映射到内存中

5.关闭描述符,因为该描述符已被内存映射了

6.为一个互斥锁以默认属性初始化一个 pthread_mutexattr_t 结构

7./然后赋予该结构 PTHREAD_PROCESS_SHARED 的属性,使它可以在多个进程内使用

8.调用 pthread_mutex_init 函数以这些属性初始化共享内存区中的互斥锁

四:程序填空题同去年一样

2017--2018试卷

一、填空题(每空2分)

新增两个,其他与往年相同,新增如下

1. ox34EF  在网络字节序中为 EF34 (高地址在左)    这是本人的答案,不一定对

2 对对个缓冲区写去文件,可以使用函数________

二:新题 请看下一个博客,这个写满了

这篇关于安徽工业大学linux网络,安工大Linux 网络程序设计历年试卷一的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/572619

相关文章

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了

poj 2112 网络流+二分

题意: k台挤奶机,c头牛,每台挤奶机可以挤m头牛。 现在给出每只牛到挤奶机的距离矩阵,求最小化牛的最大路程。 解析: 最大值最小化,最小值最大化,用二分来做。 先求出两点之间的最短距离。 然后二分匹配牛到挤奶机的最大路程,匹配中的判断是在这个最大路程下,是否牛的数量达到c只。 如何求牛的数量呢,用网络流来做。 从源点到牛引一条容量为1的边,然后挤奶机到汇点引一条容量为m的边