1.Linux系统调用
在Linux种,程序的运行空间分为用户空间和内核空间;系统调用就是操作系统提供给用户程序的一组特殊接口(用户程序可以通过该接口获得内核服务)。通过软中断机制向内核提交请求获取服务。存在于内核空间
2.用户编程接口API
上述的系统调用并不会和程序员打交道,实际使用中和内核直接打交道的是用户编程接口(就是我们常说的API)。存在于用户空间。
3.程序和进程
程序:二进制文件,占用磁盘空间
进程:启动的程序
- 需要的数据都在内存中
- 需要占用更多的系统资源:CPU,物理内存
4.并行和并发
并行:多个CPU,一个CPU对应一个任务
并发:时间段分成若干个时间片,交替处理任务
5.PCB
每个进程在内核中都有一个进程控制块PCB来维护进程相关的信息,Linux内核的PCB是task_struct结构体。/usr/src/linux-headers-3.16.0-30/include/linux/schead.h文件中可以查看struct task_struct结构体的定义,其内部成员有很多,我们重点掌握下面部分即可:
- 进程pid:pid_t
- 进程状态:就绪/运行/挂起/停止
- 进程切换时需要保存和恢复一些CPU寄存器
- 描述虚拟地址空间的信息
- 描述终端状态的信息
- 当前工作目录
- umask掩码
- 文件描述符表,包含很多指向file结构体的指针
- 和信号相关的信息
- 用户id和组id
- 进程可以使用的资源上限:ulimit -a
- 会话(Session)和进程组(多个进程组组成了会话)
6.进程状态
就绪态:有执行资格,没有执行权(等待CPU)
运行态:有执行资格,有执行权(获得CPU)
阻塞态/挂起态:没有执行资格,没有执行权
终止态