操作系统实验报告 进程管理 java编写相关的界面

合集下载

操作系统实验报告 进程管理 java编写相关的界面

操作系统实验报告 进程管理 java编写相关的界面

操作系统实验报告计算机学院(院、系)专业班组课学号20 姓名Tracy 实验日期教师评定实验一进程管理一、实验目的通过实验使学生进一步了解进程、进程状态、进程控制等基本概念。

基本能达到下列具体的目标:1.理解进程 PCB 的概念,以及 PCB 如何实现、如何组织以及管理。

2.复习数据结构中如何对链的操作,包括建链、删除、插入结点等,来实现进程的管理。

二、实验内容1、建立一个结点,即 PCB 块包括用户标识域、状态域(执行、等待、就绪)、 link域。

2、建立三个队列(执行队列、就绪队列、等待队列)。

3、根据进程状态转换实现对三个队列的具体操作。

具体的驱动可以采用时间片算法或手动调度的形式完成三个状态之间的转换4、用java编写相关的界面。

三、实验步骤1.通过java的awt和swing包进行相关界面的布局,相关代码为:Panel p1=new Panel(new FlowLayout(FlowLayout.LEFT));Panel p2=new Panel(new FlowLayout());//三个显示进程的文本框JTextField readyList,runningList,waitingList,input;//三个进程的链表ArrayList<Process> reList=new ArrayList<Process>();ArrayList<Process> ruList=new ArrayList<Process>();ArrayList<Process> waList=new ArrayList<Process>();Iterator<Process> iterRunning,iterReady,iterWaiting;public MyFrame(){this.setLayout(new BorderLayout());this.add(p1,BorderLayout.NORTH);this.add(p2,BorderLayout.CENTER);init();this.setTitle("进程三态转换");setBounds(300,300,500,300);setVisible(true);}void init(){Box box1=Box.createHorizontalBox();box1.add(new JLabel("进程就绪队列:"));readyList=new JTextField(35);readyList.setEditable(false);box1.add(readyList);Box box2=Box.createHorizontalBox();box2.add(new JLabel("进程阻塞队列:"));waitingList=new JTextField(35);waitingList.setEditable(false);box2.add(waitingList);Box box3=Box.createHorizontalBox();box3.add(new JLabel("进程运行队列:"));runningList=new JTextField(35);runningList.setEditable(false);box3.add(runningList);Box baseBox1=Box.createVerticalBox(); baseBox1.add(box1);baseBox1.add(Box.createVerticalStrut(10)); baseBox1.add(box2);baseBox1.add(Box.createVerticalStrut(10)); baseBox1.add(box3);p1.add(baseBox1);Button b1=new Button("执行—>就绪");Button b2=new Button("就绪—>执行");Button b3=new Button("执行—>阻塞");Button b4=new Button("阻塞—>就绪");Button exit=new Button("清空所有进程");this.add(exit,BorderLayout.SOUTH);b1.addActionListener(new readyListener());b2.addActionListener(new runningListener()); b3.addActionListener(new waitingListener()); b4.addActionListener(new ready2Listener()); exit.addActionListener(new clearListener());Box box4=Box.createHorizontalBox();box4.add(b1);box4.add(b2);Box box5=Box.createHorizontalBox();box5.add(b3);box5.add(b4);Box box6=Box.createHorizontalBox();input=new JTextField(20);input.addActionListener(new inputListener());box6.add(new Label("请输入进程名字,按回车确认"));box6.add(input);Box baseBox2=Box.createVerticalBox();baseBox2.add(box6);baseBox2.add(Box.createVerticalStrut(10));baseBox2.add(box4);baseBox2.add(Box.createVerticalStrut(10));baseBox2.add(box5);p2.add(baseBox2);}运行的总体界面如下图所示:图1 总体布局2.分别为“执行—》就绪”,“就绪—》执行”,“执行—》阻塞”,“阻塞—》就绪”四个按钮添加监听器,监听队列的三种状态。

(完整word版)操作系统实验报告实验一进程管理

(完整word版)操作系统实验报告实验一进程管理

实验一进程管理一、目的进程调度是处理机管理的核心内容.本实验要求编写和调试一个简单的进程调度程序。

通过本实验加深理解有关进程控制块、进程队列的概念,并体会和了解进程调度算法的具体实施办法.二、实验内容及要求1、设计进程控制块PCB的结构(PCB结构通常包括以下信息:进程名(进程ID)、进程优先数、轮转时间片、进程所占用的CPU时间、进程的状态、当前队列指针等。

可根据实验的不同,PCB结构的内容可以作适当的增删)。

为了便于处理,程序中的某进程运行时间以时间片为单位计算。

各进程的轮转时间数以及进程需运行的时间片数的初始值均由用户给定。

2、系统资源(r1…r w),共有w类,每类数目为r1…r w.随机产生n进程P i(id,s(j,k),t),0<=i〈=n,0〈=j〈=m,0〈=k〈=dt为总运行时间,在运行过程中,会随机申请新的资源。

3、每个进程可有三个状态(即就绪状态W、运行状态R、等待或阻塞状态B),并假设初始状态为就绪状态.建立进程就绪队列。

4、编制进程调度算法:时间片轮转调度算法本程序用该算法对n个进程进行调度,进程每执行一次,CPU时间片数加1,进程还需要的时间片数减1。

在调度算法中,采用固定时间片(即:每执行一次进程,该进程的执行时间片数为已执行了1个单位),这时,CPU 时间片数加1,进程还需要的时间片数减1,并排列到就绪队列的尾上。

三、实验环境操作系统环境:Windows系统。

编程语言:C#。

四、实验思路和设计1、程序流程图2、主要程序代码//PCB结构体struct pcb{public int id;//进程IDpublic int ra;//所需资源A的数量public int rb; //所需资源B的数量public int rc;//所需资源C的数量public int ntime;//所需的时间片个数public int rtime;//已经运行的时间片个数public char state;//进程状态,W(等待)、R(运行)、B(阻塞)//public int next;}ArrayList hready = new ArrayList();ArrayList hblock = new ArrayList();Random random = new Random();//ArrayList p = new ArrayList();int m,n, r, a,a1,b,b1,c,c1, h = 0, i = 1,time1Inteval;//m为要模拟的进程个数,n为初始化进程个数//r为可随机产生的进程数(r=m-n)//a,b,c分别为A,B,C三类资源的总量//i为进城计数,i=1…n//h为运行的时间片次数,time1Inteval为时间片大小(毫秒)//对进程进行初始化,建立就绪数组、阻塞数组。

