本文整理匯總了Python中priorityQueue.PriorityQueue.addPcb方法的典型用法代碼示例。如果您正苦於以下問題:Python PriorityQueue.addPcb方法的具體用法?Python PriorityQueue.addPcb怎麽用?Python PriorityQueue.addPcb使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類priorityQueue.PriorityQueue
的用法示例。
在下文中一共展示了PriorityQueue.addPcb方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: Scheduler
# 需要導入模塊: from priorityQueue import PriorityQueue [as 別名]
# 或者: from priorityQueue.PriorityQueue import addPcb [as 別名]
class Scheduler():
def __init__(self, aCpu):
self.currentQueue = FifoQueue()
self.cpu = aCpu
def getNextPcb(self):
return self.currentQueue.getMax()
def addPcb(self, pcb):
if(self.currentQueue.isEmpty() and not(self.cpu.havePcb())):
pcb.toRunning()
self.cpu.assignPcb(pcb)
else:
self.currentQueue.addPcb(pcb)
def setFIFOMode(self):
self.currentQueue = FifoQueue()
def setPriorityMode(self):
self.currentQueue = PriorityQueue(3,3)
def removePid(self, aPid):
self.currentQueue.removePid(aPid)
示例2: PriorityQueueTest
# 需要導入模塊: from priorityQueue import PriorityQueue [as 別名]
# 或者: from priorityQueue.PriorityQueue import addPcb [as 別名]
class PriorityQueueTest(unittest.TestCase):
def setUp(self):
self.priority = PriorityQueue(3,5)
self.aPcb1 = Mock()
when(self.aPcb1).getPriority().thenReturn(2)
self.aPcb2 = Mock()
when(self.aPcb2).getPriority().thenReturn(2)
def test_addPcb_initialAdd(self):
self.priority.addPcb(self.aPcb1)
chance = self.priority.table.get(6)
assert (chance.elementos[0] == self.aPcb1)
def test_addPcb_withPcb(self):
self.priority.addPcb(self.aPcb1)
self.priority.addPcb(self.aPcb2)
chance = self.priority.table.get(6)
assert (chance.elementos[0] == self.aPcb2)
assert (chance.elementos[1] == self.aPcb1)
def test_getMax(self):
self.priority.addPcb(self.aPcb1)
self.priority.addPcb(self.aPcb2)
aPcb3 = Mock()
when(aPcb3).getPriority().thenReturn(4)
self.priority.addPcb(aPcb3)
assert (self.priority.getMax() == aPcb3)
assert (self.priority.getMax() == self.aPcb1)
def test_cleanChances(self):
chan1 = Chance()
chan2 = Chance()
chan3 = Chance()
aPcb = Mock()
chan2.elementos = [aPcb]
self.priority.table = {1:chan1,2:chan2,3:chan3}
assert(self.priority.table[1] == chan1)
assert(self.priority.table[2] == chan2)
assert(self.priority.table[3] == chan3)
assert(len(self.priority.table) == 3)
self.priority.cleanChances()
assert(len(self.priority.table) == 1)
assert(self.priority.table[2] == chan2)