带有指针的计算机实验室



我有管理计算机实验室的任务。具体来说,有4个实验室,每个实验室都有不同数量的计算机。因此,我想创建一个带有指针的 2D 数组,但在尝试了不同的东西之后,我指望你解决这个错误(请!!(。以下是我程序的一部分,直到出现烦人的错误。

我在 1 次运行后出现运行时错误(在抛出std::bad_array_new_length what(): std::bad_array_new_length实例后调用终止(,当我在这里留下带有注释//PROBLEM 的行时。

在实验室前面添加一个&,编译器给了我一个错误:左值需要作为赋值的左操作数。

新手在C++,第一次使用指针,我将不胜感激任何帮助。

#include <iostream>
using namespace std;
//Global variables
const int SIZE = 4;
typedef int* Stations;
Stations *labroom;
//Function declaration:
void numberOfComputers();//Receive number of computers in each lab
int menu();//Display menu options for users
void menu_processor(int option);//process user's option
int main()
{
numberOfComputers();
menu();
menu_processor(menu());
return 0;
}
void numberOfComputers ()
{   char ans;
for (int i=0;i<SIZE;i++)
{
cout<<"Enter the number of computer stations in lab "<<i+1<<": ";
do
{
cin.get(ans);
} while (ans!='n');
labroom [i] = new int [ans-'0'];//PROBLEM HERE
cout<<"n";
}
}

这不是 c++ 代码,它只是(丑陋的(C。

在C++中,我们为静态数组提供了array,为动态数组提供了vector

首先,以聪明的方式选择变量或函数的名称:更喜欢getNumberOfComputersFromUser而不是numberOfComputersnumberOfComputers是什么意思?函数名称必须描述它正在执行的操作。

这里有一个简化的片段:

#include <vector>
#include <array>
#include <iostream>
using namespace std;
using Station = int;
using LabRooms = array<vector<Station>, 4>;
LabRooms getNumberOfComputersFromUser()
{
LabRooms labRooms;
int roomIndex = 0;
for(auto& computersInLab : labRooms)
{
cout << "Enter the number of computer stations in lab " << ++roomIndex << ": ";
auto computerCount = 0;
cin >> computerCount;
computersInLab.resize(computerCount);
}
return labRooms;
}

解释

array需要两个模板参数:类型和大小。元素是静态分配的,无需新建,因为我们已经知道我们有多少房间。每个房间的计算机列表是未知的,所以我们使用可以动态增加或减少的vector

using LabRooms = array<vector<Station>, 4>;typedef array<vector<Station>, 4> LabRooms是一样的,但我认为更清楚

for( auto& computersInLab : labRooms)遍历labRooms并获取对其元素的引用(在本例中为对Stationvector的引用。这与以下内容相同:

for(int i = 0; i < labRooms.size(); ++i)
{
auto& computersInLab = labRooms[i];
...
}

computersInLab.resize(computerCount);使用用户指定的值调整计算机列表的大小。

现在,labRooms是一个由 4 个元素组成的数组,每个元素都是一个Station列表。

最新更新