Java图形界面实验报告

Java图形界面实验报告

实验报告2013学年第 1 学期任课老师:课程名称Java语言与系统设计班级学号姓名实验名称实验4 图形用户界面(GUI)实验时间实验环境PC/windows2000/2003/XP/Jcreator Pro/JBuild/JDK Eclipse/。

实验目的和内容要求实验4 图形用户界面(GUI)1.实验目的掌握布局管理器的使用,掌握JFrame框架、JButton按钮、JLabel标签、JTextField文本框、对话框等组件的使用及其事件处理。

2.实验内容(1)编程:创建有一个文本框和三个按钮的小程序。

当按下每个按钮时,使不同的文字显示在文本框中。

(2)编程:创建一用户登录界面,接受用户输入的帐号和密码,给三次输入机会。

实验过程记录(学生写出实验步骤及中间的结果与现象,在实验中做了什么,怎么做,发生的现象和中间结果)实验步骤:1.建立一个类继承JFrame,然后初始化界面,给三个按钮添加监听器,点击之后进行判断。

然后根据接收信息是不同的文字出现在文本框中。

2.登录界面共有5个键,登录提示有只能输入3次密码,在登录按钮上添加监听器,每次点击之后都判断,不成功就显示失败,成功就弹出成功弹窗;实验结果分析与总结1、程序运行结果(请提供所完成的各道题运行结果界面截图):2、实验过程中的发现与收获,未解决或需进一步解决的问题:实现的比较简单,界面做的非常简陋,但还算实现了基本功能。

指导老师评阅意见指导老师:***填写内容时,可把表格扩大。

附:实验源程序代码//第一题package com.miao;import java.awt.FlowLayout;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import java.awt.event.WindowAdapter;import java.awt.event.WindowEvent;import javax.swing.JButton;import javax.swing.JFrame;import javax.swing.JPanel;import javax.swing.JTextField;public class Example extends JFrame implements ActionListener { private static final long serialVersionUID = 1L;private JPanel jPanel;private JButton jButton1,jButton2,jButton3;private JTextField tf1;public void test(String title) {init();}private void init() {jPanel=new JPanel();jPanel.setLayout(new FlowLayout());tf1=new JTextField(20);jButton1=new JButton("按钮1");jButton2=new JButton("按钮2");jButton3=new JButton("按钮3");jButton1.addActionListener(this);jButton2.addActionListener(this);jButton3.addActionListener(this);jPanel.add(tf1);jPanel.add(jButton1);jPanel.add(jButton2);jPanel.add(jButton3);this.add(jPanel);this.setSize(300,100);this.setResizable(false);this.setTitle("Show");this.setVisible(true);this.addWindowListener(new WindowAdapter() {public void windowClosing(final WindowEvent e) {System.exit(0);}});}public void actionPerformed(ActionEvent e) {if(e.getSource().equals(jButton1)){tf1.setText("lalalalalala");}if(e.getSource().equals(jButton2)){tf1.setText("heihei");}if(e.getSource().equals(jButton3)){tf1.setText("gaga");}}public static void main(String[] args){String s="文字转化";Example test=new Example();test.test(s);}}//第二题,登录package com.miao;import java.awt.HeadlessException;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import javax.swing.JButton;import javax.swing.JFrame;import javax.swing.JLabel;import javax.swing.JOptionPane;import javax.swing.JPanel;import javax.swing.JPasswordField;import javax.swing.JTextField;@SuppressWarnings("serial")public class Test extends JFrame {JLabel lbl1 = new JLabel("用户名:");JLabel lbl2 = new JLabel("密码:");JTextField txt = new JTextField("admin",20);JPasswordField pwd = new JPasswordField(20);JButton btn = new JButton("登录");JPanel pnl = new JPanel();private int error = 0;public void text() throws HeadlessException {init();}private void init() {this.setResizable(false);this.setTitle("测试");pnl.add(lbl1);pnl.add(txt);pnl.add(lbl2);pnl.add(pwd);pnl.add(btn);this.getContentPane().add(pnl);btn.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent e) {if (error<3&&"123".equals(new String(pwd.getPassword()))){// pnl.removeAll();// JLabel lbl3 = new JLabel();// pnl.add(lbl3);JOptionPane.showMessageDialog(null,"登陆成功!");}else if(error < 3){JOptionPane.showMessageDialog(null,"密码输入错误,请再试一次");error++;}else if(error >=3){JOptionPane.showMessageDialog(null,"对不起,您不是合法用户"); // txt.setEnabled(false);// pwd.setEnabled(false);// btn.setEnabled(false);error++;}}});}public static void main(String[] args) {// String str="测试";Test frm = new Test();frm.text();frm.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);frm.setBounds(100, 100, 300, 120);frm.setVisible(true);frm.setLocationRelativeTo(null);// frm.text("测试");}}。

操作系统实验报告----进程管理

操作系统实验报告----进程管理

实验内容:进程管理一、实验目的1、掌握Linux中进程的创建方法及执行情况;2、加深对进程、进程树等概念的理解;3、掌握Linux中如何加载子进程自己的程序;4、掌握父进程通过创建子进程完成某项任务的方法;5.、掌握系统调用exit()和_exit()调用的使用。

6、分析进程竞争资源的现象,学习解决进程互斥的方法;进一步认识并发执行的实质二、实验内容(一)进程的创建1、编写一段程序,使用系统调用fork( )创建两个子进程。

当此程序运行时,在系统中有一个父进程和两个子进程活动。

让每一个进程在屏幕上显示一个字符。

#include<stdio.h>main(){int p,x;p=fork();if(p>0){x=fork();if(x>0)printf("father\n");elseprintf("child2");}elseprintf("child1");}输出结果:child1child2father2、运行以下程序,分析程序执行过程中产生的进程情况。

