我正在尝试从Class1写入Class3中的变量1和2。
我从Class1写入Class2中的任何变量都没有问题。但是,我似乎无法从Class1永久写入Class3变量。我知道他们接收到正确的值,因为在分配后,read()方法中的cout将打印正确的值。但是,粘贴到print()方法中的同一个cout将不会打印新值。好像他们是暂时写的...
对不起班上的疯狂
class Class1
{
public:
Class1();
private:
Class2 *myClass2Array;
};
Class1::Class1()
{
myClass2Array = new Class2[size];
myClass2Array[i].getArray(myClass2Array[i].getCount()).read(string1, string2); // this line is probably a problem
}
因此,Class1的构造函数正在尝试调用Class3中声明的class3中的read()。
class Class2
{
public:
Class2();
int getCount();
Class3 getArray(int i) { return myClass3Array[i]; }
private:
Class3 *myClass3Array;
int count;
};
Class2::Class2()
{
count = 0;
myClass3Array = new Class3[8];
}
我也尝试过Class3 myClass3Array [8];并在for循环中初始化每个人...这是Class3
class Class3
{
string var1;
string var2;
public:
Class3();
void print();
void read(string, string);
};
Class3::Class3()
{
var1 = "";
var2 = "";
}
void Class3::print()
{
cout << var1 << " and " << var2 << endl; // will print old, initiated values
} // end function print()
void Class3::read(string string1, string string2)
{
var1 = string1;
var2 = string2;
cout << var1 << " " << var2 << endl; // will print new values
} // end function read()
我想我的问题可能出在声明数组的方式上,还是在尝试访问(写入)该数组的方式上。有任何想法吗?
最佳答案
问题是您的Class2::getArray
方法正在返回副本。
更改以返回参考
Class3& getArray(int i) { return myClass3Array[i]; }
问题是您正在设置
Class3
对象的副本的值,而不是在Class2
对象中的原始值上。这就是为什么您的价值观不成立的原因。另一种方法是添加setArray方法
void setArray(int i, const Class3& a) { myClass3Array[i] = a; }
然后
Class3 c3;
c3.read(string1, string2);
myClass2Array[i].setArray(myClass2Array[i].getCount(), c3);