繁体   English   中英

析构函数中的程序崩溃

[英]Program Crashing at Destructor

我似乎无法理解为什么我的程序成功运行然后在析构函数中崩溃。 下面是我的main()源代码(这很简单,它将5个变量的数组发送到创建适当类型的类模板。我进行了一些研究,似乎遗漏了一些可能导致崩溃的原因,因为额外的析构函数的调用吗?我有些困惑,这很可能是简单的修复。

main.cpp中:

int main() 
{
// using integer data type
int arraya[5] = { 1, 2, 3, 4, 5 };
GenericArray<int> a(arraya, 5);
a.print();

// using float data type
float arrayb[5] = { 1.012, 2.324, 3.141, 4.221, 5.327 };
GenericArray<float> b(arrayb, 5);
b.print();

// using string data type
string arrayc[] = { "Ch1", "Ch2", "Ch3", "Ch4", "Ch5" };
GenericArray<string> c(arrayc, 5);
c.print();
return 0;
}

头文件内容:

#ifndef GENERIC_ARRAY_H
#define GENERIC_ARRAY_H

#include<string>
#include<iostream>

template<typename type>
class GenericArray
{
public:
    GenericArray(type array[], int arraySize); // constructor
    ~GenericArray();    // destructor
    void print();       // the print function
    GenericArray(const GenericArray &obj); //copy constructor
private:
    type *ptr; //new pointer of respective type
    int size;
};

template<typename type>//print() function
void GenericArray<type>::print()
{
    for (int index = 0; index < size; index++)
    {
        cout << ptr[index] << " ";
    }
    cout << endl;
}

template<typename type>//Constructor
GenericArray<type>::GenericArray(type array[], int arraySize)
{
    size = arraySize;
    ptr = new type[size];
    ptr = array;
}

template<typename type>//Destructor
GenericArray<type>::~GenericArray()
{
    cout << "Freeing Memory!";
    delete[] ptr;
}

template<typename type>//Copy Constructor
GenericArray<type>::GenericArray(const GenericArray &obj)
{
    *ptr = *obj.ptr;
}

#endif

-在print()方法中:

不安全的是,在内存位置ptr ... (ptr + size - 1)处分配了内存,因此您可能会遇到分段错误。

-在constructor

您可以通过new分配内存,但随后立即将指针重定向到指向array所指向的同一位置。 这意味着您发生了内存泄漏。

-在destructor

如前所述,调用destructor时,您的程序在此处崩溃,因为delete []不会对使用new分配的内存进行操作,请参见constructor说明。

-在copy constructor

这里有两个问题。 首先,你可以不取消引用LHS- ptr这里,因为没有分配给他的记忆。 此外,如果为ptr分配了内存,则语句*ptr = *obj.ptr; 只会将obj.ptr的第一个元素(如果在此位置也分配了内存)复制到ptr的第一个元素。

构造函数定义不正确。 它们应复制源对象的元素。

例如

#include <algorithm>

//...

template<typename type>//Constructor
GenericArray<type>::GenericArray( const type array[], int arraySize ) 
    : ptr( new type[arraySize] ), size( arraySize )
{
    std::copy( array, array + arraySize, ptr );
}


template<typename type>//Copy Constructor
GenericArray<type>::GenericArray( const GenericArray &obj )
    : ptr( new type[obj.size] ), size( obj.size ), 
{
    std::copy( obj.ptr, obj.ptr + arraySize, ptr );
}

另外,您需要定义副本分配运算符。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM