选择填空题
1.linux 中把分区和目录对应的过程叫做( )。
挂载
2.信号是在软件层次上对()机制的一种模拟, 是一种异步通信方式。 中断
3.用 GCC 编译过程可以被细分为四个阶段:( ) 预处理,编译,汇编,连接
4.编译有线程的文件要加( )参数。
-lpthread
5.父进程等待子进程的结束,可以使用的函数是( )和( )。 wait( ) waitpid( )
6.linux 主要有两个信号安装函数,分别是 signal( ) , sigaction( )
7.Linux 操作系统内核由( )编写完成。
C 和汇编
8.目录( )下存放 linux 操作系统启动时所要用到的程序
/boot
9.Linux 中采用“一对一”的线程机制,也就是一个用户线程对应一个( )。
内核线程
10.vim 三种模式:在命令模式下按下( )就进入了底线命令模式。
:
11.linux 文件系统由四部分组成,( )用于存放文件的控制信息。
超级块
12.线程本身调用( )函数可以退出线程。
pthread_exit()
13.向列消息队发送消息的函数是( )。
msgsnd()
14.( )系统调用可以根据文件描述符来操作文件特性。
fcntl()
15.Valgrind 包括很多工具,( )是 valgrind 应用最广泛的工具,一个重量级的内存检查器,能 够发现开发中绝大多数内存错误使用情况,( )是主要用来检查程序中缓存使用出现的问题。 Memcheck,Cachegrind
16.信号发送函数中,( )用于设置定时器,当计时时间到达时,向进程发送 SIGALRM 信号。 setitimer()
17.当一个线程的属性设置为( ),该线程结束时立即释放它所占有的系统资源。
分离状态
18.以下哪种方式属于异常终止一个进程(D)
D.接到一个信号并终止。
19.下列命令哪个是创建线程私有数据命令(A)
A.pthread_key_create()
20.下面哪种通信方式适用于不同机器之间的进程通信。(D )
套接字
21.创建或打开消息队列的函数为(A ) msgget()
22.linux 中通过调用 waitpid()函数得到进程的退出信息,该函数原型为 pid_t waitpid(pit_t pid, int *statloc, int options);当第一个参数 pid 取值为-1 时,表示(A)
A 等待任一子进程退出,相当于 wait()。
23.Linux 环境中使用 kill 函数向进程或进程组发送信号。Kill 函数原型为 int kill(pid_t pid, int signo);当第一个参数 pid>0 时,表示( A )
A 发送信号给进程 ID 为 pid 的进程;
24.共享主存基本操作( A )将共享主存区映射到进程虚拟地址空间。
A shmat()
25.修改消息队列状态信息的命令是(B)
B msgctl()
26.使用 gdb 调试程序时,next 和 step 命令的作用?( )
统调用的函数原型 next:单步运行,不进入函数内部;
setp:单步运行,进入函数内部
27.Linux 系统的设备文件分为三类?( )
字符设备文件、块设备文件和网络设备文件
28.标准 I/O 提供了三种类型的缓冲,分别是?( )
全缓冲,行缓冲,不带缓冲
29. 一个完整的信号生命周期包含 4 个重要的事件,这 4 个重要事件分别是?( )
信号诞生 信号在进程中注册 信号在进程中注销 信号处理函数执行完毕
互斥锁只有两种状态,即?( )
开锁和上锁
31.在标准 IO 库中,rewind 函数作用?( )
将文件流指针指向文件起始位置
32.c 语言中没有明确给定初值的全局变量和静态变量存放在哪儿?( )
未初始化数据区
33.函数 geteuid()用于得到进程的?( )
用户有效 UID
34.一个进程是 ( )
PCB 结构与程序和数据的组合。
35.一个进程调用 wait 或 waitpid 函数,可能产生 3 中情况,下列不属于这 3 种 情况的是 ( )。
D、如果该进程没有子进程,立即返回,返回值为 0。、
36.返回调用进程的进程标识号的系统函数是 ( )。
A、 getpid
37.程序和进程是两个不同的概念,以下不能描述这个观点的是 ( )。 B、同一个程序运行 10 次,产生的是同一个进程
38.fork 函数在父进程中的返回值是 ( )。
A、创建的子进程的进程标识号
39.在 Linux 中,下列不属于正常结束进程的方法是 ( )。
D、调用 abort 函数。
40.以下程序的输出结果是( )
int main(int argc, char *argv[])
{
printf("===================start of file\n"); pid_t pid = fork();
if (pid == -1) {
perror("fork error");
exit(1);
} else if (pid == 0) {
printf("---child,my pid is %d,my parent pid is %d\n",getpid(),getppid()); } else if (pid > 0) {
printf("---parent my child is %d,my pid is %d,myparent pid is %d\n", pid,getpid(),getppid());
sleep(1); }
printf("===================end of file\n");
return 0; }
B、===================start of file
---parent my child is 4759,my pid is 4758,myparent pid is 3700 ---child,my pid is 4759,my parent pid is 4758 ===================end of file ===================end of file 41.以下程序输出结果是( )
int var = 100;
int main(void)
{
pid_t pid;
pid = fork();
if (pid == -1) {
perror("fork error");
exit(1);
} else if (pid > 0) {
var = 288;
printf("parent, var = %d\n", var);
sleep(1);
} else if (pid == 0) {
printf("child, var = %d\n", var); }
printf("------------finish---------------\n");
return 0; }
C、parent, var = 288
child, var = 100 ------------finish--------------- ------------finish--------------- 42.以下程序输出结果是( )
int var = 100; int main(void) {
int *p;
pid_t pid;
int fd;
fd = open("temp", O_RDWR|O_CREAT|O_TRUNC, 0644); if(fd < 0){
perror("open error");
exit(1); }
ftruncate(fd, 4);
p = (int *)mmap(NULL, 4, PROT_READ|PROT_WRITE, MAP_PRIVATE, fd, 0); if(p == MAP_FAILED){
perror("mmap error");
exit(1); }
close(fd); pid = fork(); if(pid == 0){
*p = 7000;
var = 1000;
printf("child, *p = %d, var = %d\n", *p, var);
} else { sleep(1);
printf("parent, *p = %d, var = %d\n", *p, var); wait(NULL);
int ret = munmap(p, 4)