首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

操作系统进程调度实验报告心得_进程的管理和控制实验报告

题目要求 一、 实验目的 多道程序设计中,经常是若干个进程同时处于就绪状态,必须依照某种策略来决定那个进程优先占有处理机。因而引起进程调度。...优先权法、轮转法 简化假设 1) 进程为计算型的(无I/O) 2) 进程状态:ready、running、finish 3) 进程需要的CPU时间以时间片为单位确定 2....两种调度算法 实验报告 1.实验目的 多道程序设计中,经常是若干个进程同时处于就绪状态,必须依照某种策略来决定那个进程优先占有处理机。因而引起进程调度。...优先权法、轮转法 简化假设 1) 进程为计算型的(无I/O) 2) 进程状态:ready、running、finish 3) 进程需要的CPU时间以时间片为单位确定 2....id self.status = status # 进程状态 self.weight = weight # 进程状态优先权重 self.needTime = needTime # 进程需要的时间片

5.9K20

操作系统实验一进程管理实验报告(进程的管理和控制实验报告)

实验一 进程管理 1.目的和要求 通过实验理解进程的概念,进程的组成(PCB结构),进程的并发执行和操作系统进行进程管理的相关原语(主要是进程的创建、执行、撤消)。...2.实验内容 用C语言编程模拟进程管理,至少要有:创建新的进程;查看运行进程;换出某个进程;杀死运行进程以及进程之间通信等功能。...3.实验环境 Windows操作系统、VC++6.0 C语言 4.实验提示 PCB结构通常包括以下信息:进程名,进程优先数,轮转时间片,进程所占用的CPU时间,进程的状态,当前队列指针等。...实验要求: 上机前认真使用C语言编写好程序,采用Visual C++6.0作为编译环境; 上机时独立调试程序 根据具体实验要求,填写好实验报告(包括目的和要求、实验内容、实验环境、设计思想、源程序、实例运行结果...、总结) 实验报告代码: #include "stdio.h" #include "conio.h" #include "stdlib.h" struct PCB_type { int pid;

