请打开考生文件夹下的解决方案文件proj3,其中声明了ValArray类,该类在内部维护一个动态分配的整型数组。ValArray类的复制构造函数应实现对象的深层复制。请编写ValArray类的复制构造函数。在main函数中给出了一组测试数据,此种情况下程序

admin2020-06-29  31

问题 请打开考生文件夹下的解决方案文件proj3,其中声明了ValArray类,该类在内部维护一个动态分配的整型数组。ValArray类的复制构造函数应实现对象的深层复制。请编写ValArray类的复制构造函数。在main函数中给出了一组测试数据,此种情况下程序的输出应该是:
    ValArray vl={1,2,3,4,5}
    ValArray v2={2,2,2,2,2}
    要求:
    补充编制的内容写在“//******* 333 *******”与“//******** 666 ********”之间。不要修改程序的其他部分。
    注意:
    相关文件包括:main.cpp、ValArray.h。
    程序最后调用writeToFile函数,使用另一组不同的测试数据,将不同的运行结果输出到文件out.dat中。输出函数writeToFile已经编译为obj文件。
    //ValArray.h
    #include<iostream>
    using namespace std;
    class ValArray{
      int * v;
      int size;
    public:
      ValArray(const int * p,int n):size(n)
     {
        v=new int[size];
        for(int i=0;i<size;i++)
          v=P
      }
       ValArray(const ValArray& other);
       ~ValArray(){delete[]v;}
       void setElement(int i,int val)
      {
        v=val;
       }
      void print(ostream&out)const
      {
        out<<’{’;
        for(int i=0;i<size-1;i++)
        out  <<v  <<",";
        out  <<v[size-1]  <<’)’;
      }
    };

    void writeToFile(const char *);

    //main.cpp
    #include"ValArray.h"
    ValArray::  ValArray  (const
    ValArray& other)
    {
    //******** 333 ********


    //******** 666 ********
    }

    int main()
    {
      const int a[]={1,2,3,4,5};
      ValArray v1(a,5);
      ValArray v2(v1);
      for(int i=0;i<5;i++)
        v2.setElement(i,2);
      cout<<"ValArray v1=";
      v1.print(cout);
      cout<<endl;
      cout<<"ValArray v2=";
      v2.print(cout);
      cout<<endl;
      writeToFile("");
      return 0;
    }

选项

答案size =other.size; //把对象数组的大小赋值给size v=new int [ other.size ]; //根据对象数组的大小动态分配数组V for(int i =0;i <size; ++i) v[i]=other.v[i]; //遍历整爪对霖的数组把值other.v[i]放到数组V中

解析 主要考查考生对复制构造函数的掌握。由函数名:ValArray::ValArray(const ValArray& other),知道要复制的对象是other,对由ValArray类的成员:int*v;int size;知道要复制的内容是动态数组v及整型变量size。动态数组要使用new语句分配内存,最后利用for循环语句来完成复制过程。
转载请注明原文地址:https://kaotiyun.com/show/ybyp777K
0

最新回复(0)