Java 进程

本文详细介绍了进程的概念,以C语言为例,阐述了从源代码到可执行程序的过程。进程在Linux中通过PCB(进程控制块)进行管理,使用双向链表组织。PCB包含进程ID、内存指针、文件描述符、状态、优先级、上下文和记账信息。同时,讨论了进程的并行与并发、隔离性和通信方式。
摘要由CSDN通过智能技术生成

1.什么是进程? 以C语言为例 一个程序 想要变成可执行程序 需要经历四个阶段,

即:

        1). 预处理(将包含的头文件全部引入 宏定义全部替换 注释全部删除等)

        2.) 编译(将文本程序转换成汇编程序并检查代码的规范性、是否有语法错误,每个c语言文件都会有一个表格,这个表格中记录了每个函数的名字 以及 参数 和 地址,编译阶段则会将这些表格合在一起,如果函数名重复 但是地址不重复 且 其中一个地址为空 那么会认为不为空的那个地址,就是函数所在的地址,如果两个地址都为空 那么会报错,如果说两个地址都不为空 就是说 有两个相同名的函数 那么也会报错) 

        3.)汇编(将汇编程序转换成二进制文件, 汇编语言 与 机器语言是一 一对应的,每个cpu在出厂的时候 生产商都会发布一款手册 其中指明了 每条机器语言是什么意思,不同cpu的机器语言可能是不一样的 具体取决于生产商,机器语言是直接作用于cpu的)

        4.) 链接(这一过程涉及静态库【如windows下一些dll文件缺失】和动态库,静态库主要在符号重定位阶段,把库中有关代码拷贝进来。而动态库涉及一些调用别人实现的库的函数,不是在自己程序中实现的。此外,静态库在重定位阶段,而动态库链接是在可执行文件装载到内存时,根据依赖关系进行重定位)

2.当一个程序变成 二进制文件后,cpu 就能够读懂这个文件 此时这个二进制文件是趴在硬盘上的,当我们 鼠标双击后,操作系统会帮助我们 把这个二进制文件拿到内存中,并且让cpu 去读取这个文件中的指令,然后程序就会运行,每有一个这样的文件运行 就可以说有了一个 PCB ,也就 进程 的意思.而进程 在linux操作系统中 是用双向链表串起来的,删除一个进程时 就是在双向链表中删除.创建一个进程时 就是在双向链表中添加.

3.PCB 是进程的意思, linux 是 c 语言写的,而PCB 是用c语言中的结构体来描述的,这个结构体中 有一些属性来对应着PCB 例如:

        1.) pid 即 进程的id 也就是进程的身份标识

        2.) 内存指针 即 指明了这个进程要执行的代码在内存的哪里.

        3.) 文件描述符 即 进程每次打开一个文件,就会在文件描述符表上多增加一项.(这个文件描述符表就可以视为一个数组,里面的每个元素又是一个结构体,就对应着一个文件的相关信息),进程只要一启动,不管你代码中是否写了打开/操作文件的代码,都会默认打开的三个文件~~(操作系统自动打开的),即 标准输入(System.in),标准输出(System.out),标准错误(System.err)

        4.) 状态 : 一种是就绪状态,一种是阻塞状态

        5.) 优先级 : 谁的优先级高 就优先给谁安排时间,并且安排的时间更多,甚至优先级高的可以插队.

        6.) 上下文 : 就表示了上次进程被调度出cpu的时候,当时程序的执行状态~~下次进程上cpu的时候,就可以恢复之前的状态,然后继续往下执行. 就相当于是 存档 + 读档~~

        7.) 记账信息 : 统计了每个进程,都分别执行了多久,分别执行了那儿些指令,分别都排队等了多久了....给进程调度提供指导依据的

4.并行和并发

        1.) 并行 微观上我们认为 两个cpu核心 同一时刻 同时执行两个任务的代码

        2.) 并发 微观上 一个cpu核心,先执行一会儿 a 任务,在执行一会儿 b 任务,在执行一会儿 c 任务 以此循环.

5. **********

        1).进程是什么?运行起来的程序就是进程

         2).进程是怎么进行管理的? 描述 + 组织,描述是用c语言里的结构体描述,结构体有很多属性,组织是用 双向链表串起来的,linux 是这样的.

         3).进程里的pcb里有什么?    转移到上方 3. 标题处有解答

         4).进程的调度是怎么进行的?时间管理大师,分别给不同的 进程安排时间,先运行进程1,在运行进程2,在运行进程3,然后循环.

         5).进程之间的 隔离性 是怎么回事? 因为某一个进程可能会出现bug修改了 不属于 自己内存地址的地址,导致其他进程崩溃,所以就需要用虚拟地址,将地址分成很多块不同的内存空间,每个进程之间 保持独立性 互不干扰,这样 进程A 奔溃了 ,进程B并不会有事情.

         6).进程之间如何通信呢? 可以使用网络进行通信,或者使用文件夹进行通讯,总之就是有一块公共空间,每一个进程都能够进行访问读写等操作.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值