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

(完整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; //进程ID

public 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为时间片大小(毫秒)

//对进程进行初始化,建立就绪数组、阻塞数组。

public void input()//对进程进行初始化,建立就绪队列、阻塞队列

{

m = int.Parse(textBox4.Text);

n = int.Parse(textBox5.Text);

a = int.Parse(textBox6.Text);

b = int.Parse(textBox7.Text);

c = int.Parse(textBox8.Text);

a1 = a;

b1 = b;

c1 = c;

r = m - n;

time1Inteval = int.Parse(textBox9.Text);

timer1.Interval = time1Inteval;

for (i = 1; i <= n; i++)

{

pcb jincheng = new pcb();

jincheng.id = i;

jincheng.ra = (random.Next(a) + 1);

jincheng.rb = (random.Next(b) + 1);

jincheng.rc = (random.Next(c) + 1);

jincheng.ntime = (random.Next(1, 5));

listBox1.Items.Add("产生进程ID:" + jincheng.id);

listBox1.Items.Add("所需A资源数目:" + jincheng.ra);

listBox1.Items.Add("所需B资源数目:" + jincheng.rb);

listBox1.Items.Add("所需C资源数目:" + jincheng.rc);

listBox1.Items.Add("所需时间片数:" + jincheng.ntime);

if ((a - jincheng.ra) >= 0 && (b - jincheng.rb) >= 0 && (c - jincheng.rc) >= 0)

{

a = a - jincheng.ra;

b = b - jincheng.rb;

c = c - jincheng.rc;

jincheng.state = 'W';

hready.Add(jincheng);//加入就绪队列

}

else

{

jincheng.state = 'B';

hblock.Add(jincheng);//加入阻塞队列

}

listBox1.Items.Add("当前进程状态:" + jincheng.state);

}

}

//从数组起始地址开始输出该数组的内容

public void disp(ArrayList list)

{

ArrayList list1 = new ArrayList();

list1 = list;

if (list1.Count > 0)

{

for (int j = 0; j < list1.Count; j++)

{

pcb p = (pcb)list1[j];

listBox1.Items.Add(" " + p.id.ToString() + " " + p.state.ToString() + " " + p.ra.ToString() + " " + p.rb.ToString() + " " + p.rc.ToString()+" " + p.ntime.ToString() + " " + p.rtime.ToString() + " \r\n");

}

}

else

{

listBox1.Items.Add("\r\n\t 该队列中没有进程!\r\n");

}

}

//输出就绪数组和阻塞数组的信息

public void outputall()

{

listBox1.Items.Add("*********当前就绪队列的信息!*********");

listBox1.Items.Add("进程ID 进程状态A资源数B资源数C资源数所需时间片已运行时间片");

disp(hready);

listBox1.Items.Add("*********当前就阻塞列的信息!*********");

listBox1.Items.Add("进程ID 进程状态A资源数B资源数C资源所需时间片已运行时间片");

disp(hblock);

}

//运行就绪数组的头进程,运行一个时间片,轮转一个时间片,时间片轮转调度算法

public void running()

{

ArrayList hready1 = new ArrayList();

hready1 = hready;

pcb p1 = new pcb();

p1=(pcb)hready1[0];

p1.state='R';

p1.rtime= p1.rtime + 1;

h=h+1;

listBox1.Items.Add("\r\n~~~~~~~当前正在运行进程ID是:" +p1.id + "~~~~~~~~\r\n");

listBox1.Items.Add("\r\n进程ID 进程状态A资源数B资源数C资源数所需时间片已运行时间片\r\n");

listBox1.Items.Add(p1.id + " " +p1.state+ " " + p1.ra + " " + p1.rb + " " + p1.rc + " " + p1.ntime + " " + p1.rtime);

if (p1.ntime==p1.rtime)

{

listBox1.Items.Add(p1.id.ToString()+"的进程已经完成!\r\n");

a = a + p1.ra;

b = b + p1.rb;

c = c + p1.rc;

hready.RemoveAt(0);

}

else

{

p1.state='W';

hready1.Add(p1);

hready.RemoveAt(0);

}

}

//检测当前资源数目是否满足阻塞数组里进程的需求

public void testblock()

{

ArrayList hblock1 = new ArrayList();

hblock1 = hblock;

for (int m = 0; m < hblock1.Count; m++)

{

p1 = (pcb)hblock1[m];

if ((a - p1.ra >= 0) && (b - p1.rb >= 0) && (c - p1.rc >= 0))

{

p1.state='W';

hready.Add(p1);

a = a - p1.ra;

b = b - p1.rb;

c = c - p1.rc;

listBox1.Items.Add("ID号为:"+p1.id + "的进程由阻塞队列转入就绪队列~~\r\n");

hblock.RemoveAt(m);

m--;

}

}

}

//检测是否有新的进程产生,随机产生新进程

public void testnew()

{

int t;

if (r>0)//r为随机产生的进程数目

{

t = random.Next(9) + 1;

if (t <= 7)

{

listBox1.Items.Add("\r\n有新的进程申请加入:~~");

pcb jincheng = new pcb();

jincheng.id = i++;

jincheng.ra = (random.Next(a) + 1);

jincheng.rb = (random.Next(b) + 1);

jincheng.rc = (random.Next(c) + 1);

jincheng.ntime = (random.Next(1, 5));

jincheng.rtime = 0;

listBox1.Items.Add("产生进程ID:" + jincheng.id);

listBox1.Items.Add("所需A资源数目:" + jincheng.ra);

listBox1.Items.Add("所需B资源数目:" + jincheng.rb);

listBox1.Items.Add("所需C资源数目:" + jincheng.rc);

listBox1.Items.Add("所需时间片数:" + jincheng.ntime);

if ((a - jincheng.ra) >= 0 && (b - jincheng.rb) >= 0 && (c - jincheng.rc) >= 0)

{

a = a - jincheng.ra;

b = b - jincheng.rb;

c = c - jincheng.rc;

jincheng.state = 'W';

listBox1.Items.Add("进程状态为:" + jincheng.state);

hready.Add(jincheng);//加入就绪队列

listBox1.Items.Add("资源满足新进程请求,该进程进入就绪队列~~\r\n");

else

{

jincheng.state = 'B';

hblock.Add(jincheng);//加入阻塞队列

listBox1.Items.Add("进程状态为:" + jincheng.state);

listBox1.Items.Add("资源不满足新进程请求,该进程进入阻塞队列~~\r\n");

}

}

}

r = r - 1;

}

//系统三类资源变化情况的显示

public void rescore()//系统三类资源变化情况的显示

{

if (a > a1) { textBox1.Text = a1.ToString(); }

if (a < 0) { textBox1.Text = "0"; }

if (a >= 0 && a < a1) { textBox1.Text = a.ToString(); }

if (b > b1) { textBox2.Text = b1.ToString(); }

if (b < 0) { textBox2.Text = "0"; }

if (b >= 0 && b <= b1) { textBox2.Text = b.ToString(); }

if (c > c1) { textBox3.Text = c1.ToString(); }

if (c < 0) { textBox3.Text = "0"; }

if (c >= 0 && c <= c1) { textBox3.Text = c.ToString(); }

}

//时间片轮转调度算法(先来先服务FCFS算法)

public void runFcfs()

{

if (hready.Count>0)

{

outputall();

running();

testblock();

testnew();

rescore();

}

else

{

timer1.Enabled = false;

textBox1.Text = a1.ToString();

textBox2.Text = b1.ToString();

textBox3.Text = c1.ToString();

listBox1.Items.Add("\r\n<<<<<<<<所有进程都已经运行结束!>>>>>>>~\r\n");

}

//计时器触发时间片轮转调度算法

private void timer1_Tick(object sender, EventArgs e)

runFcfs();

}

//开始模拟按钮单击执行函数

private void button1_Click(object sender, EventArgs e) {

runmain();

button1.Enabled = false;

textBox1.Enabled = false;

textBox2.Enabled = false;

textBox3.Enabled = false;

textBox4.Enabled = false;

textBox5.Enabled = false;

textBox6.Enabled = false;

textBox7.Enabled = false;

textBox8.Enabled = false;

textBox9.Enabled = false;

}

//清除屏幕按钮单击执行函数

private void button2_Click(object sender, EventArgs e) {

textBox1.Text = "";

textBox2.Text = "";

textBox3.Text = "";

textBox4.Text = "";

textBox5.Text = "";

textBox6.Text = "";

textBox7.Text = "";

textBox8.Text = "";

textBox9.Text = "";

listBox1.Items.Clear();

textBox4.Enabled = true;

textBox5.Enabled = true;

textBox6.Enabled = true;

textBox7.Enabled = true;

textBox8.Enabled = true;

textBox9.Enabled = true;

button1.Enabled = true;

}

//运行的主函数

public void runmain()

{

input();

imer1.Enabled = true;

3、运行界面和运行结果

界面中,可以任意设定需要模拟的进程总数(如5),初始化进程个数(如3),还有A、B、C三类资源的总数(如10、10、10)。为了方便显示,还可以设定时间片的长度(如500毫秒)。除此之外,在运行过程中,所有的资源都是随机生成的,并且其中新进程的产生也是随机的,但是产生的进程总数不会多于开始设定的模拟的进程总数,以防止不断产生新进程,程序不断运行。在显示窗口的上方,还会实时显示资源的变化情况,方便对运行的观察。当运行结束后,可以通过工具栏中的显示选项中的保存结果按钮,将结果保存成txt文件格式,方便运行后的结果分析。

五、心得体会

本次实验,我的任务是设计一个允许n个进程并发运行的进程管理模拟系统。该系统包括有简单的进程控制、同步与通讯机构,系统在运行过程中能显示各进程的状态及有关参数的变化情况,从而观察诸进程的运行过程及系统的管理过程,我是用C#写的,在我的电脑能够运行通过,虽不能尽善尽美,但也基本能实现老师的要求。

两个星期的实验,虽然时间有点短,但我也收获不少,这次实验,加深了我对进程概念及进程管理的理解;比较熟悉进程管理中主要数据结构的设计及进程调度算法、进程控制机构、同步机构及通讯机构的实施。也让我认识到自己的不足,操作系统的有些知识,我知道的还不多,没有掌握好,还需要多多学学,不断提升自己的能力。

实验中,我们小组分工合作,共同学习,虽然在实验中遇到了一些问题,但在老师和同学的细心指导和热心帮助下解决了。同时,了解到团队精神的重要性,也为以后的学习和工作打下了坚实的基础,同时积累了宝贵的经验。

windows进程管理实验报告

实验报告 课程名称:操作系统 实验项目:windows进程管理 姓名: 专业:计算机科学与技术 班级: 学号:

计算机科学与技术学院 计算机系 2019 年 4 月 23 日

实验项目名称: windows进程管理 一、实验目的 1. 学习windows系统提供的线程创建、线程撤销、线程同步等系统调用; 2. 利用C++实现线程创建、线程撤销、线程同步程序; 3. 完成思考、设计与练习。 二、实验用设备仪器及材料 1. Windows 7或10, VS2010及以上版本。 三、实验内容 1 线程创建与撤销 写一个windows控制台程序(需要MFC),创建子线程,显示Hello, This is a Thread. 然后撤销该线程。 相关系统调用: 线程创建: CreateThread() 线程撤销: ExitThread() 线程终止: ExitThread(0) 线程挂起: Sleep() 关闭句柄: CloseHandle() 参考代码: ; } 运行结果如图所示。 完成以下设计题目: 1. 向线程对应的函数传递参数,如字符串“hello world!”,在线程中显示。 2. 如何创建3个线程A, B, C,并建立先后序执行关系A→B→C。

实验内容2 线程同步 完成父线程和子线程的同步。父线程创建子线程后进入阻塞状态,子线程运行完毕后再唤醒。 相关系统调用: 等待对象 WaitForSingleObject(), WaitForMultipleObjects(); 信号量对象 CreateSemaphore(), OpenSemaphore(), ReleaseSemaphore(); HANDLE WINAPI CreateSemaphore( _In_opt_ LPSECURITY_ATTRIBUTES lpSemaphoreAttributes _In_ LONG lInitialCount, _In_ LONG lMaximumCount, _In_opt_ LPCTSTR lpName ); 第一个参数:安全属性,如果为NULL则是默认安全属性 第二个参数:信号量的初始值,要>=0且<=第三个参数 第三个参数:信号量的最大值 第四个参数:信号量的名称 返回值:指向信号量的句柄,如果创建的信号量和已有的信号量重名,那么返回已经存在的信号量句柄参考代码: n"); rc=ReleaseSemaphore(hHandle1,1,NULL); err=GetLastError(); printf("Release Semaphore err=%d\n",err); if(rc==0) printf("Semaphore Release Fail.\n"); else printf("Semaphore Release Success. rc=%d\n",rc); } 编译运行,结果如图所示。

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

实验一进程管理 一、目的 进程调度是处理机管理的核心内容。本实验要求编写和调试一个简单的进程调度程序。通过本实验加深理解有关进程控制块、进程队列的概念,并体会和了解进程调度算法的具体实施办法。 二、实验内容及要求 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; //进程ID public 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为时间片大小(毫秒) //对进程进行初始化,建立就绪数组、阻塞数组。 public void input()//对进程进行初始化,建立就绪队列、阻塞队列 { m = int.Parse(textBox4.Text); n = int.Parse(textBox5.Text); a = int.Parse(textBox6.Text); b = int.Parse(textBox7.Text); c = int.Parse(textBox8.Text); a1 = a; b1 = b; c1 = c; r = m - n; time1Inteval = int.Parse(textBox9.Text); timer1.Interval = time1Inteval; for (i = 1; i <= n; i++) { pcb jincheng = new pcb(); jincheng.id = i; jincheng.ra = (random.Next(a) + 1); jincheng.rb = (random.Next(b) + 1); jincheng.rc = (random.Next(c) + 1); jincheng.ntime = (random.Next(1, 5)); jincheng.rtime = 0;

财务管理实训总结

财务管理实训总结 实训时间:xx年xx月xx日—xx年xx月xx日 实训地点:5411教室 实训科目:财务管理 实训内容:第一,财务管理的价值观点Excel练习;第二,证券 及其股价Excel练习;第三,财务分析Excel练习;第四,财务预测与 计划Excel练习;第五,企业筹资方式Excel练习;第六,资本成本和 资本结构Excel练习;第七,项目投资Excel练习。 实训感想:每到快要结束的时候,都会感叹时间过得真快! 经过一周的实训,收获了很多知识,让自己有“更上一层楼”的 感觉。这次的实训虽说告一段落了,但是财务管理的这次实训过程给 我留下深刻的印象,这也将是下一个起程。这次实训,虽然时间很短,但我觉得会对我以后的学习及工作产生很大的影响。这次的实训让我 们在平常学习的基础上,知识得到了进一步的巩固,更加清晰明白。 实训的第一天,拿到这个题都不知从何处下手,慢慢的,经过和同班 同学的交流讨论,开始着手了,也逐步地加快了进度。第一天结束了,第一部分的内容也做完了,有了很大的成就感,懂得了方法,也获得 了很多的知识。 第二天开始做时,也就越来越上手了,正所谓“天下难事始于易,天下大事始于细”。这次的实训让我们把书本上的知识使用电脑中的 办公软件Excel来完成,其实,这对于我们学财务管理的学生来说, 为我们提供了一个很好的实训机会,让我们对Excel有了进一步的了解,Excel中很多的功能也更加熟悉,比如:终值、现值、利率、年金、净现值等的计算,这些平常我们都没有怎么使用的函数,这次在实训 中将其使用熟悉。这次财务管理的实训,我们做了七个部分的内容, 从开始不知从何下手,到最后的得来应手,“万事开头难”,只要有

进程管理实验报告

实验2过程管理实验报告学生号姓名班级电气工程系过程、过程控制块等基本原理过程的含义:过程是程序运行过程中对数据集的处理,以及由独立单元对系统资源的分配和调度。在不同的数据集上运行程序,甚至在同一数据集上运行多个程序,是一个不同的过程。(2)程序状态:一般来说,一个程序必须有三种基本状态:就绪、执行和阻塞。然而,在许多系统中,过程的状态变化可以更好地描述,并且增加了两种状态:新状态和终端状态。1)就绪状态,当一个进程被分配了除处理器(CPU)以外的所有必要资源时,只要获得了处理器,进程就可以立即执行。此时,进程状态称为就绪状态。在系统中,多个进程可以同时处于就绪状态。通常,这些就绪进程被安排在一个或多个队列中,这些队列称为就绪队列。2)一旦处于就绪状态的进程得到处理器,它就可以运行了。进程的状态称为执行状态。在单处理器系统中,只有一个进程在执行。在多处理器系统中,可能有多个进程在执行中。3)阻塞状态由于某些事件(如请求输入和输出、额外空间等),执行进程被挂起。这称为阻塞状态,也称为等待状态。通常,处于阻塞状态的进程被调度为-?这个队列称为阻塞队列。4)新状态当一个新进程刚刚建立并且还没有放入就绪队列中时,它被称为新状态。5)终止状态是