#include <stdio.h>main(){int p,x;p=fork();if (p>0)fork();else{fork();fork();}sleep(15);}实验步骤:编译连接gcc –o forktree forktree.c后台运行./forktree &使用pstree –h 查看进程树运行结果:├─gnom e-terminal─┬─bash─┬─forktree─┬─forktree─┬─forkt ree───forktree││││└─forktree│││└─forktree││└─pstree 分析:程序运行,系统首先创建一个进程forktree,执行到p=fork()创建一个子进程forktree,子进程获得处理机优先执行,父进程等待;执行else,当执行到第一个fork()函数时,子进程创建了一个进程forktree,称之为孙进程,孙进程获得处理机往下执行,子进程等待;执行到第二个fork()函数时,孙进程又创建一个进程forktree,称之为重孙进程,重孙进程很快执行完,将处理机还给孙进程,孙进程很快执行完,将处理机还给子进程;子进程继续往下执行,执行到第二个fork()函数,又创建一个进程forktree,称之为第二孙进程,并获得处理机执行,此进程很快执行完,将处理机还给子进程,子进程也很快执行完,将处理机还给父进程,父进程P>0执行if语句,运行fork()函数,又创建一个进程forktree,称之为第二子进程,此进程获得处理机执行很快运行完,将处理机还给父进程,父进程运行sleep(15)语句,休眠15秒,用pstree命令查询进程树。

java实验报告

java实验报告

java实验报告Java 实验报告一、实验目的本次 Java 实验的主要目的是通过实际编程操作,深入理解和掌握Java 语言的基本语法、面向对象编程的概念和方法,以及常用类库的使用。

同时,培养我们的问题解决能力、逻辑思维能力和代码规范意识,为今后的软件开发工作打下坚实的基础。

二、实验环境1、操作系统:Windows 102、开发工具:Eclipse IDE for Java Developers3、 JDK 版本:JDK 18三、实验内容本次实验共包括以下三个部分:1、 Java 基本语法练习变量与数据类型运算符与表达式控制流语句(ifelse、for、while、dowhile)数组2、面向对象编程实践类与对象的定义和使用构造函数与方法重载封装、继承与多态抽象类与接口3、 Java 常用类库应用String 类与字符串操作集合框架(ArrayList、HashMap)文件输入输出(File、FileReader、FileWriter)四、实验步骤及代码实现1、 Java 基本语法练习变量与数据类型:```javapublic class VariableDataType {public static void main(String args) {int age = 20;double salary = 50005;String name ="张三";boolean isStudent = true;Systemoutprintln("年龄:"+ age);Systemoutprintln("工资:"+ salary);Systemoutprintln("姓名:"+ name);Systemoutprintln("是否是学生:"+ isStudent);}}```运算符与表达式:```javapublic class OperatorExpression {public static void main(String args) {int num1 = 10;int num2 = 5;int sum = num1 + num2;int difference = num1 num2;int product = num1 num2;int quotient = num1 / num2;int remainder = num1 % num2; Systemoutprintln("和:"+ sum);Systemoutprintln("差:"+ difference);Systemoutprintln("积:"+ product);Systemoutprintln("商:"+ quotient);Systemoutprintln("余数:"+ remainder);}}```控制流语句:```javapublic class ControlFlowStatement {public static void main(String args) {// ifelse 语句int score = 80;if (score >= 90) {Systemoutprintln("优秀");} else if (score >= 80) {Systemoutprintln("良好");} else if (score >= 70) {Systemoutprintln("中等");} else if (score >= 60) {Systemoutprintln("及格");} else {Systemoutprintln("不及格");}// for 循环for (int i = 1; i <= 5; i++){Systemoutprintln("第" + i +"次循环");}// while 循环int j = 1;while (j <= 5) {Systemoutprintln("第" + j +"次 while 循环");j++;}// dowhile 循环int k = 1;do {Systemoutprintln("第" + k +"次 dowhile 循环");k++;} while (k <= 5);}}```数组:```javapublic class ArrayExample {public static void main(String args) {//一维数组int numbers ={1, 2, 3, 4, 5};for (int num : numbers) {Systemoutprintln(num);}//二维数组int matrix ={{1, 2, 3},{4, 5, 6},{7, 8, 9}};for (int row : matrix) {for (int num : row) {Systemoutprint(num +"");}Systemoutprintln();}}}```2、面向对象编程实践类与对象的定义和使用:```javapublic class Person {private String name;private int age;public Person(String name, int age) {thisname = name;thisage = age;}public void showInfo(){Systemoutprintln("姓名:"+ name +",年龄:"+ age);}public static void main(String args) {Person person1 = new Person("张三", 20);person1showInfo();}}```构造函数与方法重载:```javapublic class ConstructorOverloading {private String name;private int age;public ConstructorOverloading(String name) {thisname = name;}public ConstructorOverloading(String name, int age) {thisname = name;thisage = age;}public void showInfo(){if (age == 0) {Systemoutprintln("姓名:"+ name);} else {Systemoutprintln("姓名:"+ name +",年龄:"+ age);}}public static void main(String args) {ConstructorOverloading person1 = new ConstructorOverloading("张三");person1showInfo();ConstructorOverloading person2 = new ConstructorOverloading("李四", 25);person2showInfo();}}```封装、继承与多态:```java//父类class Animal {private String name;public Animal(String name) {thisname = name;}public void eat(){Systemoutprintln(name +"正在吃东西");}}//子类继承父类class Dog extends Animal {public Dog(String name) {super(name);}public void bark(){Systemoutprintln(name +"在叫");}}public class InheritancePolymorphism {public static void main(String args) {Animal animal = new Dog("小黑");animaleat();//向下转型为 Dog 类型调用 bark 方法if (animal instanceof Dog) {Dog dog =(Dog) animal;dogbark();}}}```抽象类与接口:```java//抽象类abstract class Shape {abstract void draw();}//实现抽象类的子类class Circle extends Shape {@Overridevoid draw(){Systemoutprintln("画一个圆");}}//接口interface Moveable {void move();}//实现接口的类class Car implements Moveable {@Overridepublic void move(){Systemoutprintln("汽车在移动");}}public class AbstractInterfaceExample {public static void main(String args) {Shape shape = new Circle();shapedraw();Moveable car = new Car();carmove();}}```3、 Java 常用类库应用String 类与字符串操作:```javapublic class StringOperation {public static void main(String args) {String str1 ="Hello, ";String str2 ="World!";String str3 = str1 + str2;Systemoutprintln(str3);int length = str3length();Systemoutprintln("字符串长度:"+ length);char charAt = str3charAt(5);Systemoutprintln("第 5 个字符:"+ charAt);boolean contains = str3contains("World");Systemoutprintln("是否包含 World:"+ contains);}}```集合框架(ArrayList、HashMap):```javaimport javautilArrayList;import javautilHashMap;import javautilMap;public class CollectionFramework {public static void main(String args) {// ArrayListArrayList<String> names = new ArrayList<>();namesadd("张三");namesadd("李四");namesadd("王五");for (String name : names) {Systemoutprintln(name);}// HashMapHashMap<String, Integer> ages = new HashMap<>();agesput("张三", 20);agesput("李四", 25);agesput("王五", 30);for (MapEntry<String, Integer> entry : agesentrySet()){Systemoutprintln(entrygetKey()+"的年龄是" +entrygetValue());}}}```文件输入输出(File、FileReader、FileWriter):```javaimport javaioFile;import javaioFileReader;import javaioFileWriter;import javaioIOException;public class FileIOExample {public static void main(String args) {//写入文件try (FileWriter writer = new FileWriter("outputtxt")){writerwrite("这是写入文件的内容");} catch (IOException e) {eprintStackTrace();}//读取文件try (FileReader reader = new FileReader("outputtxt")){int character;while ((character = readerread())!=-1) {Systemoutprint((char) character);}} catch (IOException e) {eprintStackTrace();}}}```五、实验结果与分析1、 Java 基本语法练习变量与数据类型:能够正确定义和使用各种数据类型的变量,并进行基本的运算和输出。

