1.Linux系统调用
在Linux种,程序的运行空间分为用户空间和内核空间;系统调用就是
操作梓潼提供给用户程序的一组特殊接口(用户程序可以通过该接口
获得内核服务)。通过软中断机制向内核提交请求获取服务。存在于内
核空间
2.用户编程接口API
上述的系统调用并不会和程序员打交道,实际使用中和内核直接打交道
的是用户编程接口(就是我们常说的API)。存在于用户空间。
1.程序和进程
程序:二进制文件,占用磁盘空间
进程:启动的程序
需要的数据都在内存中
需要占用更多的系统资源:CPU,物理内存
2.并行和并发
并行:多个CPU,一个CPU对应一个任务
并发:时间段分成若干个时间片,交替处理任务
3.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)和进程组
多个进程组组成了会话
4.进程状态
就绪态:有执行资格,没有执行权(等待CPU)
运行态:有执行资格,有执行权(获得CPU)
阻塞态/挂起态:没有执行资格,没有执行权
终止态