什么时候-?进程已正常或异常终止,操作系统已将其从系统队列中删除,但尚未取消。这就是所谓的终结状态。(3)过程控制块是过程实体的重要组成部分,是操作系统中最重要的记录数据。控制块PCB记录操作系统描述过程和控制过程操作所需的所有信息。通过PCB,一个不能独立运行的程序可以成为一个可以独立运行的基本单元,并且可以同时执行一个进程。换句话说,在进程的整个生命周期中,操作系统通过进程PCB管理和控制并发进程。过程控制块是系统用于过程控制的数据结构。系统根据进程的PCB来检测进程是否存在。因此,进程控制块是进程存在的唯一标志。当系统创建一个进程时,它需要为它创建一个PCB;当进程结束时,系统回收其PCB,进程结束。过程控制块的内容过程控制块主要包括以下四个方面的信息。过程标识信息过程标识用于对过程进行标识,通常有外部标识和内部标识。外部标识符由流程的创建者命名。通常是一串字母和数字。当用户访问进程时使用。外部标识符很容易记住。内部标识符是为了方便系统而设置的。操作系统为每个进程分配一个唯一的整数作为内部标识符。通常是进程的序列号。描述性信息(process scheduling message)描述性信息是与流程调度相关的一些有关流程状态的信息,包括以下几个方面。流程状态:表