操作系统进程管理实验报告

操作系统进程管理实验报告

操作系统进程管理实验报告一、引言在现代计算机科学中,操作系统的进程管理是确保系统高效运行的关键环节。

本实验旨在通过观察和分析操作系统的进程管理行为,深入理解进程的创建、运行和终止过程,以及操作系统如何对进程进行调度和资源分配。

二、实验目标1、理解进程的基本概念、进程状态及转换。

2、掌握进程的创建、终止和调度方法。

3、观察和分析进程在运行过程中的资源消耗和调度行为。

4、分析操作系统对进程的资源分配和调度策略对系统性能的影响。

三、实验环境与工具本实验在Linux操作系统上进行,使用GNU/Linux环境下的工具进行进程的创建、监控和调度。

四、实验步骤与记录1、创建进程:使用shell命令“fork”创建一个新的进程。

记录下父进程和子进程的PID,以及它们在内存中的状态。

2、进程状态观察:使用“ps”命令查看当前运行进程的状态,包括进程的PID、运行时间、CPU使用率等。

同时,使用“top”命令实时监控系统的CPU、内存等资源的使用情况。

3、进程调度:在“crontab”中设置定时任务,观察系统如何根据预设的调度策略分配CPU资源给各个进程。

4、资源分配:通过修改进程的优先级(使用“nice”命令),观察系统如何调整资源分配策略。

5、终止进程:使用“kill”命令终止一个进程,并观察系统如何处理该进程占用的资源。

五、实验结果与分析1、创建进程:通过“fork”系统调用,成功创建了一个新的进程,并获取了父进程和子进程的PID。

在内存中,父进程和子进程的状态分别为“running”和“ready”。

2、进程状态观察:使用“ps”命令可以看到父进程和子进程的状态均为“running”,同时显示了它们的CPU使用率和运行时间等信息。

通过“top”命令,可以实时监控系统的CPU、内存等资源的使用情况,为进一步分析提供了数据支持。

3、进程调度:在“crontab”中设置定时任务后,系统会根据预设的调度策略以及各个进程的运行状态,动态地分配CPU资源给各个进程。

操作系统实验之进程管理实验报告

操作系统实验之进程管理实验报告
六、自我评价与总结
本次操作系统实验是模拟进程管理过程,解决哲学家的就餐问题。个人本 次实验还比较顺利,使用了比较熟悉的 c++语言进行算法的编写,比较巧妙的 定义了两个类来定义哲学家和筷子对象的属性以及相应的动作,方便在各种就 餐过程中对筷子的资源进行申请和释放,以及哲学家实现相应的动作。另一个 觉得比较好的地方是解决了死锁问题,通过判断当前哲学家是否可以同时拿起 左右筷子来避免死锁。
①至多只允许四个哲学家同时进餐,以保证至少有一个哲学家可以进餐,
最终总会释放出他所用过的两只筷子,从而可使更多的哲学家进餐;
②仅当左右两只筷子均可用时,才允许哲学家拿起筷子就餐;
③规定奇数号哲学家先拿起右边筷子,然后再去拿左边筷子,而偶数号哲
学家则相反。
本实验中采取方法 2.
三、数据结构及功能设计
}; bool b[5]; int i, j; srand(time(0)); j = rand() % 5; for (i = j; i < j + 5; i++) {
b[i % 5] = philosopher[i % 5].eat(); cout << endl << "********************************************************" << endl; } for (i = j; i < j + 5; i++) { if (b[i % 5]) {
五、测试用例及运行结果、分析
测试结果截图:
分析:产生了一个随机数 0,并依次加 1 对每个哲学家进行分析。分析时首先看 左筷子是否可用,然后看右筷子,若有一个不可用则放下手中的另一只筷子,并 说明 need waiting。然后再下一时间段对每个哲学家再次分析,直到每个哲学 家都吃上饭,程序结束。 通过实验结果可得,程序正确运行,且解决了死锁问题。

实验二-实验报告(进程管理)

实验二-实验报告(进程管理)

实验二模拟实现进程管理组长:李和林软件1402一、实验目的1.理解进程的概念,明确进程和程序的区别。

2.理解并发执行的实质。

3.掌握进程的创建,睡眠,撤销等进程控制方法。

二、实验内容用C语言,JAVA语言,C++语言编写程序,模拟实现创建新的进程;查看运行进程,换出某个进程;杀死运行进程。

三、实验准备1.进程的定义进程是程序在一个数据集合上的运行过程,是系统资源分配和调度的一个独立单位。

一个程序在不同的数据集合上运行,乃至一个程序在同样数据集合上的多次运行都是不同的进程。

2.进程的状态通常情况下,一个进程必须具有就绪,执行和阻塞三种基本情况。

1)就绪状态当进程已分配到除处理器外的所有必要资源后,只要再获得处理器就可以立即执行,这时进程的状态就为就绪状态。

在一个系统里,可以有多个进程同时处于就绪状态,通常把这些就绪进程排成一个或多个队列,称为就绪队列。

2)执行状态处于就绪状态的进程一旦获得处理器,就可以运行,进程状态也就处于执行状态,在单处理器系统中,只能有一个进程处于执行状态,在多处理器系统中,则可能有多个进程处于执行状态3)阻塞状态正在执行的进程因为发生某些事件而暂停运行,这种受阻暂停的状态称为阻塞状态,也可称为等待状态。

