golang模拟动态高优先权优先调度算法
实验二 动态高优先权优先调度
实验内容
模拟实现动态高优先权优先(若数值越大优先权越高,每运行一个时间单位优先权-n,若数值越小优先权越高,没运行一个时间单位优先权+n),具体如下:
设置进程体:进程名,进程的到达时间,服务时间,初始优先权,进程状态(W——等待,R——运行,F——完成),进程间的链接指针
进程初始化:由用户输入进程名、服务时间、初始优先权进行初始化,同时,初始化进程的状态为W。
显示函数:在进程调度前、调度中和调度后进行显示。
排序函数:对就绪状态的进程按照优先权排序。优先权相同时进入等待队列时间早的进程在前。注意考虑到达时间
调度函数:每次从等待队列队首调度优先权最高的进程执行,状态变化。并在执行一个时间单位后优先权变化,服务时间变化,状态变化。当服务时间为0时,状态变为F。
删除函数:撤销状态为F的进程。
实验要求
1、 测试数据可以随即输入或从文件中读入。
2、 必须要考虑到进程的到达时间
3、 最终能够计算每一个进程的周转时间。
实验代码
1.txt
process1 W
process2 W
process3 W
process5 W
process4 W
main.go
package main import (
"bufio"
"container/heap"
"fmt"
"os"
"strconv"
"strings"
"time"
) type Item struct {
name string
priority int
index int
arrival int
service int
oldservice int
state string
} type PriorityQueue []*Item func (pq PriorityQueue) Len() int { return len(pq) } func (pq PriorityQueue) Less(i, j int) bool { if pq[i].priority == pq[j].priority {
return pq[i].service < pq[i].service
}
return pq[i].priority > pq[j].priority
} func (pq PriorityQueue) Swap(i, j int) {
pq[i], pq[j] = pq[j], pq[i]
pq[i].index = i
pq[j].index = j
} func (pq *PriorityQueue) Push(x interface{}) {
n := len(*pq)
item := x.(*Item)
item.index = n
*pq = append(*pq, item)
} //优先队列的Pop并不是用这个Pop,最后的元素并不是优先级最高的!
func (pq *PriorityQueue) Pop() interface{} {
old := *pq
n := len(old)
item := old[n-]
item.index = -
*pq = old[ : n-]
return item
} func (pq *PriorityQueue) Top() *Item {
item := heap.Pop(pq).(*Item)
heap.Push(pq, item)
return item
} func (pq *PriorityQueue) update(item *Item, priority, service int, state string) {
item.priority = priority
item.service = service
item.state = state
heap.Fix(pq, item.index)
} //创建优先队列
var pq = make(PriorityQueue, ) func main() {
f, err := os.OpenFile("1.txt", os.O_RDONLY, )
if err != nil {
fmt.Println("没有找到1.txt!")
os.Exit()
}
fmt.Println("请输入每秒改变优先级n")
n :=
fmt.Scan(&n)
reader := bufio.NewReader(f) for i := ; i < ; i++ {
//每次读取一行
buf, _, _ := reader.ReadLine()
sli := strings.Fields(string(buf))
priint, _ := strconv.Atoi(sli[])
arrint, _ := strconv.Atoi(sli[])
serint, _ := strconv.Atoi(sli[])
//创建实例
one := &Item{
name: sli[],
priority: priint,
index: i,
arrival: arrint,
service: serint,
oldservice: serint,
state: sli[],
}
heap.Push(&pq, one)
}
//初始化堆
heap.Init(&pq)
fmt.Println("请输入第x秒后的状态:")
x :=
fmt.Scan(&x)
//执行, 初始总数n为5,x为循环次数 num :=
for second := ; second <= x; second++ { time.Sleep(time.Second)
// pq[num] != heap.Pop(*pq)!!! //临时优先队列
var tempq = make(PriorityQueue, ) //遍历所有堆元素,仅pq[0]优先级最高!
for i := ; i < num; i++ {
onepq := pq[i] if onepq.state == "F" {
//添加到tempq
tempq = append(tempq, onepq)
continue
} //服务时间不为0,就让其-1,state设为R
if onepq.service != {
if i == {
//优先级最高
onepq.priority = pq[i].priority - n
onepq.service = pq[i].service -
onepq.state = "R"
} else {
//堆里其他元素
onepq.priority = pq[i].priority + n
onepq.state = "W"
}
} else {
//service=0, state设为F
onepq.state = "F"
} //添加到tempq
tempq = append(tempq, onepq)
} //删除堆里所有元素
for pq.Len() > {
heap.Pop(&pq)
} //把所有元素加到堆里
for _, v := range tempq {
heap.Push(&pq, v)
} //输出
fmt.Printf("\n第%d秒的状态表示\n", second)
fmt.Println("进程名 | 服务时间 | 目前优先级 | 进程状态 | 平均周转时间") //输出堆
for i := ; i < num; i++ {
if pq[i].oldservice == pq[i].service {
fmt.Printf("%v %v %v %v 0\n", pq[i].name, pq[i].service, pq[i].priority, pq[i].state)
} else {
fmt.Printf("%v %v %v %v %v\n", pq[i].name, pq[i].service, pq[i].priority, pq[i].state, (second-pq[i].arrival)*1.0/(pq[i].oldservice-pq[i].service))
} }
}
} /*
使用了golang的container/heap包,需要手动实现less/len/swap/push/pop方法,这里也自定义了update和top方法,需要注意有以下几点:
1. heap并不是按优先级排序的,所以不能用for遍历,仅pq[0]优先级最高
2. 在遍历堆内所有节点时不能直接update,因为fix方法会重新构建堆,我这里使用的方式是用切片来保存堆中所有的元素,空堆后再一次性push
*/
实验截图
前4秒状态:

