xzxzxz

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.向消息队列发送消息的函数是( )。
msgrcv()
14.( )系统调用可以根据文件描述符来操作文件特性。
stat()
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 个重要事件分别是?( )
信号诞生 信号在进程中注册 信号在进程中注销 信号处理函数执行完毕
30.互斥锁只有两种状态,即?( )
开锁和上锁
31.在标准 IO 库中,rewind 函数作用?( )
将文件流指针指向文件起始位置
32.c 语言中没有明确给定初值的全局变量和静态变量存放在哪儿?( )
未初始化数据区
33.函数 geteuid()用于得到进程的?( )
用户有效 UID
34.一个进程是 ( ) 
C、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); 
 if (ret == -1) {
 perror("munmap error");
 exit(1);
 }
 }
 return 0;
}
A、child, *p = 7000, var = 1000
parent, *p = 0, var = 100
43.哪种进程之间的通信,数据不可以重复读( )
B、fifo C、管道
44.下述是 Linux 下多线程编程常用的 pthread 库提供的函数名和意义,说法不正确的是?( )
D、pthread_exit 杀死一个线程
45.对线程函数来说,说法正确的是( ):
A、pthread_create 中参数 arg 是传递给 start_routine 函数的参数
46.对互斥锁及条件变量说法不正确的是( ):
D、在使用条件变量时,互斥锁会失去作用,所以是否有互斥锁关系不重要
47.以下说明正确的是( ):
B、线程是一个独立的指令流,是在进程中被创建的,随进程的关闭而关闭
48.线程 A SendMessage 给线程 B,线程 B 处理该消息时又 SendMessage 给线程 A,会出现
( ):
B、继承执行
48.linux 文件系统通常由四部分组成:引导块,超级块,索引节点和( )。
B、数据块
49.任何进程在运行时默认打开的三个流对象,都有相应的文件描述符,标准文件描述符定
义标准输入设备的值为( )。
A、0
50.系统调用的函数原型 int open(const char *pathname, int flags),flag 值中( )表示以读写的
方式打开文件。
C、O_RDWR
51 系统调用的函数原型 int open(const char *pathname, int flags),flag 值中( )表示若文件
存在且为只读或只写成功打开,则将长度截为 0。
B、O_TRUNC
52.int main()
{
int fd,length;
fd=open("lseek.txt",O_RDWR);
length=lseek(fd,0,SEEK_END);
printf("the length os lseek is %d\n",length);
close(fd);
return 0;
}
此行代码 length=lseek(fd,0,SEEK_END);中的 length 的值表示( )。
A、文件 lseek.txt 的大小
53.使用下列函数调用 int fcntl(int fd, int cmd);来实现文件描述符的复制,cmd 参数应使用哪
一个?
A、F_DUPFD
54.阅读程序填空:如果想要获取文件的大小,空白处应该填写以下哪个答案。
int main(int argc, char *argv[])
{
struct stat statBuf;
if(stat(argv[1],&statBuf)<0)
{
perror("stat");
}
else
{
printf("the size of file is %ld", );
}
return 0;
}
A、 statBuf.st_size
55.在创建文件和目录时候,有默认权限。如果 umask 值为 0022,则文件的默认权限为( )
B、0644
56.int main (void)
{
 int fd; if((fd=open("tempfile",O_WRONLY|O_CREAT|O_TRUNC,0700))< 0)
 {
 perror("open");
 exit(1);
 }
 if((link("tempfile","hardlink"))==-1)
 {
 perror("open");
 exit(1);
 }
 struct stat statBuf;
 fstat(fd, &statBuf);
 printf("link num:%ld\n", statBuf.st_nlink);
 sleep(3);
 if(unlink("tempfile") < 0)
 {
 perror("unlink");
 exit(1);
 }
 fstat(fd, &statBuf);
 printf("unlink ,num:%ld\n", statBuf.st_nlink);
return 0;
}
执行程序,代码输出结果为( )。
A.link num:2
57.获取目录的系统调用函数为( ) 。
B、getcwd()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值