通常将处于阻塞状态的进程拍成一个队列,称为阻塞队列,在有些系统中,也会按阻塞原因的不同将阻塞状态的进程排成多个队列。

3.进程状态之间的转换4.进程控制块1)进程控制块的作用进程控制块是进程实体的重要组成部分,主要包含下述四个方面的信息:a)进程标示信息b)说明信息c)现场信息d)管理信息5.进程控制块的组织方式1)链接方式2)索引方式6.进程控制原语1)创建原语2)撤销原语3)阻塞原语4)唤醒原语7.程序代码#include<stdio.h>#include<iostream>using namespace std;void clrscr();void create();void run( );void exchange( );//唤出void kill( );void wakeUp( );//唤醒struct process_type{int pid;int priority;//优先次序int size;int state;//状态char info[10];};struct process_type internalMemory[20];int amount=0,hangUp=0,pid,flag=0;//数目,挂起void main( ){int n;int a;n=1;clrscr( );while(n==1){cout<<"\n********************************************";cout<<"\n* 进程演示系统 *";cout<<"\n********************************************";cout<<"\n 1.创建新的进程 2.查看运行进程 ";cout<<"\n 3.换出某个进程 4.杀死运行进程 ";cout<<"\n 5.唤醒某个进程¨ 6.退出系统 ";cout<<"\n*********************************************"<<endl;cout<<"请选择 ";cin>>a;switch(a){case 1:create( );break;case 2:run( );break;case 3:exchange();//换出break;case 4:kill();break;case 5:wakeUp();break;case 6:exit(0);default:n=0;}}}void create(){ //创建进程int i=0;if (amount>=20){cout<<" 内存已满,请先结束或换出进程";}else{for (i=0;i<20;i++){if (internalMemory[i].state==0){break;}}cout<<"请输入新进程的pid: "<<endl;cin>>internalMemory[ i ].pid;cout<<"请输入新进程的优先级: "<<endl;cin>>internalMemory[amount].priority;cout<<"请输入新进程的大小: "<<endl;cin>>internalMemory[amount].size;cout<<"请输入新进程的内容: "<<endl;cin>>internalMemory[amount].info;internalMemory[i].state=1;amount++;}}void clrscr()//清除内存空间{for (int i=0;i<19;i++){internalMemory[i].pid=0;internalMemory[i].priority=0;internalMemory[i].size=0;internalMemory[i].state=0;}amount=0;}void run(){for (int i=0;i<20;i++){if (internalMemory[i].state==1){cout<<"当前内存中的进程:\n"<<endl;cout<<"当前运行的进程: ";cout<<internalMemory[i].pid<<endl;cout<<"当前运行进程的优先级: ";cout<<internalMemory[i].priority<<endl;cout<<"当前运行进程占用的空间大小: ";cout<<internalMemory[i].size;}}}void exchange( ){//唤出优先级最小的进程if (!amount){cout<<"当前没有运行进程\n";return;}cout<<"\n输入换出进程的ID值: ";cin>>pid;for (int i=0;i<20;i++){if (pid==internalMemory[i].pid){if (internalMemory[i].state==1){internalMemory[i].state=2;hangUp++;cout<<"\n已经成功换出进程\n";}else if (internalMemory[i].state==0){cout<<"\n要换出的进程不存在";}else{cout<<"\n要换出的进程已被挂起\n";}flag=1;break;}}if (flag==0){cout<<"\n要换出的进程不存在";}}void kill( ){if (!amount){cout<<"当前没有运行进程\n";return;}cout<<"请输入要杀死的进程: ";cin>>pid;for (int i=0;i<20;i++){if (pid==internalMemory[i].pid){if (internalMemory[i].state==1){internalMemory[i].state=0;amount--;cout<<"此进程被杀死"<<pid;}else if (internalMemory[i].state==0){cout<<"\n要杀死的进程不存在\n";}else{cout<<"\n要杀死的进程已被挂起\n";}flag=1;break;}}if (!flag){cout<<"\n要杀死的进程不存在\n";}}void wakeUp(){if (!amount){cout<<"当前没有运行进程"<<endl;return;}if (!hangUp){cout<<"当前没有挂起进程";return;}cout<<"请输入pid: ";cin>>pid;for (int i=0;i<20;i++){if (pid==internalMemory[i].pid){flag=0;if (internalMemory[i].state==2){internalMemory[i].state=1;hangUp--;cout<<"已经成功唤醒进程\n";}else if (internalMemory[i].state==0){cout<<"\n要换醒的进程不存在\n";}else{cout<<"\n要唤醒的进程已被挂起\n";}break;}}if (flag){cout<<"\n要唤醒的进程已被挂起\n"<<endl;}}8.实现的结果。

计算机操作系统实验课实验报告

计算机操作系统实验课实验报告

