c++ - 我将如何在 C++ 中实现处理器调度模拟器?
问题描述
我的输入文件看起来像这样
in.txt
1 0 10
其中每一行是一个单独的结构的 ID(任意的,不表示到达的顺序)、到达时间和突发时间
在从要使用的用户那里获得输入后,我想实现如下所示的输出。
例如,用户输入 FSCS 然后
S.algorithm: FCFS
Total 1 tasks are read
<system time 0> process 1 is running
<system time 1> process 1 is running
<system time 2> process 1 is running
<system time 3> process 1 is finished
任何对实际代码的帮助将不胜感激!!!
我的工作还没有
while (file)
{
file >> temp.ID >> temp.arrivalTime >> temp.burstTime;
d.push_back(temp);
int i = 0, time = 0;
while (i < d.size())
{
if (d[i].arrivalTime > time)
cout << "Time " << time << "process is idle";
time += d[i].arrivalTime;
cout << "Time " << time << " Process " << d[i].ID << " is running" << endl;
time += d[i].burstTime;
i++;
}
}
输入.txt
1 0 5
2 5 8
3 9 6
输出
<system time <0> process 1 is running
<system time <1> process 1 is running
<system time <2> process 1 is running
<system time <3> process 1 is running
<system time <4> process 1 is running
<system time <5> process 1 finished
<system time <5> process 2 is running
<system time <6> process 2 is running
<system time <7> process 2 is running
<system time <8> process 2 is running
<system time <9> process 2 is running
<system time <10> process 2 is running
<system time <11> process 2 is running
<system time <12> process 2 is running
<system time <13> process 2 finished
<system time <13> process 3 is running
<system time <14> process 3 is running
<system time <15> process 3 finished
Press any key to continue . . .
解决方案
对于文件处理部分,使用类似这样的东西
ifstream file("input.txt")
if(!file)
{
std::cerr<<"Cannot open file"<<std::endl;
exit(1);
}
myData temp;
while(file)
{
file >> temp.Id >> temp.arrivalTime >> temp.burstTime;
d.push_back(temp);
}
int time,i;
time = i = 0;
while( i < d.size())
{
if( time < d[i].arrivalTime )
{
std::cout<<"<system time <"<<time<<"> system is idle"<<std::endl;
time++;
}
else if( time < d[i].arrivalTime + d[i].burstTime )
{
std::cout<<"<system time <"<<time<<"> process "<<i<<" is running"<<std::endl;
time++;
}
else{
std::cout<<"<system time <"<<time<<"> process "<<i<<" finished"<<std::endl;
i++;
}
}
编辑:
test.cpp
#include <iostream>
#include <fstream>
#include <vector>
#include <cstdlib>
using namespace std;
struct myData {
int Id;
int arrivalTime;
int burstTime;
int finishTime;
};
int main()
{
ifstream file("input.txt");
vector<myData> d;
if(!file)
{
std::cerr<<"Cannot open file"<<std::endl;
exit(1);
}
myData temp;
temp.finishTime = -1;
while(file)
{
if(file.good())
file >> temp.Id >> temp.arrivalTime >> temp.burstTime;
d.push_back(temp);
}
int time,i;
time = i = 0;
while( i < d.size() - 1 )
{
if( time < d[i].arrivalTime )
{
std::cout<<"<system time <"<<time<<"> system is idle"<<std::endl;
time++;
}
else if( time < d[i].finishTime || d[i].finishTime==-1 )
{
if(d[i].finishTime == -1)
d[i].finishTime = d[i].burstTime + time;
std::cout<<"<system time <"<<time<<"> process "<<i+1<<" is running"<<std::endl;
time++;
}
else{
std::cout<<"<system time <"<<time<<"> process "<<i+1<<" finished"<<std::endl;
i++;
}
}
}
和input.txt
1 0 3
推荐阅读
- python - Python unittest:无法模拟导入的函数,因此条件评估为 False
- sql-server - 是否可以在 ORDER BY 子句中使用 STRING_SPLIT?
- node.js - 我的 Shopify 应用无法在 Firefox 上运行 - 被内容安全政策阻止
- python - Python:如何通过函数传递对象/变量并直接在函数内部进行更改?
- javascript - 设置全局变量 Protractor
- javascript - 如何返回具有特定条件的连续子数组的长度
- c# - 实体上的多个 where 条件导致只读属性为真
- html - 如何缩放 svg 文本水平中心?
- javascript - foreach javascript 的控制台日志未显示
- python - 如何按字母顺序对字典中的键进行排序并将它们放入列表中?