亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? dispatch.txt

?? 操作系統(tǒng)
?? TXT
字號:
#include<iostream>
#include<string>
#include <assert.h>
#include<queue>
#include<vector>
using namespace std; 
class dispatch{
	friend std::istream& operator>>(std::istream& input,dispatch& Dispatch);//友元函數(shù)dispatch輸入流
	friend std::ostream& operator<<(std::ostream& output,dispatch& Dispatch);//友元函數(shù)dispatch輸出流
private:
	int count;  //定義變量表示進程process的個數(shù)
	bool SF_FC;//標志選擇的調(diào)度算法類型
	double Tse,Wi;//總周轉(zhuǎn)時間和總帶權(quán)周轉(zhuǎn)時間
	typedef bool (*compare_type)(process&,process&);//定義指向函數(shù)的指針,實現(xiàn)不同調(diào)度算法選擇的實現(xiàn)
	compare_type compare_1,compare_2;//定義指向函數(shù)的指針,實現(xiàn)不同調(diào)度算法選擇的實現(xiàn)
	priority_queue<process,vector<process>,compare_type> PQueue;//定義按到達時間順序的隊列PQueue
	queue<process> Queue;//定義此隊列表示完成的進程
	vector<process> vec;
public:
	dispatch(bool sf_fc = true):count(0),SF_FC(sf_fc),Tse(0),Wi(0) {
		compare_1 = &compare_FSFC;
		compare_2 = &compare_SF;
		if (sf_fc == false){//當給定的標志為真時,表示FSFC調(diào)度算法
			PQueue = priority_queue<process,vector<process>,compare_type>(compare_1);
			cout<<"選擇的是最短進程優(yōu)先(搶占式)調(diào)度算法"<<endl;
		}
		else{
			PQueue = priority_queue<process,vector<process>,compare_type>(compare_1);
			cout<<"選擇的是先來先服務(wù)調(diào)度算法"<<endl;
		}
	}
	void FSFC(){//先來先服務(wù)的實現(xiàn)...
		int i =0;
		double atime ; //標志當前內(nèi)存中進程結(jié)束的時間點
		process *Pro1 = &PQueue.top();// 取隊首元素
		atime = (*Pro1).GETstart_time();
		while(i < count)
		{
			(*Pro1).Set_bvisited();
			cout<<(*Pro1)<<"  ";
			++i;
			atime=atime+(*Pro1).GETrun_time(); 
			(*Pro1).SETend_time(atime);
			if((*Pro1).Get_bvisited()){//如果當前進程已經(jīng)完成服務(wù)功能
				Tse = Tse +((*Pro1).GETend_time()-(*Pro1).GETstart_time());
				Wi = Wi + ((*Pro1).GETend_time()-(*Pro1).GETstart_time())/((*Pro1).GETrun_time());
				Queue.push(*Pro1);
			}
			else 
				cout<<"error!"<<endl;
			PQueue.pop();//刪除隊列中的隊首元素
			if(PQueue.empty() == false)
				process *Pro1 = &PQueue.top();// 取隊首元素
		}
	}
	void Short_No1(){
		double atime;//標志當前內(nèi)存中進程結(jié)束的時間點
		double btime;//表示內(nèi)存中進程剩余的運行時間
		double ctime;//表示執(zhí)行順序時間點
		int count1 = count;
		vector<process>::iterator iter,iter1,iter2;
		process *ptr = &PQueue.top();//對隊首元素的end_time()進行初始化
		(*ptr).SETend_time( (*ptr).GETrun_time());
		vec.push_back(PQueue.top());//取出第一個到達的進程,放入vector
		PQueue.pop();
		cout<<"******1"<<endl;
		iter=vec.begin();
		ctime = (*iter).GETstart_time();
		atime = (*iter).GETrun_time()+(*iter).GETstart_time();
		while(count1>0){
			cout<<"******2"<<endl;
			process *ptr;
			if(PQueue.empty()==false){
				ptr= &PQueue.top();//對隊首元素的end_time()進行初始化
				(*ptr).SETend_time( (*ptr).GETrun_time());
			}
			//ctime = (*ptr).GETstart_time();
			//btime = atime - ctime;
			//(*iter).SETend_time(btime);//設(shè)置運行進程的剩余時間
			while( PQueue.empty()==false && atime>(*ptr).GETstart_time()){//如果在進程運行期間有進程到達
				cout<<"******3"<<endl;
				ctime = (*ptr).GETstart_time();
				btime = atime - ctime;
				(*iter).SETend_time(btime);//設(shè)置運行進程的剩余時間
				cout<<"******4"<<endl;
				vec.push_back(*ptr);//把到達的進程放進vector中
				cout<<"******5"<<endl;
				iter = vec.begin();
				cout<<"*iter1 : "<<*iter<<endl;
				cout<<"atime :"<<atime<<endl;
				if( (*iter).GETend_time()>(*ptr).GETrun_time() ){
					cout<<"******6"<<endl;
					cout<<"*ptr :"<<*ptr<<endl;
					atime =(*ptr).GETstart_time() +(*ptr).GETrun_time();
					cout<<"atime :"<<atime<<endl;
					//ctime =(*ptr).GETstart_time();
					//btime =atime-ctime;
					//(*iter).SETend_time(btime);//設(shè)置運行進程的剩余時間
					sort(vec.begin(),vec.end(),compare_2); //若新進來的進程優(yōu)先級高,則排序,令優(yōu)先高的進程位置于vector第一個元素
					iter = vec.begin();
					cout<<"*iter2 :"<<*iter<<endl;
					if(PQueue.empty()==false){
						PQueue.pop();//刪除在到達時間隊列中的隊首進程信息
						if(PQueue.empty()==false)
							ptr =&PQueue.top();//取得修改后的到達時間隊列中的新隊首進程
					}
					//找到優(yōu)先級高的進程,則退出此循環(huán),重新進行小進程運行并查找時候有更高優(yōu)先級的進程到達
				}
				else{
					cout<<"******7"<<endl;
					if(PQueue.empty()==false){
						PQueue.pop(); //刪除在到達時間隊列中的隊首進程信息
						if(PQueue.empty()==false)
							ptr =&PQueue.top();//取得修改后的到達時間隊列中的新隊首進程
					}
				}
			}
			cout<<"******8"<<endl;
			iter1 =vec.begin();//取優(yōu)先級最高的進程
			ctime = atime;
			cout<<"atime :"<<atime<<endl;
			(*iter1).Set_bvisited(true);
			(*iter1).SETend_time(atime);
			Tse = Tse+(atime-(*iter1).GETstart_time());
			Wi  = Wi +(atime-(*iter1).GETstart_time())/((*iter).GETrun_time());
			Queue.push(*iter1);
			cout<<*iter1<<endl;
			vec.erase(iter1);
			--count1;//標志完全結(jié)束一個進程的運行
			cout<<"******9"<<endl;
			iter1=vec.begin();iter2=vec.end();
			if(iter1==iter2){
				if(PQueue.empty()==false){
					vec.push_back(PQueue.top());//取出第一個到達的進程,放入vector
					PQueue.pop();
					iter=vec.begin();
					ctime = (*iter).GETstart_time();
					atime = (*iter).GETend_time()+(*iter).GETstart_time();
				}
				break;
			}
			else{
				iter =vec.begin();
				atime = (*iter).GETend_time()+ctime;
			}
		}
	}
	void print(){
		process *ptr;
		int i = 1;
		//cout<<"進程調(diào)度信息如下:"<<endl;
		cout<<" **運行順序****進程名****到達時間****運行時間****結(jié)束時間****"<<endl;
		while (Queue.empty() == false){
			ptr = &Queue.front();
			cout<<"**"<<i<<"**********"<<(*ptr).GETname();
			cout<<"**********"<<(*ptr).GETstart_time();
			cout<<"**********"<<(*ptr).GETrun_time();
			cout<<"**********"<<(*ptr).GETend_time()<<"*****"<<endl;
			++i;
			Queue.pop();
		}
		cout<<"平均周轉(zhuǎn)時間:"<<(Tse/count)<<endl;
		cout<<"平均帶權(quán)周轉(zhuǎn)時間:"<<(Wi/count)<<endl;
	}
};
std::istream& operator>>(std::istream& input,dispatch& Dispatch){
	process Pro1;
	int count1=0;
	while(input>>(Pro1)){
		Dispatch.PQueue.push(Pro1);
		++count1;
	}
	Dispatch.count = count1;
	cout<<"共有進程數(shù)為 "<<Dispatch.count;
	return input;
}
std::ostream& operator<<(std::ostream& output,dispatch& Dispatch){
	int i=1;
	output<<"共有的進程數(shù)目:"<<Dispatch.count<<endl;
	output<<"進程名     到達時間     運行時間     "<<endl;
	while(i<= Dispatch.count){
		cout<<"...."<<endl;
		output<<Dispatch.PQueue.top()<<endl;
		Dispatch.PQueue.pop();
		++i;
		cout<<"....."<<endl;
	}
	cout<<"*******"<<endl;
	return output;
}
	
	

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
伊人婷婷欧美激情| 日本黄色一区二区| 91在线观看视频| 欧美成人性战久久| 亚洲丝袜精品丝袜在线| 午夜精品成人在线| 99这里都是精品| 日韩视频一区在线观看| 自拍偷在线精品自拍偷无码专区| 免费成人在线视频观看| 91影视在线播放| 久久先锋影音av鲁色资源网| 亚洲小说欧美激情另类| 不卡一区中文字幕| 日韩欧美亚洲国产另类| 亚洲制服丝袜一区| 91网上在线视频| 久久精品一区二区三区不卡牛牛| 香蕉加勒比综合久久| www.日韩在线| 欧美国产禁国产网站cc| 国内成人自拍视频| 欧美一区二区三区免费观看视频| 亚洲永久精品大片| 91视频精品在这里| 亚洲另类在线一区| 国产精品资源网站| 日韩限制级电影在线观看| 五月激情六月综合| 欧美日韩另类一区| 图片区小说区区亚洲影院| 91成人在线精品| 一区二区三区色| 欧美性猛片aaaaaaa做受| 依依成人精品视频| 欧美中文字幕一区二区三区| 一卡二卡三卡日韩欧美| 日本道色综合久久| 亚洲美女淫视频| 色网站国产精品| 一区二区欧美国产| 欧美视频在线一区| 日韩精品欧美成人高清一区二区| 欧美日韩一级黄| 丝袜美腿亚洲一区| 欧美成人a在线| 国产在线一区观看| 日本一区二区三区久久久久久久久不| 国产精品系列在线播放| 国产精品视频观看| 欧美在线观看视频一区二区三区| 亚洲综合久久av| 欧美久久久久久久久| 奇米影视一区二区三区小说| 久久综合九色欧美综合狠狠| 国产精品一区二区久久不卡 | 久久久亚洲精华液精华液精华液| 国内成人精品2018免费看| 欧美国产精品一区| 欧亚一区二区三区| 精品一区二区免费在线观看| 国产日韩亚洲欧美综合| 色播五月激情综合网| 日韩精品成人一区二区三区| 欧美精品一区二区高清在线观看| gogo大胆日本视频一区| 亚洲国产色一区| 日韩精品影音先锋| 一本色道久久综合亚洲91| 天堂一区二区在线| 国产精品久久久久久亚洲毛片| 在线观看日韩一区| 美国十次综合导航| 国产精品美女久久久久久久网站| 欧美日韩中字一区| 国产激情视频一区二区三区欧美| 亚洲人妖av一区二区| 日韩久久久久久| 色综合天天综合色综合av| 青青草91视频| 中文子幕无线码一区tr| 欧美日韩国产经典色站一区二区三区| 国产成人自拍网| 亚洲电影中文字幕在线观看| 欧美激情一区二区三区蜜桃视频 | 欧美日韩一区二区欧美激情| 国产一区美女在线| 污片在线观看一区二区| 亚洲色图在线看| 久久久久久综合| 69堂成人精品免费视频| 色噜噜久久综合| 国产高清成人在线| 欧美aaa在线| 亚洲自拍都市欧美小说| 国产精品美女视频| 久久精品一区二区三区av | 色婷婷综合久久久中文字幕| 国产资源在线一区| 日本不卡一区二区三区| 亚洲影视在线观看| 国产精品久久久久影院亚瑟| 久久久久久久久久久久久女国产乱 | 一区二区三区欧美日韩| 国产亚洲精品bt天堂精选| 亚洲一区在线观看免费观看电影高清| www久久久久| 91精品国产全国免费观看| 91黄色免费网站| fc2成人免费人成在线观看播放| 国产一区二区美女诱惑| 蜜桃精品在线观看| 亚洲午夜免费电影| 欧美极品少妇xxxxⅹ高跟鞋| xvideos.蜜桃一区二区| 欧美一卡2卡3卡4卡| 欧美日韩三级一区二区| 一本一道久久a久久精品综合蜜臀| 成人av在线一区二区| 成人免费高清在线| av在线综合网| av午夜一区麻豆| 91在线视频免费91| 在线视频中文字幕一区二区| 色美美综合视频| 欧美日韩成人在线一区| 制服丝袜成人动漫| 日韩美女视频在线| 久久久久久久久久久黄色| 国产亚洲欧美在线| 18欧美亚洲精品| 亚洲欧洲av另类| 亚洲精品日日夜夜| 五月天激情综合| 麻豆精品久久精品色综合| 国产美女在线精品| 成人av片在线观看| 91久久免费观看| 91精品久久久久久久99蜜桃 | 色婷婷亚洲婷婷| 精品视频一区 二区 三区| 日韩精品最新网址| 欧美国产精品中文字幕| 一区二区三区在线免费| 偷拍一区二区三区| 国产精品一二三在| 91福利在线导航| 日韩美女一区二区三区四区| 国产日韩影视精品| 亚洲成人三级小说| 九色porny丨国产精品| www.亚洲色图| 91精品国产综合久久久久久| 久久久噜噜噜久久中文字幕色伊伊| 中文字幕在线不卡视频| 一区二区三国产精华液| 久草精品在线观看| 97久久人人超碰| 精品乱码亚洲一区二区不卡| 亚洲欧美综合另类在线卡通| 丝袜亚洲另类欧美| 成人免费观看视频| 日韩三级在线免费观看| 国产精品久久精品日日| 婷婷开心激情综合| www.色综合.com| 日韩精品专区在线影院观看| 日韩毛片一二三区| 美国三级日本三级久久99 | 亚洲猫色日本管| 国内精品视频666| 精品污污网站免费看| 国产精品欧美一区喷水| 久久国内精品自在自线400部| 91女神在线视频| 国产女主播视频一区二区| 日韩不卡一区二区三区| 日本精品视频一区二区三区| 久久精品欧美日韩| 日本午夜一本久久久综合| 色欧美乱欧美15图片| 国产色婷婷亚洲99精品小说| 日欧美一区二区| 91麻豆成人久久精品二区三区| 精品对白一区国产伦| 日韩和欧美一区二区| 欧美午夜在线一二页| 最好看的中文字幕久久| 欧美精品在线一区二区| |精品福利一区二区三区| 国产乱码字幕精品高清av | 99久久精品国产导航| 久久久国际精品| 国产综合久久久久久鬼色 | 欧美亚洲动漫精品| 国产精品激情偷乱一区二区∴| 国产精品一区二区果冻传媒| 精品久久免费看| 精品一区在线看| 久久综合九色综合欧美就去吻|