嵌入式操作系统实验报告

中南大学信息科学与工程学院实验报告 姓名:安磊 班级:计科0901 学号: 0909090310

指导老师:宋虹

目录 课程设计内容 ----------------------------------- 3 uC/OS操作系统简介 ------------------------------------ 3 uC/OS操作系统的组成 ------------------------------ 3 uC/OS操作系统功能作用 ---------------------------- 4 uC/OS文件系统的建立 ---------------------------- 6 文件系统设计的原则 ------------------------------6 文件系统的层次结构和功能模块 ---------------------6 文件系统的详细设计 -------------------------------- 8 文件系统核心代码 --------------------------------- 9 课程设计感想 ------------------------------------- 11 附录-------------------------------------------------- 12

课程设计内容 在uC/OS操作系统中增加一个简单的文件系统。 要求如下: (1)熟悉并分析uc/os操作系统 (2)设计并实现一个简单的文件系统 (3)可以是存放在内存的虚拟文件系统,也可以是存放在磁盘的实际文件系统 (4)编写测试代码,测试对文件的相关操作:建立,读写等 课程设计目的 操作系统课程主要讲述的内容是多道操作系统的原理与技术,与其它计算机原理、编译原理、汇编语言、计算机网络、程序设计等专业课程关系十分密切。 本课程设计的目的综合应用学生所学知识,建立系统和完整的计算机系统概念,理解和巩固操作系统基本理论、原理和方法,掌握操作系统开发的基本技能。 I.uC/OS操作系统简介 μC/OS-II是一种可移植的,可植入ROM的,可裁剪的,抢占式的,实时多任务操作系统内核。它被广泛应用于微处理器、微控制器和数字信号处理器。 μC/OS 和μC/OS-II 是专门为计算机的嵌入式应用设计的,绝大部分代码是用C语言编写的。CPU 硬件相关部分是用汇编语言编写的、总量约200行的汇编语言部分被压缩到最低限度,为的是便于移植到任何一种其它的CPU 上。用户只要有标准的ANSI 的C交叉编译器,有汇编器、连接器等软件工具,就可以将μC/OS-II嵌入到开发的产品中。μC/OS-II 具有执行效率高、占用空间小、实时性能优良和可扩展性强等特点,最小内核可编译至2KB 。μC/OS-II 已经移植到了几乎所有知名的CPU 上。 严格地说uC/OS-II只是一个实时操作系统内核,它仅仅包含了任务调度,任务管理,时间管理,内存管理和任务间的通信和同步等基本功能。没有提供输入输出管理,文件系统,网络等额外的服务。但由于uC/OS-II良好的可扩展性和源码开放,这些非必须的功能完全 可以由用户自己根据需要分别实现。 uC/OS-II目标是实现一个基于优先级调度的抢占式的实时内核,并在这个内核之上提供最基本的系统服务,如信号量,邮箱,消息队列,内存管理,中断管理等。 uC/OS操作系统的组成 μC/OS-II可以大致分成核心、任务处理、时间处理、任务同步与通信,CPU的移植等5个部分。如下图:

财务管理实训报告范文三篇

财务管理实训报告范文三篇 财务管理实训汇报范文格式一 在这个学期里,我们开展了财务管理课,期末学校跟着安排我们进行财务管理实训。以下是这次实训的一些详细情况,以及我的一些感悟领会。 这次实训在期末进行,时间为从xx月xx号至xx月xx号,共10个课时,大概持续一个星期。这次实训的目的是为了进一步稳固我们按模块教学所掌握的《财务管理》操作技能知识,全面检验我们财务会计核算综合运用技能,加强我们动手能力和实践操作能力,并为今后从事财务管理打下良好基础,而特开展的。这次实训要求我们能以企业的财务报表等核算资料为基础,对企业财务活动的过程和结果进行研究和评价,以分析企业在生产经营过程中的利弊得失、财务状况及开展趋势,并能为评价和改良财务财务管理工作及为将来进行经济决策提供重要的财务信息。实训内容分为三大块:一初步分析,二财务指标分析,三综合分析。 实训开始的第一步骤是公式计算。根据企业资产负债表以及利润表上的数据信息,再通过特定的公式把各项指标的构造比率、增长额和增长率等项目方案计算出来。这个工作的技术含量相比照较低,最要是考察我们对公式的理解程度以及运用程度,只要你熟悉公式,懂得运用公式,然后对号入座,几乎上就没什么大问习题了,但是要计

算的数据比较多,相对就变得繁琐,毕竟是一环扣一环的公式计算,这要求核算人员工作态度认真严谨。由于实训要求书面书写清洁整齐、标准、严禁挖乱、涂改和使用涂改液,所以我做的时候先在草稿上做一次,确认无误后,再填入实训资料。我平常是属于比较认真学习的那一类,所以这个公式计算没到四个课时,我就完成了,进展得相比照较顺利。可是进行第二步骤运用公式分析就遇到相当大的困难。 第二步骤公式分析、评价,也就是这次实训过程中最为关键、最为重要、最精华的一步,也是这次实训的主要内容以及主要目的。 第一步是对资产负债表以及利润表作初步分析。资产负债表总体分为三大块:资产、负债及所有者权益,而其中资产又分为流动资产和非流动资产,负债又分为流动负债和非流动负债。每一大块到每一小块,再到每一小块的细分都要进行分析小结,这点对初学者来说要求不低难度不少,或许是教师对我们期望值相当高,希望通过高要求打好我们基础,所以才安排大习题量并细分析。 大致上的资产总额构造分析,流动资产构造分析、非流动资产构造分析等,然后再细分下去的货币资金分析、应收账款分析、应收票据分析、其他应收款分析、存货分析等,通过教师的指导以及与同学们的讨论,我还是可以理解和分析的,可是明细的预付账款、原材料、固定资产和再建工程,就不知道怎么作出总结归纳好了。后来在课本上大量并且细微阅读有关内容,在网上大量疯狂的搜索有关资料,再根据资料通过自己的独立思考,渐渐的领悟很多财务分析的问习题,譬如对预付账款的分析,开始我只明白预付账款的字面意思,就是指

进程管理实验报告

