1.系统调用/API;程序/进程;并行/并发;PCB;进程状态

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)
阻塞态/挂起态:没有执行资格,没有执行权
终止态

猜你喜欢

转载自blog.csdn.net/weixin_36750623/article/details/83040589