计算机操作系统实验课实验报告一、实验目的本次计算机操作系统实验课的主要目的是通过实际操作和观察,深入理解计算机操作系统的基本原理和功能,提高对操作系统的实际运用能力和问题解决能力。

二、实验环境本次实验使用的计算机配置为:处理器_____,内存_____,操作系统为_____。

实验所使用的软件工具包括_____。

三、实验内容及步骤(一)进程管理实验1、编写程序创建多个进程,并观察进程的执行顺序和资源分配情况。

首先,使用编程语言(如 C 或 Java)编写代码,创建多个进程。

然后,通过操作系统提供的工具(如任务管理器)观察进程的创建、执行和结束过程。

记录不同进程的执行时间、CPU 使用率和内存占用情况。

2、实现进程间的通信机制,如管道、消息队列等。

分别编写使用管道和消息队列进行进程间通信的程序。

在程序中发送和接收数据,并观察通信的效果和数据的完整性。

(二)内存管理实验1、模拟内存分配算法,如首次适应算法、最佳适应算法和最坏适应算法。

编写程序实现上述三种内存分配算法。

输入不同的内存请求序列,观察每种算法下内存的分配情况和碎片产生情况。

2、研究虚拟内存的工作原理,并进行相关实验。

通过操作系统的设置,调整虚拟内存的大小。

运行大型程序,观察虚拟内存的使用情况和系统性能的变化。

(三)文件系统实验1、实现文件的创建、读写和删除操作。

使用编程语言创建文件,并向文件中写入数据。

读取文件中的内容,并进行验证。

删除文件,观察文件系统的变化。

2、研究文件系统的目录结构和文件权限管理。

观察文件系统的目录层次结构,了解目录的组织方式。

设置文件的权限,如只读、读写、执行等,观察不同权限对文件操作的影响。

四、实验结果与分析(一)进程管理实验结果与分析1、在创建多个进程的实验中,发现进程的执行顺序并非完全按照创建的顺序,而是由操作系统的调度算法决定。

某些进程可能会因为等待资源而暂时被挂起,而其他进程则会得到执行机会。

2、通过进程间通信实验,发现管道通信方式简单直接,但只能用于具有亲缘关系的进程之间;消息队列则更加灵活,可以在不同的进程之间传递消息,但需要更多的编程和管理工作。

操作系统实验报告java

操作系统实验报告java

操作系统实验报告java操作系统实验报告 Java一、实验目的本次实验旨在通过使用 Java 编程语言来深入理解操作系统的一些核心概念和原理,如进程管理、线程同步、内存管理等。

通过实际的编程实践,提高对操作系统相关知识的掌握程度,培养解决实际问题的能力。

二、实验环境操作系统:Windows 10开发工具:IntelliJ IDEAJDK 版本:18三、实验内容及步骤1、进程管理创建多个进程模拟并发执行,并观察其执行顺序和资源竞争情况。

使用 Java 的`ProcessBuilder`类来创建新的进程,并通过管道进行进程间通信。

以下是示例代码:```javaimport javaioIOException;import javautilArrayList;import javautilList;public class ProcessManagement {public static void main(String args) {List<Process> processes = new ArrayList<>();try {ProcessBuilder processBuilder1 = new ProcessBuilder("notepadexe");processesadd(processBuilder1start());ProcessBuilder processBuilder2 = new ProcessBuilder("calcexe");processesadd(processBuilder2start());} catch (IOException e) {eprintStackTrace();}//等待所有进程结束for (Process process : processes) {try {processwaitFor();} catch (InterruptedException e) {eprintStackTrace();}}}}```2、线程同步实现多个线程对共享资源的访问,并使用同步机制来避免竞态条件。

操作系统 进程管理 实验报告

操作系统 进程管理 实验报告

昆明理工大学信息工程与自动化学院学生实验报告(201 —201 学年第二学期)课程名称:操作系统开课实验室:年月日年级、专业、班学号姓名成绩实验项目名称进程管理指导教师教师评语教师签名:年月日一、实验目的通过编写进程管理的算法,要求学生掌握整个进程管理的各个环节,进程的数据结构描述,进程的各种状态之间的转换,以及进程的调度算法。

以加深对进程的概念及进程调度算法的理解,并且提高链表的应用能力,达到提高编程能力的目的。

二、实验原理及基本技术路线图(方框原理图)用C语言或C++语言开发。

需要定义PCB的数据结构,用链表的形式管理进程,采用多级反馈队列调度的算法模拟进程的控制。

要求有创建、撤销、调度、阻塞、唤醒进程等功能。

进程的状态转换图:多级反馈队列调度算法:(1) 应设置多个就绪队列,并为各个队列赋予不同的优先级。

第一个队列的优先级最高,其余各队列的优先权逐个降低。

该算法赋予各个队列中进程执行时间片的大小也各不相同,在优先权愈高的队列中,为每个进程所规定的执行时间片就愈小。

(2) 当一个新进程进入内存后,首先将它放入第一队列的末尾,按FCFS原则排队等待调度。

当轮到该进程执行时,如它能在该时间片内完成,便可准备撤离系统;如果它在第二队列中运行一个时间片后仍未完成,再依次将它放入第三队列,……,如此下去,在第n队列中便采取按时间片轮转的方式运行。

(3) 仅当第一队列空闲时,调度程序才调度第二队列中的进程运行;仅当第1~(i-1) 队列均空时,才会调度第i队列中的进程运行。

如果处理机正在第i队列中为某进程服务时,又有新进程进入优先权较高的队列(第1~(i-1)中的任何一个队列),则此时新进程将抢占正在运行进程的处理机程序功能结构图:三、所用仪器、材料(设备名称、型号、规格等)。