进程的控制 1 .实验目的 通过进程的创建、撤消和运行加深对进程概念和进程并发执行的理解,明确进程与程序之间的区别。 【答:进程概念和程序概念最大的不同之处在于: (1)进程是动态的,而程序是静态的。 (2)进程有一定的生命期,而程序是指令的集合,本身无“运动”的含义。没有建立进程的程序不能作为1个独立单位得到操作系统的认可。 (3)1个程序可以对应多个进程,但1个进程只能对应1个程序。进程和程序的关系犹如演出和剧本的关系。 (4)进程和程序的组成不同。从静态角度看,进程由程序、数据和进程控制块(PCB)三部分组成。而程序是一组有序的指令集合。】2 .实验内容 (1) 了解系统调用fork()、execvp()和wait()的功能和实现过程。 (2) 编写一段程序,使用系统调用fork()来创建两个子进程,并由父进程重复显示字符串“parent:”和自己的标识数,而子进程则重复显示字符串“child:”和自己的标识数。 (3) 编写一段程序,使用系统调用fork()来创建一个子进程。子进程通过系统调用execvp()更换自己的执行代码,新的代码显示“new

program.”。而父进程则调用wait()等待子进程结束,并在子进程结束后显示子进程的标识符,然后正常结束。 3 .实验步骤 (1)gedit创建进程1.c (2)使用gcc 1.c -o 1编译并./1运行程序1.c #include #include #include #include void mian(){ int id; if(fork()==0) {printf(“child id is %d\n”,getpid()); } else if(fork()==0) {printf(“child2 id %d\n”,getpid()); } else {id=wait(); printf(“parent id is %d\n”,getpid()); }

实时操作系统报告

实时操作系统课程实验报告 专业:通信1001 学号:3100601025 姓名:陈治州 完成时间:2013年6月11日

实验简易电饭煲的模拟 一.实验目的: 掌握在基于嵌入式实时操作系统μC/OS-II的应用中,基于多任务的模式的编程方法。锻炼综合应用多任务机制,任务间的通信机制,内存管理等的能力。 二.实验要求: 1.按“S”开机,系统进入待机状态,时间区域显示当前北京时间,默认模式“煮饭”; 2.按“C”选择模式,即在“煮饭”、“煮粥”和“煮面”模式中循环选择; 3.按“B”开始执行模式命令,“开始”状态选中,时间区域开始倒计时,倒计时完成后进入“保温”状态,同时该状态显示选中,时间区域显示保温时间; 4.按“Q”取消当前工作状态,系统进入待机状态,时间区域显示北京时间,模式为当前模式; 5.按“X”退出系统,时间区域不显示。 6.煮饭时长为30,煮粥时长为50,煮面时长为40. 三.实验设计: 1.设计思路: 以老师所给的五个程序为基础,看懂每个实验之后,对borlandc的操作有了大概的认识,重点以第五个实验Task_EX为框架,利用其中界面显示与按键扫描以及做出相应的响应,对应实现此次实验所需要的功能。 本次实验分为界面显示、按键查询与响应、切换功能、时钟显示与倒计时模块,综合在一起实验所需功能。 2.模块划分图: (1)界面显示: Main() Taskstart() Taskstartdispinit() 在TaskStartDispInit()函数中,使用PC_DispStr()函数画出界面。

(2)按键查询与响应: Main() Taskstart() 在TaskStart()函数中,用if (PC_GetKey(&key) == TRUE)判断是否有按键输入。然后根据key 的值,判断输入的按键是哪一个;在响应中用switch语句来执行对应按键的响应。 (3)切换功能: l计数“C”按 键的次数 M=l%3 Switch(m) M=0,1,2对应于煮饭,煮粥,煮面,然后使用PC_DispStr()函数在选择的选项前画上“@”指示,同时,在其余两项钱画上“”以“擦出”之前画下的“@”,注意l自增。 四.主要代码: #include "stdio.h" #include "includes.h" #include "time.h" #include "dos.h" #include "sys/types.h" #include "stdlib.h" #define TASK_STK_SIZE 512 #define N_TASKS 2 OS_STK TaskStk[N_TASKS][TASK_STK_SIZE]; OS_STK TaskStartStk[TASK_STK_SIZE]; INT8U TaskData[N_TASKS];

财务管理实验报告总结免费范文

财务管理实验报告总结免费范文 一、实验目的 二、实验成员角色分配 团队中的四个人必须有很强的团队意识和强大的凝聚力,这项工作本身就是一项相互配合与在相互帮助中完成的工作,每个人都负 有别人不可替代的任务。如果四个人当中有一个人缺少团队意识, 那只会有一种结果:必输无疑,无论其它人的个人业务水平有多高,因为每个人的工作都是紧密的相互关联、密不可分的。 三、实验过程及分析 (一)生产计划与实行 第一年,我们公司主要是生产低端产品,所以安装了三条生产线分别是两条低端L1,一条在建的中端M1,之所以我们在选择生产线 时选择的都是最贵的,是因为我们小组坚信,只要能生产出多的产品,就一定能盈利。但在产房的购买与租赁问题中,我们出现了错误,这个错误是到后面也无法弥补的。我们第一年选择了厂房租赁,规则上是说厂房租赁每年4万,可到实际操作中就不是这样了,厂 房每年的租金都会翻倍,这也使我们接下来几年的预算全部出错, 甚至在最后两年出现了紧急贷款的情况。 (二)财务变化分析 第一年,公司处于初创期,需要购置厂房、购买设备、聘用工人、采购原材料、生产产品,做好生产的准备。由于购买了设备、原材 料等,所以企业资产总计是呈增长的。处于初创期的企业意味着资 金只出无进,而且根据规则,企业第一年只能卖低端产品,导致资 金流出要大于资金流入,所以企业的营业利润、利润总额以及净利 润均呈负增长。 第二年,在扣除一系列费用之后,虽然公司资金有剩余,但还不足以满足公司本年的经营,所以我们选择了借入长期借款来满足公

