进程的概念

进程是主动获取资源的执行实体,每个进程拥有唯一的PC。在单核CPU中,通过分时任务和中断处理实现多进程的并发感觉。程序从加载到内存,到执行涉及栈和堆空间的管理,以及可能的I/O操作导致的等待状态。操作系统通过上下文切换管理进程,如遇到中断,会保存当前进程状态并切换到其他进程。Windows采用抢占式多任务,而分时系统平均分配CPU时间片。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

进程的概念

程序的概念
这里说的是一个可执行文件,passive的意思可以理解为我们这个执行文件需要我们进行双击才会被被执行。
在这里插入图片描述双击后,程序入口地址读入寄存器,程序加载入主存,成为一个进程
在这里插入图片描述进程是主动去获取想要的资源,注意这里每个进程都只有一个pc
在这里插入图片描述这里我去问了一下老师,老师说微观上来说确实一个核心一个pc只能同时运行一个进程,因为学习过计组之后我们知道单核只有一个pc寄存器,分时任务可以设置中断程序然后让pc数据存入对应堆栈空间,然后执行完相应程序再读取回来,通过cpu流水线进行优化,这样一套流程让我们感觉到多进程是在同时运行的。

程序推入内存示意图
在这里插入图片描述

在这里插入图片描述

执行流程:
1.先将代码解释成二进制指令,该指令区域(text)是只读的,压入无法修改;
2.入口main函数加载入栈空间,压入静态变量i和调用另外一个g函数,同时压入全局变量global;
3.g函数压入栈,a局部变量压入栈,再压入f函数;
4.压栈入f函数,x,y,p局部变量进栈,动态申请堆空间100Byte(p指针局部变量值为此堆空间的地址) ,继续向下读
5.返回到f函数f函数再代码中存在的地址区,继续向下读;
6.读到g函数return,返回g函数代码点,返回0值进栈,释放栈、堆空间,释放text空间;

遗留问题
在这里插入图片描述

c语言需要手动释放垃圾内存

并发的进程:
在这里插入图片描述在这里插入图片描述当然这里我们要知道这个"并发"并非并行,前面讨论pc的时候有讲。
当然如果是多核cpu是可以并行的。

并发进程共享cpu
就算是并行也会被并发所影响
在这里插入图片描述最后给进程下个定义
在这里插入图片描述

进程的状态:
在这里插入图片描述
最后一个等待态是不具备运行条件,下面这个例子是,如果指定到2步输出语句需要调用系统write占用io,如果这个函数执行占用资源很大,那调用2步函数的进程需要进入等待状态让出cpu控制权,等待调用结束。
在这里插入图片描述

运行状态何时能让出cpu控制权?
在这里插入图片描述

调用i/o设备进入等待,非正常结束进入终止。
在这里插入图片描述

windows叫做抢占式的多任务操作系统,如果有更高优先级的进程到达就绪状态,那么立刻就会抢占低优先级进程的cpu使用权;分时操作系统为所有的并发进程分发时间片,假设分时系统为每个进程运行时间平均分配100s,那么进程占用cpu达到100s就会被强制剥夺cpu使用权。

进程转化
在这里插入图片描述

总结:
外中断:外部事件
内中断:经典例子地址越界,除数为0,c语言堆栈溢出。

在这里插入图片描述
中断处理程序保存前面 我们画的那个程序内存空间的数据
中断程序执行一个lpsw指令跳回用户模式
在这里插入图片描述在这里插入图片描述

上下文内容(context)
在这里插入图片描述

操作系统管理context,只需要调用每个进程的context内的PCB
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

白帽小丑

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值