计算机一台四、实验方法、步骤#include <stdio.h>#include <stdlib.h>#include <conio.h>#define getpch(type) (type*)malloc(sizeof(type)) //将申请内存空间函数自定义为getpch(type)struct pcb{ //定义进程控制块的结构char name[10]; //进程名称char state; //进程状态int super; //进程优先级int need_time; //进程总共需要的cpu时间int run_time;int arrival_time;int start_time;int finish_time;int zztime;int dzztime;struct pcb* link; //进程指向下一个进程的指针}*ready=NULL, *p; //ready表示指向就绪队列中首元素的指针,初始化为NULL,p用来存放当前刚输入的PCBtypedef struct pcb PCB; //自定义PCB结构体int pzztime=0;int pdzztime=0;int num;int time=0;void sort(){PCB *first, *second;int insert=0; //insert用于记录当前PCB p是否插在就绪队列的尾部if((ready==NULL)||((p->super)>(ready->super))){ //就绪队列中的元素按优先级从高到低排的p->link=ready; //把P放在队首,并且让ready指向pready=p;}else //就绪队列不为空,p的super不比首元素大,那就循环进行比较{first=ready;second=first->link; //first和second都是两个用于循环的变量while(second!=NULL) //一直比较到就绪队列的末尾{if((p->super)>(second->super)) //当前进程的优先级大于原就绪队列中second所指向的元素时,就把p插入到first和second所指向的元素之间{p->link=second;first->link=p;second=NULL;insert=1; //插入队列记录符号}else{first=first->link; //两个循环变量继续后移,为下一轮循环做准备second=second->link;}}if(insert==0) first->link=p; //循环到最后了,如果insert仍为0的话,就把P放在队尾}}//PCB输入模块void input(){int i;printf("\t\t\t\t**************");printf("\n\t\t\t\t* 进程管理*");printf("\n\t\t\t\t**************");printf("\nplease enter the number of process:");scanf("%d",&num);for(i=1;i<=num;i++){printf("\n第%d个进程:",i);p=getpch(struct pcb);printf("\nplease enter the name of process:");scanf("%s",p->name);printf("please enter the priority of the process:");scanf("%d",&p->super);printf("please enter the need_time of the process:");scanf("%d",&p->need_time);printf("please enter the arrival_time of the process:");scanf("%d",&p->arrival_time);p->run_time=0;p->state='W'; //所有进程的初始状态都是等待状态p->link=NULL;sort();}}//PCB就绪队列中元素计数模块int space() //计算就绪队列中PCB的总数{int l=0;PCB *pr=ready; //获取就绪队列的头指针ready while(pr!=NULL) //循环计数{l++;pr=pr->link;}return(l);}//打印PCB信息模块void disp(PCB *pr){printf("\nprocess\tstate\tpriority\n");time = pr->arrival_time > time? pr->arrival_time:time;pr->start_time=time;time+=pr->need_time;pr->state='R';pr->finish_time=time;pr->zztime=pr->finish_time-pr->arrival_time;pr->dzztime=pr->zztime/pr->need_time;pzztime=pr->zztime+pzztime;pdzztime=pr->dzztime+pdzztime;printf(" %s\t",pr->name);printf(" %c\t",pr->state);printf(" %d\t\t\n",pr->super) ;printf("进程名进入时间开始时间运行时间完成时间周转时间带权周转时间\n");printf("%s%d%d%d%d%d%d",pr->name,pr->arrival_time,pr->start_time,pr->need_time,pr-> finish_time,pr->zztime,pr->dzztime);}//检查当前有哪些进程在运行,那些处于wait状态void check(){PCB *pr;printf("\n The current running process is: %s\n",p->name);disp(p);pr=ready;printf("\n\n\n The state of the Waiting List:\n");while(pr!=NULL) //打印其它等待的进程{disp(pr);pr=pr->link;}}//打印已经完成的进程并释放内存空间void destroy(){printf("\nAfter this dispatch ,the process [%s] will finish.\n",p->name);free(p);}//本程序实行的是动态优先级调度//进程运行一段时间(这里设为5)后将其优先级减一,插入后续队列void running(){(p->run_time)+=5;if(p->run_time==p->need_time) //如果执行时间和该进程所需时间相等,则撤销该进程destroy();else //未执行完毕则优先级减一并将状态改为w{(p->super)--;p->state='W';sort(); //加入队列并重新排序}}//主函数模块void main() //主函数{int len, h=0; //h表示进程调度的次数,每调度一次,h++char ch;input(); //输入程序len=space(); //获取就绪队列长度while((len!=0)&&(ready!=NULL)){ch=getchar();h++;printf("\n The execute number: %d \n",h);p=ready; //以下三行是将P从就绪队列的队首摘除ready=p->link;p->link=NULL;p->state='R'; //将P的状态改为Rcheck();running();pzztime=pzztime/num;pdzztime=pdzztime/num;printf("\n平均周转时间,平均带权周转时间\n");printf("%d,%d",pzztime,pdzztime);printf("\npress any key to continue...");ch=getchar();}printf("\n\nAll the processes have finished !"); //所有进程已经完成ch=getchar();}五、实验过程原始记录(数据、图表、计算等)六、实验结果、分析和结论(误差分析与数据处理、成果总结等。

操作系统实验报告java

操作系统实验报告java

操作系统实验报告院系:专业:班级:学号:姓名:指导老师:进程调度的模拟与内存管理一、实验目的在采用多道程序设计的系统中,往往有若干个进程同时处于就绪状态。

当就续进程个数大于处理器数时,就必须依照某种策略来决定哪些进程优先占用处理器。

实验模拟实现处理机调度,以加深了解处理机调度的工作,并体会优先级和时间片轮转调度算法的具体实施方法。

帮助了解在不同的存储管理方式下,应怎样实现主存空间的分配和回收。

二、实验要求1、可随机输入若干进程,并按优先权排序;2、从就绪队首选进程运行:优先权-1/要求运行时间-1要求运行时间=0时,撤销该进程3、重新排序,进行下轮调度。

4、可随时增加进程;5、规定道数,设置后备队列和挂起状态。

若内存中进程少于规定道数,可自动从后备队列调度一作业进入。

被挂起进程入挂起队列,设置解挂功能用于将指定挂起进程解挂入就绪队列。

6、每次调度后,显示各进程状态。

7、自行假设主存空间大小,预设操作系统所占大小并构造未分分区表;表目内容:起址、长度、状态(未分/空表目)8、结合以上实验,PCB增加为:{PID,要求运行时间,优先权,状态,所需主存大小,主存起始位置,PCB指针}9、采用最先适应算法分配主存空间;10、进程完成后,回收主存,并与相邻空闲分区合并。

