0906进程

2024-03-10 16:40
文章标签 进程 0906

本文主要是介绍0906进程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

进程

进程和程序:
程序是已经编好的二进制文件,在磁盘上不占用系统资源
进程,需要运行才能存在,占用系统资源,在内存中执行
并发:一个时间段里有多个进程启动和完成,但任意时刻只有一个进程只有一个进程在进行(虽然人感觉不出来),各个进程穿插运行
a,b两个文件,在磁盘里叫程序,在内存里叫进程。
从微观角度:
在CPU里每次只执行一个进程
多个进程轮流循环进行
操作系统负责调度进程执行,比如时间片       
宏观角度:
CPU频率高,每秒10亿条以上命令
肉眼识别速度偏慢
人能看到的进程是同时进行的,即并发,并非真正意义上的多个程序在运行(实际上一个CPU核心每次依然只有一个进程在进行)
64位机寻址实际也只用了2^48,资源浪费很大
映射:三个程序都需要运行,
程序的映射:各路程序的堆栈→CPU(MNU)→映射至虚拟内存
内核到内存的映射:内核通过操作系统映射到同一区域
用户空间:虚拟空间的实际使用量会金国MMU处理成相同大小的物理空间
内核空间:对CPU,每个程序都有各自的内核,程序在虚拟内存上跑

进程控制块PCB:在内核中,储存并维护进程相关信息:
内核进程控制块是task_struct结构体

进程状态模型

三态模型
就绪状态:当进程获得处理机可以执行前的状态。多个就绪态进程拍成序列
执行状态:进程获得处理机,程序正在执行
阻塞状态:因发生事件而暂停执行时的状态,即进程执行收到阻塞,故称这种状态位阻塞状态。阻塞的进程排成一个队列

 

五态模型
创建状态:申请空白PCB,填写控制和管理进程的星系,
就绪状态:分配到CPU开始运行前的状态
执行状态:处于就绪状态被调度后,进入执行状态
阻塞状态:进程暂时无法运行即受到阻塞,满足运行状态后进入就绪状态
终止状态:进程结束或出错,进入终止状态,无法再启动

fork函数:通过系统调用创建一个与旧进程完全相同的进程

头文件:<unistd.h><sys/types.h>
语法pid_t fork(void);成功返回子进程和0,失败返回-1,返回其他值和父进程
区别父子进程的标志:pid
getpid()子ID,getppid()父ID,getuid(),getgid()
在else项以外运行fork函数会让所有进程产生子进程

进程共享

父子进程之间在fork后的共同点和不同点:
全局变量,.data,.text,.栈,堆,环境变量,用户ID,宿主目录,进程工作目录,信号处理方保持一致...
进程ID fork返回值 父进程ID 进程运行时间 闹钟 未决信号集发生变化
父子进程之间遵循读时共享,写时赋值,旨在节省内存占用

回收子进程

孤儿进程和僵尸进程
查看进程 ps -aux
孤儿进程:父进程先于子进程结束,则子进程称为孤儿进程,子进程的父进程为init领养进程。
中止孤儿进程 用kill -9 pid号

 

僵尸进程:进程终止,父进程尚未回收,子进程残留资源PCB存放于内核中,变成僵尸进程
僵尸进程不能用kill命令清除,通过exit指令来退出进程

 

这篇关于0906进程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/794852

相关文章

C#如何优雅地取消进程的执行之Cancellation详解

《C#如何优雅地取消进程的执行之Cancellation详解》本文介绍了.NET框架中的取消协作模型,包括CancellationToken的使用、取消请求的发送和接收、以及如何处理取消事件... 目录概述与取消线程相关的类型代码举例操作取消vs对象取消监听并响应取消请求轮询监听通过回调注册进行监听使用Wa

[Linux]:进程(下)

✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:Linux学习 贝蒂的主页:Betty’s blog 1. 进程终止 1.1 进程退出的场景 进程退出只有以下三种情况: 代码运行完毕,结果正确。代码运行完毕,结果不正确。代码异常终止(进程崩溃)。 1.2 进程退出码 在编程中,我们通常认为main函数是代码的入口,但实际上它只是用户级

java 进程 返回值

实现 Callable 接口 与 Runnable 相比,Callable 可以有返回值,返回值通过 FutureTask 进行封装。 public class MyCallable implements Callable<Integer> {public Integer call() {return 123;}} public static void main(String[] args

C#关闭指定时间段的Excel进程的方法

private DateTime beforeTime;            //Excel启动之前时间          private DateTime afterTime;               //Excel启动之后时间          //举例          beforeTime = DateTime.Now;          Excel.Applicat

linux中使用rust语言在不同进程之间通信

第一种:使用mmap映射相同文件 fn main() {let pid = std::process::id();println!(

Golang进程权限调度包runtime

关于 runtime 包几个方法: Gosched:让当前线程让出 cpu 以让其它线程运行,它不会挂起当前线程,因此当前线程未来会继续执行GOMAXPROCS:设置最大的可同时使用的 CPU 核数Goexit:退出当前 goroutine(但是defer语句会照常执行)NumGoroutine:返回正在执行和排队的任务总数GOOS:目标操作系统NumCPU:返回当前系统的 CPU 核数量 p

如何保证android程序进程不到万不得已的情况下,不会被结束

最近,做一个调用系统自带相机的那么一个功能,遇到的坑,在此记录一下。 设备:红米note4 问题起因 因为自定义的相机,很难满足客户的所有需要,比如:自拍杆的支持,优化方面等等。这些方面自定义的相机都不比系统自带的好,因为有些系统都是商家定制的,难免会出现一个奇葩的问题。比如:你在这款手机上运行,无任何问题,然而你换一款手机后,问题就出现了。 比如:小米的红米系列,你启用系统自带拍照功能后

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位 一、背景二、定位问题三、解决方法 一、背景 flume系列之:定位flume没有关闭某个时间点生成的tmp文件的原因,并制定解决方案在博主上面这篇文章的基础上,在机器内存、cpu资源、flume agent资源都足够的情况下,flume agent又出现了tmp文件无法关闭的情况 二、

C++编程:ZeroMQ进程间(订阅-发布)通信配置优化

文章目录 0. 概述1. 发布者同步发送(pub)与订阅者异步接收(sub)示例代码可能的副作用: 2. 适度增加缓存和队列示例代码副作用: 3. 动态的IPC通道管理示例代码副作用: 4. 接收消息的超时设置示例代码副作用: 5. 增加I/O线程数量示例代码副作用: 6. 异步消息发送(使用`dontwait`标志)示例代码副作用: 7. 其他可以考虑的优化项7.1 立即发送(ZMQ_IM

[轻笔记] ubuntu Shell脚本实现监视指定进程的运行状态,并能在程序崩溃后重启动该程序

根据网上博客实现,发现只能监测进程离线,然后对其进行重启;然而,脚本无法打印程序正常状态的信息。自己通过不断修改测试,发现问题主要在重启程序的命令上(需要让重启的程序在后台运行,不然会影响监视脚本进程,使其无法正常工作)。具体程序如下: #!/bin/bashwhile [ 1 ] ; dosleep 3if [ $(ps -ef|grep exe_name|grep -v grep|