后2秒状态:

golang模拟动态高优先权优先调度算法的更多相关文章
- 利用python画出动态高优先权优先调度
之前写过一个文章. 利用python画出SJF调度图 动态高度优先权优先调度 动态优先权调度算法,以就绪队列中各个进程的优先权作为进程调度的依据.各个进程的优先权在创建进程时所赋予,随着进程的推进或其 ...
- 在WPF中使用PlaneProjection模拟动态3D效果
原文:在WPF中使用PlaneProjection模拟动态3D效果 虽然在WPF中也集成了3D呈现的功能,在简单的3D应用中,有时候并不需要真实光影的3D场景.毕竟使用3D引擎会消耗很多资源,有时候使 ...
- Golang模拟用户登陆,突破教务系统
目录 一.Golang模拟用户登陆,突破教务系统 1.1 请求登陆页面 1.2 抓包分析登陆请求 1.3 golang使用js引擎合成salt 1.4 模拟表单提交,完成登陆 1.5 进入成绩查询页, ...
- Golang编写动态库实现回调函数
Golang编写动态库实现回调函数 我们现在要做一个动态库,但是C++实在是比较难,于是就想能不能用更简单的golang来实现,golang也就是最近的版本才支持编译成动态库,在网上也没找到可用的案例 ...
- golang调用动态库
测试动态库 test_so.h int test_so_func(int a,int b); test_so.c #include "test_so.h" int test_so_ ...
- NFS-heartbeat-drbd模拟NFS高可用
NFS介绍: NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源.在NFS的应用中,本地NFS ...
- JAVA 模拟瞬间高并发
如何模拟一个并发?当时我的回答虽然也可以算是正确的,但自己感觉缺乏实际可以操作的细节,只有一个大概的描述. 当时我的回答是:“线程全部在同一节点wait,然后在某个节点notifyAll.” 面试官: ...
- UnityShader - 模拟动态光照特效
模型贴片 + 特效Shader = 动态光照特效 效果是这样的: 做法简单粗暴,直接使用模型贴片: shader上使用了noise只是提供一种思路,也有更简单的方法代替
- Golang: 模拟搜索引擎爬虫
最近网站需要针对百度做 SEO 优化,用 Go 语言写了个测试程序,模拟一下百度的爬虫,看看返回的内容是否正确. 代码很简单,就是发送一个请求,把百度相关的信息放入请求头中即可,代码如下: packa ...
随机推荐
- noip2010 真题练习 2017.2.18
第一题比较简单,用exist数组判断是否在循环队列中,就可实现线性算法. Code #include<iostream> #include<cstdio> #include&l ...
- python函数作用域LEGB
我们的在学习Python函数的时候,经常会遇到很多定义域的问题,全部变量,内部变量,内部嵌入的函数,等等,Python是如何查找的呢?以及Python又是按照什么顺序来查找的呢?这里做一个顺序的说明 ...
- uboot启动提示Error, wrong i2c adapter 0 max 0 possible后卡住了怎么办
答:这个与i2c驱动有关,应该使能i2c驱动相关的配置项
- Cent OS 常用配置命令
1.ifconfig #查看网络接口状态 2.ifconfig –a #查看主机所有接口的情况 3.ifconfig eth0 192.168.1.106 netmask 255.255.255 ...
- Faster-RCNN-TensorFlow-Python3.5 在Ubuntu16.04下的配置方法
目录 Faster-RCNN-TensorFlow-Python3.5 在Ubuntu16.04下的配置方法 安装过程 1. 深度学习环境Tensorflow的安装 2. 安装python包 3. ...
- Axure RP 8.0 Licence
新版本:(比如 Axure RP 8.0.0 3319)Licensee:米 业成 (STUDENT)Key:nFmqBBvEqdvbiUjy8NZiyWiRSg3yO+PtZ8c9wdwxWse4W ...
- 浅谈PHP5中垃圾回收算法
原文链接:http://www.cnblogs.com/leoo2sk/archive/2011/02/27/php-gc.html PHP是一门托管型语言,在PHP编程中程序员不需要手工处理内存资源 ...
- Win7下怎么设置让远程桌面连接记住密码下次登录不需再输入
远程桌面连接功能想必大家都不会陌生吧,特别是使用VPS服务器的用户们经常会用到,为了服务器的安全每次都会把密码设置的很复制,但是这样也有一个麻烦,就是每次要桌面远程连接的时候都要输入这么复杂的密码,很 ...
- linux 系统调用号表
位于 /usr/include/asm/unistd.h 由于我是64位系统,所以有一些额外的东西.我的这个文件为下文 #ifndef _ASM_X86_UNISTD_H #define _ASM_X ...
- Java实现冒泡排序算法
一.基本思路: 冒泡排序是一种简单的交换类排序.其基本思路是,从头开始扫描待排序的元素,在扫描过程中依次对相邻元素进行比较,将关键字值大的元素后移.每经过 一趟排序后,关键字值最大的元素将移到末尾,此 ...