提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
1 简答题
- Linux 系统是什么样的系统?由哪几部分组成,分别属于哪种模式?
Linux 系统是一种金字塔模型的系统。由用户、标准实用程序、标准库、Linux操作系统、硬件组成。前三者属于用户模式,Linux操作系统属于内核模式。
-
Linux 有几种不同的接口?
具有三种不同的接口:系统调用接口、库函数接口和应用程序接口 -
请写出 Linux 的组成部分。
引导程序、内核、初始化系统、后台进程、图形服务器、桌面环境、应用程序。 -
命令cp a b与命令mv a b的区别是什么?
cp 是将文件进行复制,复制完成后会有两个文件 a 和 b;而 mv 相当于是文件的移动,移动完成后就不再有 a 文件。
- 内核系统由哪几部分组成,分别有什么作用?
• 内核系统分为以下三部分:
• I/O 部分负责与设备进行交互以及执行网络和存储 I/O 操作的所有内核部分。
• I/O 右边的是内存部件,程序被装载进内存,由 CPU 执行,这里会涉及到虚拟内存的部件,页面的换入和换出是如何进行的,坏页面的替换和经常使用的页面会进行缓存。
• 进程模块负责进程的创建和终止、进程的调度、Linux 把进程和线程看作是可运行的实体,并使用统一的调度策略来进行调度。
-
什么是父进程,什么是子进程?
调用 fork 函数的进程被称为 父进程(parent process),使用 fork 函数创建出来的进程被称为 子进程(child process)。 -
进程不可以忽略哪两个发送过来的信号?
SIGSTOP 和 SIGKILL 信号。 -
shell 中的 管线 pipelines 是用管道实现的,当 shell 发现输出 sort
它会创建两个进程,一个是 sort,一个是 head,sort,会在这两个应用程序之间建立一个管道使得 sort 进程的标准输出作为 head 程序的标准输入。sort 进程产生的输出就不用写到文件中了,如果管道满了系统会停止 sort 以等待 head 读出数据。 -
在使用共享内存前,需要经过哪些调用流程?
• 创建共享内存段或者使用已创建的共享内存段(shmget())
• 将进程附加到已经创建的内存段中(shmat())
• 从已连接的共享内存段分离进程(shmdt())
• 对共享内存段执行控制操作(shmctl()) -
命名管道的工作方式与常规管道工作方式的区别在于?
未命名的管道没有备份文件:操作系统负责维护内存中的缓冲区,用来将字节从写入器传输到读取器。一旦写入或者输出终止的话,缓冲区将被回收,传输的数据会丢失。相比之下,命名管道具有支持文件和独特 API ,命名管道在文件系统中作为设备的专用文件存在。当所有的进程通信完成后,命名管道将保留在文件系统中以备后用。 -
每个消息队列由什么标识符唯一标识?
IPC 标识符。 -
消息队列有哪两种模式?
一种是严格模式, 严格模式就像是 FIFO 先入先出队列似的,消息顺序发送,顺序读取。还有一种模式是非严格模式,消息的顺序性不是非常重要。 -
一个套接字可以与一个或多个进程关联?
一个套接字可以与一个或多个进程关联。 -
套接字有哪几种分类?
• 顺序包套接字(Sequential Packet Socket): 此类套接字为最大长度固定的数据报提供可靠的连接。此连接是双向的并且是顺序的。
• 数据报套接字(Datagram Socket):数据包套接字支持双向数据流。数据包套接字接受消息的顺序与发送者可能不同。
• 流式套接字(Stream Socket):流套接字的工作方式类似于电话对话,提供双向可靠的数据流。
• 原始套接字(Raw Socket): 可以使用原始套接字访问基础通信协议。 -
操作系统可以分为两种模式?
• 内核态:操作系统内核使用的模式
• 用户态:用户应用程序所使用的模式 -
上下文切换是什么意思?
内核态模式和用户态模式的频繁切换。 -
系统调用是什么?
引起内核态和用户态切换的一种方式,系统调用通常在后台静默运行,表示计算机程序向其操作系统内核请求服务。 -
Linux 和 Unix 一样,都是通过什么来区分不同的进程?
PID 。 -
在 Linux 中如何创建进程?
为子进程开辟一块新的用户空间的进程描述符,然后从父进程复制大量的内容。为这个子进程分配一个 PID,设置其内存映射,赋予它访问父进程文件的权限,注册并启动。 -
线程分为哪两种?
用户级线程和内核级线程。 -
单个线程可能会垄断 CPU 时间片,导致其他线程无法执行从而 饿死。如果执行一个 I/O 操作,那么 I/O 会阻塞,其他线程也无法运行。如何解决这一问题?
一种解决方案是,一些用户级的线程包解决了这个问题。可以使用时钟周期的监视器来控制第一时间时间片独占。然后,一些库通过特殊的包装来解决系统调用的 I/O 阻塞问题,或者可以为非阻塞 I/O 编写任务。
-
为了进行调度,Linux 系统将线程分为哪三类?
• 实时先入先出
• 实时轮询
• 分时 -
CFS 算法优先调度哪些任务?
使用 CPU 时间最少的任务。 -
内核启动代码是使用什么语言完成的,主要包括哪些工作?
汇编语言。主要包括创建内核堆栈、识别 CPU 类型、计算内存、禁用中断、启动内存管理单元等,然后调用 C 语言的 main 函数执行操作系统部分。
2 选择题
把多个文件内容进行连接的命令是: cat
用于提取输入的后面几行的过滤器是 tail
命名管道写入的第一个字节是读取的第 1 个字节
用于执行驻留在活动进程中的文件的系统调用是? exec
存储未初始化的全局变量和未初始化的 static 变量的是( )。 bss段