司经营。在这一年企业继续购进原材料和设备来扩大生产,实现产 品多样化,同时加之上年所剩产成品使得本年资产总额继续上涨。 本年我们在销售低端产品的基础上增加了中端产品的销售,这一举 措让我们尝到了销售收入的甜头,公司营业利润以及净利润相比上 一年有大幅增长,呈正增长趋势,销售利润率也呈现上涨之势。 第三年,我们不甘于平稳的经营模式,决定扩大生产量,增加厂房和设备,并开始进军高端市场。虽然随之而来的是高额的成本费用,但由于我们公司所占的市场份额比重较高,所以销售收入也是 不菲的,营业利润及净利润几乎高出上一年的50%,销售利润率、 净资产收益率等盈利指标的增长也是可观的。 在第四年到第八年期间,我们企业本着平稳中有突破的精神,继续填置设备,积极扩大生产量,虽然在这期间存在销售状况下降的 情况,但总体销售状况是可观的。由于一些销售收入有回款期限, 所以也导致了企业资金缺乏,只能依靠借入长期贷款来满足企业经 营需求,并且在第七年我们也通过发行股票的方式来筹集资金。总 体而言,这几年的销售收入总是处于波动之中,第六年和第七年达 到最高,销售成本以及各项费用的支出情况也并不稳定,这使得企 业营业利润和净利润无法呈现出一个平稳的增长态势,造成这一结 果的原因之一可能是财务预算工作做得不够细致准确,对于预计销 售量的考虑过于简单。 (三)成本及财务指标分析 从费用控制来看,财务费用比较稳定,在第七年因为发行股票财务费用激增,在其他年份均低于行业水平,主要是我们每年从银行 借债不多,也没有出现过应收账款贴现的现象,表示我们从一开始 财务预算就是较合理的,没有出现过资金严重短缺的年份,但是由 于对系统了解不够充分,我们企业在后两年出现了紧急借款的现象,而且借款数目比较小,这说明在后两期由于业务大,成本高,主要 是原材料购买多,我们企业现金流出现断裂,应该在前期做多些贷款,避免出现紧急贷款这种失误。其次是管理费用,从管理费用分 年趋势图看,公司第一年管理费用最高,达到350000元,主要原因 是购买生产线,第二年、第三年管理费用分别是142000元、157500

财务管理实训心得

财务管理实训心得体会 为期一周的财务管理实训结束了,这一周的实习让我深深感到理论和实践的巨大差异。原本自认为财务管理这门课学得不错,但当模拟到真实工作环境中时,却感到力不从心。大量的数据,业务以及分析是我完全没有预料到的。尽管有些可以运用所学的理论知识解决,但是在许多时候并没有想象的那么简单和顺利。整个实训包括以下几个部分: 1、财务分析报告:在财务分析报告中,又包括三方面内容:水平分析、垂直分析和财务效率指标分析。水平分析是对连续两年的报表历史数据进行分析,进行横向数据对比,通过差异额及差异率对企业经营的变化作出分析。垂直分析是对连续两年的报表历史数据进行分析,通过纵向的相对指标看出各项目对总资产的影响,再通过差额比较出两年数据间的不同而得到企业经营状况的差异及趋势。财务效率指标,通过对企业两年的偿债能力分析、营运能力分析、盈利能力分析和增长能力分析得到企业在各个方面的能力,尽管这些指标存在一定的误区,但也能从一定程度上了解到企业的很多实际情况。 2、预算报表:预算报表是全面预算管理的一部分内容,根据经验数据(销售量、单价),先计算出销售总额得出了预计的首先计划;再凭借着以销定产的思路,抛出库存量,计算得到生产量及需要采购的量,而得到费用支出计划表;然后再依次算出预计直接人工、预计制造费用、预计销售及管理费用,从而可填列现金预算表。通过上述工

作,我们就可以计算得到预计的资产负债表和利润表。 3、资金筹集管理:根据实验资料的要求,企业预计的借款及还款金额和时间,我们可以填制还款计划表:由资金的总需求量减去利润留用和折旧(非付现成本)剩下的就需要外部融资,正如该公司向银行举债。 4、投资财务可行性分析报告:该报告是假设企业投资一条新生产线,而在未来五年生产经营而取得收益。同样我们用以销定产的思路,先根据销售量估算出现金收入估算表,然后在估算出直接材料、直接人工、制造费用销售及管理费用,再得出现金流量估算表,最后根据上述数据就可以计算得到净现值、获利指数、内含报酬率和投资回收期这些财务指标。再通过这些财务指标的数据来分析得出此投资是否可行。 在我看来,第一部分必须从全局上准确把握整个趋势,并且通过一层层仔细分析,最终找出导致变化的因素。比如说:公司期末负债比期初增加了14.94%,主要是由于流动负债的增加,而它的增加又是因为短期借款大幅上升。只有这样才能有针对性地对其进行改善。除此之外我发现自己对企业财务报表分析的基本方法和技巧不熟练。像杜邦分析、改进的杜邦分析都不清楚,因此在做的过程中对数字感觉很模糊,没有十足的把握。第二部分并不难,最重要的是要细心和耐心。虽然做财务管理工作有很多相同的重复工作,但是却是容不得一点马虎的,因为一个小小的错误也会造成重大的财务损失。

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

实验一进程管理 1.实验目的: (1)加深对进程概念的理解,明确进程和程序的区别; (2)进一步认识并发执行的实质; (3)分析进程争用资源的现象,学习解决进程互斥的方法; (4)了解Linux系统中进程通信的基本原理。 2.实验预备内容 (1)阅读Linux的sched.h源码文件,加深对进程管理概念的理解; (2)阅读Linux的fork()源码文件,分析进程的创建过程。 3.实验内容 (1)进程的创建: 编写一段程序,使用系统调用fork() 创建两个子进程。当此程序运行时,在系统中有一个父进程和两个子进程活动。让每一个进程在屏幕上显示一个字符:父进程显示字符“a”,子进程分别显示字符“b”和“c”。试观察记录屏幕上的显示结果,并分析原因。 源代码如下: #include #include #include #include #include int main(int argc,char* argv[]) { pid_t pid1,pid2; pid1 = fork(); if(pid1<0){ fprintf(stderr,"childprocess1 failed"); exit(-1); } else if(pid1 == 0){ printf("b\n"); } 1/11

else{ pid2 = fork(); if(pid2<0){ fprintf(stderr,"childprocess1 failed"); exit(-1); } else if(pid2 == 0){ printf("c\n"); } else{ printf("a\n"); sleep(2); exit(0); } } return 0; } 结果如下: 分析原因: pid=fork(); 操作系统创建一个新的进程(子进程),并且在进程表中相应为它建立一个新的表项。新进程和原有进程的可执行程序是同一个程序;上下文和数据,绝大部分就是原进程(父进程)的拷贝,但它们是两个相互独立的进程!因此,这三个进程哪个先执行,哪个后执行,完全取决于操作系统的调度,没有固定的顺序。 (2)进程的控制 修改已经编写的程序,将每个进程输出一个字符改为每个进程输出一句话,再观察程序执行时屏幕上出现的现象,并分析原因。 将父进程的输出改为father process completed 2/11

