进程退出,值3221225477

时间:2018-09-16 12:08:00

标签: c++ class dynamic-arrays

我创建了一个使用动态数组的程序。当我使用我的插入函数然后显示数组的元素时,它可以显示所有我想要的内容。问题在于,程序结束时不会返回值0,而是会阻塞几秒钟,然后说“进程退出,值3221225477”。怎么了?

标题:

#ifndef VETTORE_H
#define VETTORE_H
#include "regalo.h"

typedef regalo T;

class vettore {
    friend ostream& operator<<(ostream&,const vettore&);
    friend istream& operator>>(istream&,vettore&);
    private:
        T *v;
        int riemp;
        int max;
    public:
        vettore();
        vettore(const int);
        ~vettore(){delete [] v;};
        bool full(){return riemp==max;};
        bool empty()const;
        bool inserisci(const T&);
        T& operator[](const int index);

};

#endif

cpp文件:

#include "vettore.h"

ostream &operator<<(ostream& out,const vettore & v1){
    for(int i=0;i<v1.riemp;i++){
        out<<v1.v[i];
    }
    return out;
}

istream &operator>>(istream& in,vettore &v1){
    for(int i=0;i<v1.riemp;i++){
        in>>v1.v[i];
    }
return in;
}

vettore::vettore(){
    riemp=0;
    max=10;
    v=new T[max];
}

vettore::vettore(const int n):max(n),riemp(0){
    v=new T[max];
}

bool vettore::empty()const{
if(riemp==0){
return true;
}else return false;
}

bool vettore::inserisci(const T& n){
    if(max==0){
        cout<<"Inserisci il massimo di elementi del vettore: ";
        cin>>max;
    }
    if(!full()){
        v[riemp]=n;
        riemp++;
        return true;
    }else return false;
}

T& vettore::operator[](const int index){
    return v[index];
}

主文件:

#include "vettore.h"

int main(int argc, char** argv) {
    int riempimento;
    vettore vett(1);
    regalo r1("Alex",300,"quadrato");

    vett.inserisci(r1);
    cout<<"Gli elementi del vettore sono: \n";
    for(int i=0;i<riempimento;i++){
        cout<<vett[i]<<endl;
    }
    system("PAUSE");
    return 0;
}

1 个答案:

答案 0 :(得分:2)

您的代码中存在一些问题:

  1. riempimento未初始化,因此main中的for循环将执行未知数量的迭代,可能超过向量的大小。最好从向量内部公开riemp的值,然后在循环中使用它。
  2. 您需要实现rule of three,这还没有给您带来问题,但是如果您复制vettore对象,将来会出现。
  3. 如果在调用maxinserisci为0,则提示用户输入max值,则不会检查cin是否成功,也不会重新分配{{1 }}的大小足以容纳v元素。
  4. 这没问题,但是max可以简单地实现为:

    empty