code:
#coding=utf-8
import sys,random,time
#produce a random
def randomTime():
return random.randint(1,20)
def randomValue():
return random.randint(60,100)
class pcb:
def __init__(self,ctime,cvalue,cname):
self.name=cname
self.time=ctime
self.value=cvalue
class myPriorityQueue:
def __init__(self):
self.q=[]
def length(self):
return len(self.q)
def insert(self,e):
i=0
if (len(self.q)!=0):
for i in range(len(self.q)):#i from 0 --- n-1
if e.value>self.q[i].value:
break
self.q.insert(i,e)
#print 'length=%d'%len(self.q),
#print "insert (time=%d,value=%d) into pq"%(e.time,e.value)
def get(self):
t=self.q[0]
del self.q[0]
return t
def display(self):
print 'current myPriorityQueue:'
for i in range(len(self.q)):
print 'name='+str(self.q[i].name),'value='+str(self.q[i].value),'time='+str(self.q[i].time)
print '---------------------------------'
class dispatchProcess:
def __init__(self,n):#瑙e喅鏂规n
if n==1:
self.solution=1
self.changetime=1
self.changevalue=3
#self.fuc={}
elif n==2:
pass
else:
print '[-]ERROR solutions'
def ProcessOneSecond(self):
global pq,runtime
runtime+=1
print 'run for %d senconds'%runtime,
e=pq.get()
if not e.time==1:
pq.insert(pcb(ctime=e.time-self.changetime,cvalue=e.value-self.changevalue,cname=e.name))
print '%s(%d,%d) run 1s ---> %s(%d,%d) '%(e.name,e.time,e.value,e.name,e.time-self.changetime,e.value-self.changevalue)
return e
def start(self):
global pq
if pq.length()==0:
print 'no process!'
else:
m=raw_input('Single-step debugging?(y/n):')
print 'process start running!'
if m=='y':
print 'enter n for next second'
print 'enter d for display status'
print 'enter e run to end!'
print 'enter q for exit'
while pq.length()!=0:
if m=='y':
t=raw_input('>')
if t=='n':
e=self.ProcessOneSecond()
#print '(%d,%d) run 1s ---> (%d,%d) '%(e.time,e.value,e.time-self.changetime,e.value-self.changevalue)
elif t=='d':
pq.display()
elif t=='q':
break
elif t=='e':
m='n'
else:
print '[-]ERROR INPUTS!'
else:
#while pq.length()!=0:
self.ProcessOneSecond()
time.sleep(1)
def init():
global n,pq,runtime
runtime=0;
n=raw_input('How many process do you want?(4~~8 suggested)\n>')
n=int(n,10)
print '[+]producing %d processes ...'%n
#produce
l={}
for i in range(n):
l[i]=pcb(cname=chr(ord('a')+i),ctime=randomTime(),cvalue=randomValue())
print 'have produced %d process (name=%s,time=%d,value=%d)'%(i,l[i].name,l[i].time,l[i].value)
c=raw_input('OK?(y/n):');
if c=='n':
sys.exit()
for i in range(n):
pq.insert(l[i])
#---------------------------------------------------------------------------next for second method
class pcb2:
def __init__(self,cname):
self.name=cname
self.timeSlice=random.randint(5,10)
self.usedTime=0
self.needTime=random.randint(10,30)
class RotateTimeSliceDispatch:
def __init__(self):
self.l=[]
n=raw_input('How many process do you want?(4~~8 suggested)\n>')
self.n=n=int(n,10)
print '[+]producing %d processes ...'%n
#produce
for i in range(n):
e=pcb2(cname=chr(ord('a')+i))
self.l.append(e)
print 'produce a process %s(timeSlice=%d,needTime=%d)'%(e.name,e.timeSlice,e.needTime)
self.runtime=0
def goOneSecond(self):
self.runtime+=1
self.l[0].needTime-=1
self.l[0].usedTime+=1
print '%d s.process %s run 1s. '%(self.runtime,self.l[0].name),
print 'timeSlice=%d,usedTime=%d,needTime=%d'%(self.l[0].timeSlice,self.l[0].usedTime,self.l[0].needTime)
if self.l[0].needTime==0:
print 'and it ends'
del self.l[0]
return
if self.l[0].usedTime==self.l[0].timeSlice:
t=self.l[0]
del self.l[0]
t.usedTime=0
self.l.append(t)
print 'and it goes to the last'
print
def start(self):
if len(self.l)==0: return
m=raw_input('Single-step debugging?(y/n):')
print 'process start running!'
if m=='y':
print 'enter n for next second'
print 'enter d for display status'
print 'enter e run to end!'
print 'enter q for exit'
while len(self.l):
time.sleep(1)
if m=='y':
t=raw_input('>')
if t=='n':
self.goOneSecond()
elif t=='d':
#show the queue
for i in range(len(self.l)):
print 'process %d is %s,timeSlice=%d,usedTime=%d,needTime=%d'%(i,self.l[i].name,self.l[i].timeSlice,self.l[i].usedTime,self.l[i].needTime)
elif t=='e':
m='n'
elif t=='q':
break
else:
print 'ERROR!'
continue
else:
self.goOneSecond()
if __name__=="__main__":
global f,pq,dp
pq=myPriorityQueue()
print '[+]1.优先权方法'
print '[+]2.时间片轮转法'
f=raw_input('>')
f=int(f,10)
if f==1:
dp=dispatchProcess(f)
init()
dp.start()
elif f==2:
rts=RotateTimeSliceDispatch()
rts.start()
else:
print '[-]ERROR!'
print 'All done'
运行结果:
[+]1.优先权方法
[+]2.时间片轮转法
1
How many process do you want?(4~~8 suggested)
5
[+]producing 5 processes …
have produced 0 process (name=a,time=2,value=71)
have produced 1 process (name=b,time=15,value=87)
have produced 2 process (name=c,time=19,value=87)
have produced 3 process (name=d,time=13,value=91)
have produced 4 process (name=e,time=15,value=97)
OK?(y/n):y
Single-step debugging?(y/n):y
process start running!
enter n for next second
enter d for display status
enter e run to end!
enter q for exit
n
run for 1 senconds e(15,97) run 1s —> e(14,94)
n
run for 2 senconds e(14,94) run 1s —> e(13,91)
d
current myPriorityQueue:
name=d value=91 time=13
name=e value=91 time=13
name=b value=87 time=15
name=c value=87 time=19
name=a value=71 time=2
e
run for 3 senconds d(13,91) run 1s —> d(12,88)
run for 4 senconds e(13,91) run 1s —> e(12,88)
run for 5 senconds d(12,88) run 1s —> d(11,85)
run for 6 senconds e(12,88) run 1s —> e(11,85)
run ……….
run for 64 senconds a(1,68) run 1s —> a(0,65)
All done[+]1.优先权方法
[+]2.时间片轮转法
2
How many process do you want?(4~~8 suggested)
5
[+]producing 5 processes …
produce a process a(timeSlice=7,needTime=14)
produce a process b(timeSlice=8,needTime=20)
produce a process c(timeSlice=7,needTime=13)
produce a process d(timeSlice=5,needTime=11)
produce a process e(timeSlice=8,needTime=27)
Single-step debugging?(y/n):y
process start running!
enter n for next second
enter d for display status
enter e run to end!
enter q for exit
n
1 s.process a run 1s. timeSlice=7,usedTime=1,needTime=13
d
process 0 is a,timeSlice=7,usedTime=1,needTime=13
process 1 is b,timeSlice=8,usedTime=0,needTime=20
process 2 is c,timeSlice=7,usedTime=0,needTime=13
process 3 is d,timeSlice=5,usedTime=0,needTime=11
process 4 is e,timeSlice=8,usedTime=0,needTime=27
n
2 s.process a run 1s. timeSlice=7,usedTime=2,needTime=12
d
process 0 is a,timeSlice=7,usedTime=2,needTime=12
process 1 is b,timeSlice=8,usedTime=0,needTime=20
process 2 is c,timeSlice=7,usedTime=0,needTime=13
process 3 is d,timeSlice=5,usedTime=0,needTime=11
process 4 is e,timeSlice=8,usedTime=0,needTime=27
e
3 s.process a run 1s. timeSlice=7,usedTime=3,needTime=11
4 s.process a run 1s. timeSlice=7,usedTime=4,needTime=10
5 s.process a run 1s. timeSlice=7,usedTime=5,needTime=9
6 s.process a run 1s. timeSlice=7,usedTime=6,needTime=8
7 s.process a run 1s. timeSlice=7,usedTime=7,needTime=7
and it goes to the last
8 s.process b run 1s. timeSlice=8,usedTime=1,needTime=19
9 s.process b run 1s. timeSlice=8,usedTime=2,needTime=18
10 s.process b run 1s. timeSlice=8,usedTime=3,needTime=17
11 s.process b run 1s. timeSlice=8,usedTime=4,needTime=16
12 s.process b run 1s. timeSlice=8,usedTime=5,needTime=15
13 s.process b run 1s. timeSlice=8,usedTime=6,needTime=14
14 s.process b run 1s. timeSlice=8,usedTime=7,needTime=13
15 s.process b run 1s. timeSlice=8,usedTime=8,needTime=12
and it goes to the last
16 s.process c run 1s. timeSlice=7,usedTime=1,needTime=12
17 s.process c run 1s. timeSlice=7,usedTime=2,needTime=11
18 s.process c run 1s. timeSlice=7,usedTime=3,needTime=10
19 s.process c run 1s. timeSlice=7,usedTime=4,needTime=9
20 s.process c run 1s. timeSlice=7,usedTime=5,needTime=8
21 s.process c run 1s. timeSlice=7,usedTime=6,needTime=7
22 s.process c run 1s. timeSlice=7,usedTime=7,needTime=6
and it goes to the last
23 s.process d run 1s. timeSlice=5,usedTime=1,needTime=10
24 s.process d run 1s. timeSlice=5,usedTime=2,needTime=9
25 s.process d run 1s. timeSlice=5,usedTime=3,needTime=8
26 s.process d run 1s. timeSlice=5,usedTime=4,needTime=7
27 s.process d run 1s. timeSlice=5,usedTime=5,needTime=6
and it goes to the last
28 s.process e run 1s. timeSlice=8,usedTime=1,needTime=26
29 s.process e run 1s. timeSlice=8,usedTime=2,needTime=25
30 s.process e run 1s. timeSlice=8,usedTime=3,needTime=24
31 s.process e run 1s. timeSlice=8,usedTime=4,needTime=23
32 s.process e run 1s. timeSlice=8,usedTime=5,needTime=22
33 s.process e run 1s. timeSlice=8,usedTime=6,needTime=21
34 s.process e run 1s. timeSlice=8,usedTime=7,needTime=20
35 s.process e run 1s. timeSlice=8,usedTime=8,needTime=19
and it goes to the last
36 s.process a run 1s. timeSlice=7,usedTime=1,needTime=6
37 s.process a run 1s. timeSlice=7,usedTime=2,needTime=5
38 s.process a run 1s. timeSlice=7,usedTime=3,needTime=4
39 s.process a run 1s. timeSlice=7,usedTime=4,needTime=3
40 s.process a run 1s. timeSlice=7,usedTime=5,needTime=2
41 s.process a run 1s. timeSlice=7,usedTime=6,needTime=1
42 s.process a run 1s. timeSlice=7,usedTime=7,needTime=0
and it ends
43 s.process b run 1s. timeSlice=8,usedTime=1,needTime=11
44 s.process b run 1s. timeSlice=8,usedTime=2,needTime=10
45 s.process b run 1s. timeSlice=8,usedTime=3,needTime=9
46 s.process b run 1s. timeSlice=8,usedTime=4,needTime=8
47 s.process b run 1s. timeSlice=8,usedTime=5,needTime=7
48 s.process b run 1s. timeSlice=8,usedTime=6,needTime=6
49 s.process b run 1s. timeSlice=8,usedTime=7,needTime=5
50 s.process b run 1s. timeSlice=8,usedTime=8,needTime=4
and it goes to the last
51 s.process c run 1s. timeSlice=7,usedTime=1,needTime=5
52 s.process c run 1s. timeSlice=7,usedTime=2,needTime=4
53 s.process c run 1s. timeSlice=7,usedTime=3,needTime=3
54 s.process c run 1s. timeSlice=7,usedTime=4,needTime=2
55 s.process c run 1s. timeSlice=7,usedTime=5,needTime=1
56 s.process c run 1s. timeSlice=7,usedTime=6,needTime=0
and it ends
57 s.process d run 1s. timeSlice=5,usedTime=1,needTime=5
58 s.process d run 1s. timeSlice=5,usedTime=2,needTime=4
59 s.process d run 1s. timeSlice=5,usedTime=3,needTime=3
60 s.process d run 1s. timeSlice=5,usedTime=4,needTime=2
61 s.process d run 1s. timeSlice=5,usedTime=5,needTime=1
and it goes to the last
62 s.process e run 1s. timeSlice=8,usedTime=1,needTime=18
63 s.process e run 1s. timeSlice=8,usedTime=2,needTime=17
64 s.process e run 1s. timeSlice=8,usedTime=3,needTime=16
65 s.process e run 1s. timeSlice=8,usedTime=4,needTime=15
66 s.process e run 1s. timeSlice=8,usedTime=5,needTime=14
67 s.process e run 1s. timeSlice=8,usedTime=6,needTime=13
68 s.process e run 1s. timeSlice=8,usedTime=7,needTime=12
69 s.process e run 1s. timeSlice=8,usedTime=8,needTime=11
and it goes to the last
70 s.process b run 1s. timeSlice=8,usedTime=1,needTime=3
71 s.process b run 1s. timeSlice=8,usedTime=2,needTime=2
72 s.process b run 1s. timeSlice=8,usedTime=3,needTime=1
73 s.process b run 1s. timeSlice=8,usedTime=4,needTime=0
and it ends
74 s.process d run 1s. timeSlice=5,usedTime=1,needTime=0
and it ends
75 s.process e run 1s. timeSlice=8,usedTime=1,needTime=10
76 s.process e run 1s. timeSlice=8,usedTime=2,needTime=9
77 s.process e run 1s. timeSlice=8,usedTime=3,needTime=8
78 s.process e run 1s. timeSlice=8,usedTime=4,needTime=7
79 s.process e run 1s. timeSlice=8,usedTime=5,needTime=6
80 s.process e run 1s. timeSlice=8,usedTime=6,needTime=5
81 s.process e run 1s. timeSlice=8,usedTime=7,needTime=4
82 s.process e run 1s. timeSlice=8,usedTime=8,needTime=3
and it goes to the last
83 s.process e run 1s. timeSlice=8,usedTime=1,needTime=2
84 s.process e run 1s. timeSlice=8,usedTime=2,needTime=1
85 s.process e run 1s. timeSlice=8,usedTime=3,needTime=0
and it ends
All done
难度不大,重在理解。