嵌入式实时操作系统实验报告

嵌入式实时操作系统实验报告 任务间通信机制的建立 系别计算机与电子系 专业班级***** 学生姓名****** 指导教师 ****** 提交日期 2012 年 4 月 1 日

一、实验目的 掌握在基于嵌入式实时操作系统μC/OS-II的应用中,任务使用信号量的一般原理。掌握在基于优先级的可抢占嵌入式实时操作系统的应用中,出现优先级反转现象的原理及解决优先级反转的策略——优先级继承的原理。 二、实验内容 1.建立并熟悉Borland C 编译及调试环境。 2.使用课本配套光盘中第五章的例程运行(例5-4,例5-5,例5-6),观察运行结果,掌握信号量的基本原理及使用方法,理解出现优先级反转现象的根本原因并提出解决方案。 3.试编写一个应用程序,采用计数器型信号量(初值为2),有3个用户任务需要此信号量,它们轮流使用此信号量,在同一时刻只有两个任务能使用信号量,当其中一个任务获得信号量时向屏幕打印“TASK N get the signal”。观察程序运行结果并记录。 4. 试编写一个应用程序实现例5-7的内容,即用优先级继承的方法解决优先级反转的问题,观察程序运行结果并记录。 5.在例5-8基础上修改程序增加一个任务HerTask,它和YouTask一样从邮箱Str_Box里取消息并打印出来,打印信息中增加任务标识,即由哪个任务打印的;MyTask发送消息改为当Times为5的倍数时才发送,HerTask接收消息采用无等待方式,如果邮箱为空,则输出“The mailbox is empty”, 观察程序运行结果并记录。 三、实验原理 1. 信号量 μC/OS-II中的信号量由两部分组成:一个是信号量的计数值,它是一个16位的无符号整数(0 到65,535之间);另一个是由等待该信号量的任务组成的等待任务表。用户要在OS_CFG.H中将OS_SEM_EN开关量常数置成1,这样μC/OS-II 才能支持信号量。

财务管理实训报告总结三篇】

财务管理实训报告总结【三篇】 篇一 财务管理技能实训是一种理论知识与实践技能有效结合与综合使用的训练平台。这学期财务管理实训的几次模拟经营课程,让我受益颇多。我们小组经营的公司是电子科技有限公司,我在公司担任的是资金经理的角色,主要负责现金流量表的预测和管理。我同我们小组成员一起来对我们模拟公司的经营实行了决策和管理。因为我们公司第一季度经营良好,第三季度有所下降,从第五季度开始净利润都出现了稳定的增长。所以,接下来我将对公司第一、第二、第三、第五、第六季度的现金流量表的一些情况做简短的分析,同时,总结出一些我在这次的模拟经营实训的几点心得。 现金流量是投资决策考虑的关键指标,它是实行企业价值判断的重要指标,是企业持续经营的基本保障,也是企业扩大再生产的资源保障,同时还是影响企业流动性强弱的决定因素。对于企业来说,若在购买生产线之前未对预计当期现金流出和下季初费用扣除加以计算,就无法安排好筹资案,企业将很可能出现资金链的断裂。如果通过紧急贷款补足负的现金流量,之后只好通过借款维持经营,借款的额度又受财务状况的直接影响,这样的话,企业容易走入到一个财务困境中。所以,科学地分析和利用现金流量表是报表使用者实行准确决策的前提之一。 (一)第一季度因为公司成立刚刚成立,需要购买原材料,生产设备等基础设施以及雇佣工人和产房租赁,从而公司产生了一批投资资金和运营资金以及劳务资金流出。但是,公司向银行贷款,填补了资金缺失,使得本季度期末现金及现金等价物余额达到了509800元。现金流量表具体情况如下:(1)经营活动产生的现金流中:购买商品、接受劳务支付现金304200元;支付给职工以及职工支付的现金150000元;支付的其他与经营活动相关的现金338700元(2)投资活动产生的现

操作系统实验报告

实验报告 实验课程名称:操作系统 实验地点:南主楼七楼机房 2018—2019学年(一)学期 2018年 9月至 2019 年 1 月 专业: 班级: 学号: 姓名: 指导老师:刘一男

实验一 实验项目:分时系统模拟 实验学时:2实验日期: 2018-10-25 成绩: 实验目的利用程序设计语言模拟分时系统中多个进程按时间片轮转调度算法进行进程调度的过程; 假设有五个进程A,B,C,D,E,它们的到达时间及要求服务的时间分别为:进程名 A B C D E 到达时间0 1 2 3 4 服务时间 4 3 4 2 4 时间片大小为1,利用程序模拟A,B,C,D,E五个进程按时间片轮转的调度及执行过程并计算各进程的周转时间及带权周转时间。 执行过程并计算各进程的周转时间及带权周转时间。 轮转调度:BDACE

(1)修改时间片大小为2,利用程序模拟A,B,C,D,E五个进程按时间片轮转的调度及执行过程并计算各进程的周转时间及带权周转时间。 轮转调度:ADBCE (2)修改时间片大小为4,利用程序模拟A,B,C,D,E五个进程按时间片轮转的调度及执行过程并计算各进程的周转时间及带权周转时间.

顺序:ABCDE 1、思考 时间片的大小对调度算法产生什么影响?对计算机的性能产生什么影响?答:通过对时间片轮转调度算法中进程最后一次执行时间片分配的优化,提出了一种改进的时间片轮转调度算法,该算法具有更好的实时性,同时减少了任务调度次数和进程切换次数,降低了系统开销,提升了CPU的运行效率,使操作系统的性能得到了一定的提高。 A B C D E 时间片为1 周转时间12 9 14 8 13 3 3 3.5 4 3.25 带权周转 时间 时间片为2 周转时间8 12 13 7 13 2 4 3.25 3.5 3.25 带权周转 时间 时间片为4 周转时间 4 6 9 10 13 1 2 2.25 5 3.25 带权周转 时间

财务管理模拟实习报告doc

