Linux选择填空

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()

选择填空二 Linux 选择填空

  1. gcc 编译过程:预处理、编译、汇编、连接。

Jdb:b:设置断点;r:执行程序;c:执行下面的程序
Vim:nyy:赋值 n 行;ndd:删除 n 行;p 或 P:粘贴在光标所在行的下一行或者上一 行。

  1. 进程初始化数据区:全局初始化数据区/静态数据区。 进程的运行环境:五大组成部分,在简答题。
  2. 进程的堆区:用于动态内存分配。一般由程序员分配和释放,若程序员不释放,程序结

束时由 OS 回收。

  1. Linux 文件系统中的块有(根据块使用的不同):引导块、超级块、Inode 块、数据块。

控制信息、文件基本属性等是 Inode 节点,为文件系统索引。存放数据的为数据块。超 级块中含有文件系统的基本信息,如块大小、指向空间 inode 和数据块的指针等相关信 息。

  1. 进程运行时默认打开的标准对象:标准输入设备 stdin、标准输出设备 stdout、标准错误 输出设备 stderr。
  2. 软连接和硬链接的特点:硬链接和原来的文件公用一个 Inode 节点。相当于加了个相同 的文件,只是改了改名字。
    硬链接创建函数:link
    删除硬链接函数:unlink

软连接创建函数:symlink

读取软连接中的内容所用的函数:readlink(文件名,读取到的空间,读取的大小)。

  1. 修改文件权限命令:chmod、chgrp、chown。
  2. 文件描述符为整形:对于用户空间来说,任何打开的文件都将分配一个唯一非负整数,

用于标识该打开文件,该值即文件描述符,为一个大于等于 0 的整数。

  1. 权限的值,读:4 写:2 执行:1 注意:前三位为用户的权限,再三位为所属组的权
  2.   限,再三位为其他用户的权限。
  3. 获取文件属性,是否穿透。stat 函数具有穿透能力,能够穿透链接文件;而 lstat 函数不
  4.   具有穿透能力,不穿透链接文件,文件类型还为链接文件。
  5. opendir 函数:打开一个目录,返回一个目录流指针。参数为欲打开目录的名称(路径)。

mkdir 函数:第一个参数时欲创建的目录文件路径,第二个参数时创建目录的权限。

  1. wait 函数:调用 wait 函数的父亲进程将堵塞式等待改进的任意一个子进程结束后,回收

该子进程的内核进程资源。参数用来接受子进程退出状态。返回值为子进程的 PID。 waitpid 函数,用来等待指定子进程结束。返回值为子进程的 PID。 第一个参数,大于 0 时,表示等待进程 PID 为该 PID 值的进程结束;
等于 0 时,表示等待与当前进程的进程组 PGID 一致的进程结束;

等于-1 时,与 wait 函数相同;
小于-1 时,表示等待进程组 PGID 是此值的绝对值的进程结束。 第二个参数用来接受等待进程的结束状态。第三个参数一般设置为。

  1. fork 函数:创建进程。
  2. 进程的进程块没有被释放,称为进程的僵死状态。
  3. Fcntl 函数:修改某个文件描述符的特殊属性
  4. 创建硬链接的系统调用:link()
  5. 安装信号处理函数:signal 和 sigaction。
  6. 信号的生命周期:简答题上
  7. 消息队列中发送信息的函数:msgsnd
  8. 信号是在软件层次上对中断机制的一种模拟,是一种异步通信方式。
  9. 接受消息队列的函数 msgrcv
  10. alarm()设置定时器
  11. 信号分为可靠信号和不可靠信号。
  12. 管道分为有名管道和匿名管道。
  13. 互斥锁的两种状态:上锁和解锁。
  14. 自己退出线程的函数:pthread_exit()

被取消线程运行:pthread_cancle()

  1. 互斥锁、条件变量、读写锁的初始化

互斥锁的初始化:pthread_mutex_init() 条件变量的初始化:pthread_cond_init() 读写锁的初始化:pthread_rwlock_init()

  1. 读写锁:非阻塞的加锁解锁和阻塞的加锁解锁。 堵塞的方式申请读锁:pthread_rwlock_rdlock() 非堵塞的方式申请读锁:pthread_rwlock_tryrdlock() 堵塞方式申请写锁:pthread_rwlock_wrlock() 非堵塞方式申请写锁:pthread_rwlock_trywrlock()
  2. 线程编译的时候加上-lpthread。
  3. 回收线程的函数:pthread_join()
  4. 互斥锁的上锁函数是 pthread_mutex_lock(),非阻塞加 try;

解锁函数是 pthread_mutex_unlock()。

  1. 面向连接的编程:TCP;面向无连接的是:UDP
  2. 在不同主机间进行通讯的是:scoket 或者是套接字
  3. TCP 和 UDP 都是传输层的协议。
  4. 三次握手:连接建立、数据传输、连接释放。
  5. 创建套接字的函数 scoket()
  6. 网络编程的常见函数 j

监听网络函数:listen() 发起连接函数:connect() 接受连接函数:accept()
读写 scoket 对象:read()/write()

TCP 发送和接受数据:send()/recv() 关闭 scoket 对象:close()

上一篇:kill -9 无法杀死进程解决


下一篇:使用laravel-amdin调用文件上传阿里oss注意点