1.8K41
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linux进程控制——Linux进程等待

    前言:接着前面进程终止,话不多说我们进入Linux进程等待的学习,如果你还不了解进程终止建议先了解: Linux进程终止 本篇主要内容: 什么是进程等待 为什么要进行进程等待 如何进程等待...进程等待的概念: 我们通常说的进程等待其实是通过wait/waitpid的方式,让父进程(一般)对子进程进行资源回收的等待过程,父进程必须等待这个子进程结束后,处理它的代码和数据! 2....进程等待必要性: 若子进程退出,而父进程对它不管不顾,就可能造成‘僵尸进程’的问题,进而造成内存泄漏。...父进程创建子进程的目的是为了让子进程协助自己完成任务的,而父进程需要知道子进程将任务完成得如何。这就需要通过进程等待的方式,获取子进程的退出信息。 3....,进程控制马上就到了我们的最后一步——进程替换,让我们来期待下一篇!

    12310

    Linux进程控制——Linux进程终止

    前言:前面了解完前面的Linux进程基础概念后,我们算是解决了Linux进程中的一大麻烦,现在我们准备更深入的了解Linux进程——Linux进程控制!...我们主要介绍的Linux进程控制内容包括:进程终止,进程等待与替换,进程程序替换! 本篇主要内容: 重识进程创建 进程退出场景 错误码和退出码 1....重识进程创建 1.1 fork函数 在我们之前提到过,创建进程使用的是fork函数,它从已存在进程中创建一个新进程。新进程为子进程,而原进程为父进程。...#include pid_t fork(void); // 返回值:自进程中返回0,父进程返回子进程id,出错返回-1 进程调用fork,当控制转移到内核中的fork代码后,...exit终止进程的时候,不会自动刷新缓冲区 总结 进程终止相对于其他的进程控制来说,是很好理解的。我们主要介绍了进程终止,在明白错误码和退出码之后,相信能理解父进程是怎么得到子进程信息的。

    11810

    【Linux】进程控制

    【Linux】进程控制 1、进程创建 在Linux中创建进程的话通常也就两种方式,一个方法是创建可执行程序,然后通过我们的./的操作让进程创建。...所以进程调用到fork的时候内核就需要这样做, 1、分配新的内存块和内核数据结构给子进程 2、将父进程的部分数据结构内容拷贝至子进程 3、添加子进程到系统进程列表中 4、fork返回,开始调度器调度...所以这样的进程拥有独立性的特点。 也是一个进程崩溃不影响另一个的原因。 所以为什么父进程返回的是子进程的PID,子进程的返回时0?...因为父进程得到子进程的PID的话,就能够尽可能方便管理,控制子进程,包括后续的杀掉进程,回收进程。...本质就是子进程让父进程放在自己的等待队列中,让状态设置为S状态,当子进程全部调度结束的时候,再把父进程放出,在开始执行父进程。

    7110

    Linux进程控制

    Linux进程简介 进程是操作系统中的一个重要概念,它是一个程序的一次执行过程,程序是进程的一种静态描述,系统中运行的每一个程序都是在它的进程中运行的。...进程4要素 要有一段程序供该进程运行 进程专用的系统堆栈空间 进程控制块(PCB),具体实现是task_struct结构 有独立的存储空间 Linux系统中所有的进程是相互联系的,除了初始化进程外,所有进程都有一个父进程...新的进程不是被创建,而是被复制,或是从以前的进程复制而来。Linux中所有的进程都是由一个进程号为1的init进程衍生而来的。...(守护进程):Linux启动时启动的进程,并在后台运行 进程控制块 在Linux中,每个进程在创建时都会被分配一个数据结构,称为进程控制块(PCB, Process Control Block),描述进程的运动变化过程...通过ps命令可以查看系统中目前有多少进程正常运行 通过ps-aux命令可以查看每个进程的详细信息 进程控制的相关函数 fork()函数 系统调用fork()函数派生一个进程,函数原型为: #include

    2K30

    Linux进程控制

    今天,我们要开始学习新的内容了--->进程控制,进程控制涉及到操作系统如果管理和控制运行在计算机系统内的进程。...我们将从fork函数,Linux进程退出,Linux进程等待,Linux进程替换等方面学习。那么接下来我们就开始敲黑板了!! fork函数 话不多说,上码!!...,wer:%d,&wer:%p\n", wer, &wer); sleep(3); } } return 1; } 在Linux上浅浅运行一下:...人亦如此,进程亦如此,所以父进程返回子进程的pid,子进程只需要返回0即可!! 3.问题三 返回的本质就是写入,所以谁先返回,谁就先写入fd。...fork常见用法 一个父进程希望复制自己,使父子进程同时执行不同的代码段。例如,父进程等待客户端请求,生成子进程来处理请求。 个进程要执行一个不同的程序。

    9510

    【Linux】进程控制

    理解父进程返回pid,给子进程返回0 父亲只有一个,孩子可以有多个,这是现实的问题,孩子找父亲具有唯一性 所以给父进程返回子进程pid便于标识子进程这很好解释了父进程返回pid的问题 同一个id...进程为什么要等待 1.父进程通过进程等待的方式,回收子进程资源 2.获取子进程退出信息 进程等待的方法 wait 返回值:成功返回被等待进程pid,失败返回-1。...若正常结束,则返回该子进程的ID 对应的错误: 僵尸进程退出的时候对应信息放在哪: 子进程和父进程有对应的pcb信息,父进程调用waitpid,子进程退出的时候把对应的代码和信号保存起来,保存到...但是,对于获得子进程的退出结果,我们可以不采用位操作进行,Linux提供了对应操作的宏 WIFEXITED(status): 若为正常终止子进程返回的状态,则为真。...execl系列函数将程序加载到内存中,所以Linux的execl接口是加载器,所以是先加载后执行,main也是函数也要被调用,通过execl/系统传参给main 程序替换中execve是系统调用,其他都是封装

    20030

    Linux进程控制

    进程控制 fork函数 进程终止 退出码 常见的退出方式 进程等待 什么是进程等待,为什么要进程等待 阻塞与非阻塞 进程替换 替换原理 替换函数 执行系统命令 执行自己写的程序 模拟实现简易的shell...进程拥有独立性,fork之后就变成了两个程序,父子进程共享后边的代码。 那么为什么给父进程返回的就是子进程的pid,而给子进程返回的就是0呢?...进程等待 什么是进程等待,为什么要进程等待 之前说过僵尸进程会导致内存泄漏,因为他的资源无法回收,所以就需要等待子进程结束然后来保存资源给父进程,通过获取子进程退出信息知道是否成功退出。...但是如果让我们自己去求信号和退出码很麻烦,所以Linux提供了一些操作的宏,重点说两个: WIFEXITED(status): 若为正常终止子进程返回的状态,则为真。...是先调用exec函数,因为它的作用上面说了,是将程序加载到内存中,Linux中,它就是加载器。

    2.9K00

    Linux进程控制——Linux进程程序替换

    前言:Linux进程控制包含了进程终止,进程等待,进程程序替换。走到现在我们也只剩下进程程序替换没介绍了,那么让我们来看看进程程序替换到底是什么!...本篇主要内容: 替换原理 替换函数 实现简易shell 我们所创建的所有的子进程,执行的代码,都是父进程代码的一部分,如果我们想让子进程执行新的程序,执行全新的代码和访问全新的数据,不在和父进程有瓜葛这就要用到我们的进程替换了...当进程调用一种exec函数时,该进程的用户空间代码和数据完全被新程序替换,从新程序的启动例程开始执行。调用exec并不创建新进程,所以调用exec前后该进程的id并未改变。.../usr/bin/bash echo "hello Linux" echo "hello world" touch code // test.c int main() { printf("pid...总结 进程程序替换能够让我们只用C语言就可以调用其他任何语言去执行,极大程度上带来了便利,也可以帮助我们完成很多任务,好了,关于Linux进程控制我们先了解到这,下次我们将进入新的章节!

    9910

    【Linux】————进程控制

    我们可以得出以下的结论: 变量的内容不一样,父子进程绝对不是输出的同一个变量 但地址值是一样的,说明这个地址绝对不是物理地址 在Linux下,这种地址叫做虚拟地址 我们在C/C++中看到的地址,...二、进程创建: 1.作者主页 在linux中fork函数时非常重要的函数,它从已存在进程中创建一个新进程。新进程为子进程,而原进程为父进程。 ​...进程调用fork,当控制转移到内核中的fork代码后,内核做: ​ 当一个进程调用fork之后,就有两个二进制代码相同的进程。而且它们都运行到相同的地方。...实际用户的进程数超过了限制。 三、进程终止 1.进程终止的概念 ​ main 函数的返回值可以被父进程获取的,用来判断子进程的干活的情况 。 ​...如,子进程运行完成,结果对还是不对,或者是否正常退出。 父进程通过进程等待的方式,回收子进程资源,获取子进程退出信息。

    13010

    【Linux】进程控制

    今日更新了Linux的进程控制的内容 欢迎大家关注点赞收藏⭐️留言 fork函数初识 在linux中fork函数时非常重要的函数,它从已存在进程中创建一个新进程。...新进程为子进程,而原进程为父进程。...#include pid_t fork(void); //返回值:子进程中返回0,父进程返回子进程id,出错返回-1 进程调用fork,当控制转移到内核中的fork代码后,内核做:...分配新的内存块和内核数据结构给子进程 将父进程部分数据结构内容拷贝至子进程 添加子进程到系统进程列表当中 fork返回,开始调度器调度 当一个进程调用fork之后,就有两个二进制代码相同的进程。...但每个进程都将可以 开始它们自己的旅程。 fork 函数返回值 子进程返回0, 父进程返回的是子进程的pid。 为什么父进程返回的是子进程的pid?

    12110

    Linux进程控制

    1.进程创建 1.1.fork()函数常规用法 一个父进程希望复制自己,使父子进程同时执行不同的代码段。例如,父进程等待客户端请求,生成子进程来处理请求。 一个进程要执行一个不同的程序。...3.进程等待 3.1为什么要进行进程等待 1.需要父进程去回收子进程的资源(内存空间),如果子进程结束了,需要父进程去回收空间,否则子进程就会变成僵尸进程,造成内存泄漏。...2.一般来说,进程都会有一个目的,进程等待就可以让父进程得到子进程的运行结果。...进程具有独立性:每个进程都有自己的地址空间,意味着每个进程只能访问自己的内存区域,而不能访问其他进程的内存区域,所以子进程进行程序替换,只会改变自己的地址空间的内容,不会影响到父进程的地址空间。...exec函数的行为:仅在调用它的进程中生效,而不会影响到父进程。由于exec函数是在子进程中调用的,因此只有子进程的映像被替换,父进程的映像保持不变,父进程继续执行其后续代码。

    9810

    Linux进程控制

    一.进程创建 fork()函数: 在进程概念这篇文章中,我们浅浅地了解了一下fork函数,它的功能是让父进程去创建一个子进程,并且有两个返回值,对应着父进程的返回值和子进程的返回值。...在linux中fork函数时非常重要的函数,它从已存在进程中创建一个新进程。新进程为子进程,而原进程为父进程。...0,父进程返回子进程id?...进程终止就到这。接下来我们来谈谈进程等待。 三、进程等待 进程等待可以解决僵尸进程问题。...代码和数据加载到内存的操作,其实就是操作系统调用了exec*函数完成的,所以在Linux的系统中,exec*是加载器。exec*函数的功能就是将程序加载到内存嘛,这是谈的第一点。

    2.4K30

    【Linux】进程控制

    一、进程创建 我们在前面的文章中多次使用过fork函数,我们在这里再来简单概括一下进程的创建 fork可以在已有的进程中创建出一个新进程,老进程为父进程,新进程为子进程 #include pid_t fork(void); //在父进程中返回子进程id,在子进程中返回0,出错返回-1 进程调用fork,当控制转移到内核中的fork代码后,内核分配新的内存块和内核数据结构给子进程,然后将父进程部分数据结构内容拷贝至子进程...,这部分内容很多给到信号部分详细解释 三、进程等待 1、必要性 子进程退出,如果父进程不做处理,那么子进程就会成为僵尸进程,进而造成内存泄漏的问题,并且如果进程一旦成为僵尸进程,就无法被杀死,因为它不再运行...,子进程还没有跑完,那么父进程就进入了阻塞等待,需要先等子进程跑完自己才能跑,这样大大降低了效率,我们可以根据最后一个选项的作用,做到进程的非阻塞等待 (1)进程的阻塞等待方式 在子进程跑的时候父进程在阻塞等待...wait、waitpid 等系统调用进行读取,待父进程成功获取这些退出信息后,系统才会对该 PCB 进行销毁操作,释放其占用的内核资源 四、进程程序替换 1、替换原理 每个进程在 Linux 系统中都有一个进程地址空间

    2400

    linux进程控制

    ,然后给这个子进程拷贝一份父进程的数据,接着把这个子进程添加到我们系统的进程列表里面,最后是使用调度器进行调度; 2.2fork的返回值 子进程返回0 父进程返回子进程的pid,所以这个函数的调用的时候会有两个返回值...,然后把这个修改的数据在物理内存上面开辟新的空间,对应的这个子进程的页表上面的只读的标签也会被去掉; 2.4调度器的调度 当我们的一个父进程对应多个子进程的时候,这个子进程的执行顺序我们是没有办法进行控制的...2759,2760说明两次调用的时候都是作为父进程,因为父进程调用fork函数,返回这个子进程的pid,子进程的返回值是0,如果不是0,说明这个是父进程,我们对照发现这个只有A进程两次调用的时候都是作为父进程的...,因此第一个结果是A进程的; 第3个结果,第一次作为子进程打印0,第二次作为父进程打印2761,我们对比发现这个应该是进程B,因为这个进程B第一次作为子进程,第二次作为父进程的; 第二个结果,2759和...0,按照道理应该是第一次作为父进程,第二次作为子进程,但是这个时候我们发现并没有这个符合要求的进程,但是实际上这个是C进程,因为这个C进程第二次是作为子进程,打印0是没有问题的,但是第一次他是作为父进程的吗

    5410

    【Linux】进程控制

    1. fork函数写时拷贝的理解 若父子进程数据都不修改,则父子进程指向同一个物理地址, 若子进程数据修改,则拷贝一个物理空间,将新的地址填到子进程对应的页表中,使子进程重新映射,访问到新的空间 进程的内核数据结构...进程终止 情况分类 正常执行分为 结果正确, 结果不正确 崩溃了(进程异常) 崩溃的本质:进程因为某些原因,导致进程收到来自操作系统的信号(具体后面解释) 结果对的时候,不会关心过程,但是结果不对,就会关心过程...进程等待 如果子进程变成僵尸状态,使用父进程接收子进程的进程退出码, 父进程通过进程等待的方式,回收子进程资源,获取子进程信息 子进程的运行结果 : 代码跑完,结果对...5秒,再等待5秒后进入父进程,在等待期间子进程处于僵尸状态,父进程将子进程回收,子进程僵尸状态消失,最后再过5秒,父进程退出 复制SSH渠道创建终端2,在保证终端1的mytest可执行程序运行的情况下输入如下指令...12,退出信号为0,表示代码正常 ---- 父进程在wait的时候,如果子进程没有退出呢,父进程在干什么?

    2K20

    【Linux】进程控制

    进程控制 一、进程创建 1. fork 函数创建子进程 在 Linux 中 fork 函数是非常重要的函数,它从已存在进程中创建一个新进程。新进程为子进程,而原进程为父进程。...当进程调用 fork,控制转移到内核中的 fork 代码后,内核应该做: 分配新的内存块(pcb)和内核数据结构(进程地址空间、页表等)给子进程 将父进程部分数据结构内容拷贝至子进程 将子进程添加到系统进程列表当中...但是我们的 Linux 中并不使用系统提供的接口获取退出码的退出原因描述,而是使用自定义的退出原因描述。...首先每个进程 pcb 内部都有内置的等待队列,当父进程在等子进程时,其实就是将父进程的 pcb 链入子进程的等待队列里;当子进程退出时,操作系统就直接从子进程的等待队列里把父进程拿出来,然后调度父进程,...但是我们通过位运算得到的退出信息可读性不是很好,所以 Linux 也为我们提供了两个接口: WIFEXITED(status): 若为正常终止子进程返回的状态,则为真。

    15110

    【Linux】Linux进程控制>进程创建&&进程终止&&进程等待&&进程程序替换

    1.进程创建 1.1 fork函数 在linux中fork函数时非常重要的函数,它从已存在进程中创建一个新进程。...新进程为子进程,而原进程为父进程 #include pid_t fork(void); 返回值:自进程中返回0,父进程返回子进程id,出错返回-1 进程调用fork,当控制转移到内核中的...else if (ret > 0) { // 异常退出 printf("sig code : %d\n", st & 0X7F); } } } 测试结果: [root@localhost linux.../a.out #等20秒退出 child exit code:10 [root@localhost linux]# ....Linux鼓励将这种应用于程序之内的模式扩展到程序之间。如下图 一个C程序可以fork/exec另一个程序,并传给它一些参数。这个被调用的程序执行一定的操作,然后通过exit(n)来返回值。

    16610

    Linux进程控制【进程程序替换】

    ---- 前言 子进程 在被创建后,共享的是 父进程 的代码,如果想实现自己的逻辑就需要再额外编写代码,为了能让 子进程 执行其他任务,可以把当前 子进程 的程序替换为目标程序,此时需要用到 Linux...,将其替换为对应的指令程序并执行任务,就能实现各种指令 进程程序替换图解 Linux 中的指令都是用 C语言 写的可执行程序,所以可以进行替换 bash 运行后,输入 指令 本质上就是在进行程序替换...这就表明程序替换并不是进程替换 因为是同一个进程,所以对父进程没有任何影响,体现了进程间的独立性 在子进程执行程序替换前,子进程和父进程共享一份只读区域的数据,但因为发生了程序替换,触发 写时拷贝 机制...,令子进程读取另一块区域的数据 写时拷贝 在只读数据区也能触发,因为不能影响到父进程 ---- 总结 以上就是本篇关于 Linux 进程程序替换的相关内容了,在本文中,我们知道了进行程序替换的目的,学习使用了程序替换相关的七大函数...,最后还观察了程序替换后的神奇现象,在学完这些知识后,我们就可以实现一个简单的 bash,体验一下在自己程序中输入指令操控 Linux 的奇妙体验 如果你觉得本文写的还不错的话,期待留下一个小小的赞,你的支持是我分享的最大动力

    25920
    领券