财务管理模拟实习报告 篇一:财务管理模拟实验报告 财务管理模拟实验报告 一、实验过程 1、组建模拟公司,建立管理团队 以小组为单位组建模拟公司,注册公司名称,建立管理团队(每组6人),准备参与模拟竞争。首先,推选公司总裁,然后,由总裁根据公司生产经营管理的需要进行职能分工,确定财务总监、市场总监、销售总监、供应总监、信息总监等岗位人选,并明确各自具体职责。 2、规划公司经营,编制财务预算 在熟悉模拟公司市场竞争规则的前提下,各公司召开年度财务计划工作会议,对公司目前所处的外部经营环境和内部运营条件进行分析,研究生产经营管理过程中蕴藏着的有利机会和主要威胁,确立公司经营战略和财务管理目标,编制年度财务预算。 公司经营管理战略包括新产品开发战略、新市场进入战略、投资战略、竞争战略等。 财务管理目标可选择利润最大化、股东财富最大化或企业价值最大化等目标。 年度财务预算包括现金预算、生产预算、综合费用预算、销售预算、广告费预算、经营预算、投资预算、管理费用预

算、财务费用预算等。 3、经营模拟公司,开展财务活动 每年年初,根据公司对市场的分析,依据广告费预算,参加产品订货会,支付广告费,登记销售订单;根据上年度财务成果,支付应交税费、应付股利。由于我公司前两年亏损高达38百万,所以在以后年度需将亏损补足才能计提所得税,股利分配也是到第五年盈利较多才开始分配,第六年也采用固定股利支付率政策进行了股利分配。 每年度,根据公司短期融资需要,申请或偿还短期借款,投资(变卖或转产)生产线,订购原材料,支付应付账款,原材料入库,产品生产,按订单交货,收回应收账款,新产品研发投资,支付公司行政管理费。为了赢利,于第一年一季度开始研发乙产品,同时开始安装半自动生产线一条来生产乙产品,为了扩大生产,到第二年一季度租入Y厂房来安装生产线,另外又安装一条半自动生产线生产乙产品,应市场需求,第三年一季度,又为了合理生产乙产品,又开始安装办自动生产线。每年年末,根据公司长期资金需求,确定具体筹资方式,包括申请或归还长期贷款、发行股票等,新市场开拓投资,ISO资格认证投资,支付设备维修费,构建或融资租入厂房,计提固定资产折旧,进行股利分配。我公司于第一年年末申请了四年期长期贷款83百万,后来又借了7百万,总计90百万,第三年年末发行了四年期债券24

进程管理_实验报告一流程图

实验一 课程名称:操作系统 课程类型:必修 实验项目名称:进程管理 实验题目:短作业优先算法、动态可剥夺优先数算法和基本循环轮转算法。 一、实验目的 进程是操作系统最重要的概念之一,进程调度又是操作系统核心的主要内容。本实验要求学生独立的用高级语言编写和调试一个简单的模拟进程调度的程序。通过本实验,加深学生理解有关进程控制块、进程队列的概念,并体会和了解短作业优先、优先数和时间片轮转调度算法的具体实施办法。 二、实验要求及实验环境 (1)设计一个有n 个进程的进程调度程序(具体个数可由键盘输入)。每一个进程用一个进程控制块PCB 来代表。PCB 中应包含下列信息:进程名、进程优先数、进程的状态、进程需要运行的时间及利用CPU运行的时间等。进程的个数、各进程的优先数、轮转时间片数以及进程运行需要地时间可由

键盘输入。 (2)调度程序应包含2~3 种不同的调度算法,运行时可任选一种。 (3)每个进程处于运行Run、就绪ready 和完成Finish 三种状态之一,假定初始状态都为就绪状态ready。(也可没有Finish状态,可以在设计程序时实现处以Finish状态的进程删掉)。 (4)系统能显示各进程状态和参数的变化情况。(5)动态可剥夺优先数算法是:在创建进程时给定一个初始的优先数,当进程获得一次cpu后其优先数就减少1,如果就绪队列中有优先级更高的将剥夺运行中的进程。 三、设计思想 (本程序中的用到的所有数据类型的定义,主程序的流程图及各程序模块之间的调用关系) 1.程序流程图 (见下图) 2.逻辑设计 使用链表表示就绪队列,每个元素包括进程名、进程优先数、进程的状态、进程需要运行的时间及利用CPU运行的时间等信息。 该结构需支持以下操作:取头节点,在表尾插入节

实时操作系统实验报告2

实时操作系统实验报告 专业:11通信工程 学号:20110306136 姓名: 王帅 指导老师:申屠浩

实验二 任务管理实验 实验目的: 1、理解任务管理的基本原理,了解任务的各个基本状态及其变迁过程; 2、掌握μC/OS -II 中任务管理的基本方法(挂起、解挂); 3、熟练使用μC/OS -II 任务管理的基本系统调用。 实验要求与思路: 为了体现任务的各个基本状态及其变迁过程,本实验设计了T0、T1和T3三个任务,它们交替运行,如图2-2所示。 T0 T1 T2 T3 T4 T5 T6 T7 T8 图2-2 注意: 图中的栅格并不代表严格的时间刻度,而仅仅表现各任务启动和执行的相对先后关系。 说明: 在系统完成初始化后,可以先创建并启动优先级最低的TaskStart ,由它创建其他3个应用任务T0、T1和T2,之后整个系 T0 T2 T1 T0 T1 T2 T1 T0

统的运行流程如下: 1)优先级最高的T0开始执行,之后T0挂起自己; 2)然后系统调度选中T1开始执行,之后T1挂起自己; 3)接着系统调度选中T2,之后唤醒T0; 4)如此循环 实现提示: 在启动任务中创建三个任务后,应挂起任务1和任务2。 在每个任务恢复其它任务并挂起自己之前,显示当前三个任务的状态,并延时1秒。 函数说明: void PC_GetDateTime (char *s); 获取"YYYY-MM-DD HH:MM:SS"格式的时间字串存放在字符串s中,s的长度最少为21字节。 void PC_DispStr (INT8U x, INT8U y, INT8U *s, INT8U color); 在y行x列以color颜色值显示字串s,注意color由背景色和前景色两种颜色构成。 INT8U OSTimeDlyHMSM (INT8U hours, INT8U minutes, INT8U seconds, INT16U milli); 按时、分、秒、毫秒设置进行延时。 void OSTimeDly (INT16U ticks) 按ticks值进行延时,1 ticks一般为10ms。 INT32U OSTimeGet (void)

相关文档
最新文档