我正在尝试从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);

10-08 05:20