11、采用图形界面;三、实验内容选择一个调度算法,实现处理机调度。

1、设计一个按优先权调度算法实现处理机调度的程序;2、设计按时间片轮转实现处理机调度的程序。

3、主存储器空间的分配和回收。

在可变分区管理方式下,采用最先适应算法实现主存空间的分配和回收。

四、实验原理该模拟系统采用java语言实现,要实现的功能有新建进程、进程调度、挂起进程、解挂进程、删除进程,道数和时间片大小可以由用户自己调整,有两种调度策略:按优先权调度和按时间片轮转调度。

每个进程可能有5种状态:新建(new)、就绪(ready)、运行(running)、阻塞(waiting)、挂起(suspend)。

Java实验报告一[Java程序的编辑、编译运行]

Java实验报告一[Java程序的编辑、编译运行]

J a v a面向对象编程实验报告题目:J ava程序的编辑运行专业:网络工程班级:11205520学号:01姓名:杨喆太原工业学院计算机工程系年月日一、实验目的与要求1、掌握在window下的java环境的安装配置2、掌握javac与java命令的使用3、熟练动手编译运行java程序4、熟练编写简单的java分支程序5、熟练编写java类以及java对象的创建运行。

二、实验内容1、在windows下安装Java环境JDK2、在cmd.exe下运行编译命令javac3、在cmd.exe下运行执行命令java4、书写HelloWorld.java 源程序,编译打印并输出hello、world!5、编写分支程序使用if语句或switch语句进行月份判断输出:2月28天,1月、3月、5月、7月、8月、10月、12月的天数为31天,其他月份为30天。

编程测试:程序接收1-12数值,按照以上规则输出xx月有多少天6、分析抽象一个学生类用Java代码实现此类、创建此类的对象,并调用执行。

三、实施步骤1、在windows下安装Java环境JDK单击“开始”→“所有程序”→“附件”→“命令提示符”打开DOS 窗口,在命令提示符下输入set path=%path%;D:\Program Files\Java\jdk1.7.0\bin执行完后输入“java”或“javac”,回车后,如果出现其用法参数提示信息,则说明安装正确。

2、编写一个Java Application,利用JDK软件包中的工具编译并运行这个程序。

步骤(1):编写、编译Java 源程序。

打开MyEclipse,新建一个java文件,键入如下程序代码:public class Hello{public static void main(String args[]){System.out.println("Hello,World!");}}将文件命名为Hello.java,注意保存文件Hello.java到路径“e:\java\”下。

面向对象程序设计实验报告java实验报告图形用户界面

面向对象程序设计实验报告java实验报告图形用户界面

图形用户界面设计实验 1Nested PanelsThe program Nested Panels.java is from Listing 3.8 of the text. Save the program to your directory and do the following:1. Compile and run the program. Experiment with resizing the frame and observe the effect on the components.运转程序后出现以下界面:改变窗口的大小,察看到:(见下列图)(1)两个子面板 one 和 two 的尺寸都保持不变。

(2)蓝色的主面板跟着窗口的变大而扩展。

(3)蓝色面板变长, one 和 two 子面板都不变,当蓝色面板变宽时,两个子面板跟着它挪动,并保持居中状态。

(4)减小窗口,依据流式布局的形式, two 子面板因为地点容不下,自动被放在下一行的地点。

2.Modify the program by adding a third subpanel that is twice as wide, butthe same height, as the other two subpanels. Choose your own label and color for the subpanel (the color should not be red, green, or blue). Add the panel to the primary panel after the other two panels.改正的代码以下:JPanel subPanel3 = new JPanel() ;subPanel3.setPreferredSize (new Dimension(300, 100));ubPanel3.setBackground (Color.red); JLabel label3 =new JLabel ("Three");subPanel3.add (label3);primary.add (subPanel3);pile and run the modified program. Again, experiment with resizing the frame and observe the effect on the components.改变窗口的大小, 3 个子面板变化状况跟第一步实验的近似。

操作系统实验2进程管理报告【范本模板】

操作系统实验2进程管理报告【范本模板】

实验一进程管理一、实验目的:1.加深对进程概念的理解,明确进程和程序的区别;2.进一步认识并发执行的实质;3.分析进程争用资源的现象,学习解决进程互斥的方法;4.了解Linux系统中进程通信的基本原理;二、实验预备内容:1.阅读Linux的sched.h源码文件,加深对进程管理概念的理解;2.阅读Linux的fork()源码文件,分析进程的创建过程;三、实验环境说明:1.此实验采用的是Win7(32bit)下虚拟机VMware—workstation—10.0.4 build-2249910;2.ubuntu 版本3.19。

0;3.直接编写c文件在终端用命令行执行;4.虚拟机分配8G内存中的1024M;5.虚拟机名称knLinux;6.ubuntu用户名kn;四、实验内容:1.进程的创建:a)题目要求:编写一段程序,使用系统调用fork() 创建两个子进程。

当此程序运行时,在系统中有一个父进程和两个子进程活动.让每一个进程在屏幕上显示一个字符:父进程显示字符“a",子进程分别显示字符“b”和“c”.试观察记录屏幕上的显示结果,并分析原因。

b)程序设计说明:一个父进程,两个子进程,分别输出显示a,b,c.c)源代码:d)运行结果:e)分析:由输出结果可知,运行结果不唯一,可以是abc,acb,bca等多种情况。

因为在程序中,并没有三个进程之间的同步措施,所以父进程和子进程的输出顺序是随机的。

在试验次数足够大的情况下,6中顺序都有可能出现:abc, acb,bac, bca, cab,cba。

2.进程的控制:a)修改已经编写的程序,将每个进程输出一个字符改为每个进程输出一句话,再观察程序执行时屏幕上出现的现象,并分析原因。

i.程序设计说明:将第一个程序中输出字符的语句改为输出parent process和childprocess1&2的语句。

ii.源代码:iii.运行结果:iv.分析:发现在结果中,运行结果同第一个程序,但是在一个进程输出语句的中途不会被打断,语句都是完整的。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
相关文档
最新文档