如何在数组C ++中存储未知数量的元素
|
抱歉,标题不清楚,但我现在将解释我的问题。我是C ++的新手。
我用C ++创建了一个类。该类的实例是程序的输入,必须将它们存储在数组中才能执行计算。问题在于,一次运行必须由用户定义的该类实例的数量是固定的,但每次运行可能会有所不同。这里有个例子:
#include <<blablah>blahblah>
int main()
{
int number_of_instances = 3;
MyClass first_instance(one_parameter_1, another_parameter_1);
MyClass second_instance(one_parameter_2, another_parameter_2);
MyClass third_instance(one_parameter_3, another_parameter_3);
///////////////////
现在,我必须在阵列中存储所有三个
MyClass array[number_of_instances] = {first_instance, second_instance, third_instance};
问题是我不知道用户要输入多少
///////////////////
performCalculations(array);
return 0;
}
非常感谢。
没有找到相关结果
已邀请:
6 个回复
冕偷淮款
您不必担心内存管理,并且可以像访问普通数组一样访问向量:
您还可以根据需要在循环中将项目添加到向量中,如下所示:
如果直接将对象存储在向量中,则向量超出范围时,所有对象将被破坏。 将对象直接存储在向量中的缺点之一是将向量作为参数传递给函数。这将是一个缓慢的操作,因为必须复制矢量(及其所有对象)。
古擅坛犯
在堆上分配一个数组。 (完成操作后,请不要忘记将它们“ +7”。)请注意,这要求对象具有默认构造函数。
担每棱绰
蓄荣糖些
而不是普通数组,因为向量将不断增长以容纳其他元素。
徐百晴墓斜
臀夯脖锑
,可以在
标头中找到
模板。在使用任何在线可用的c ++常见问题解答进行编码之前,您必须学习一些技巧才能很好地进行编码