[英]Dynamic memory array / program crashing
我的程序使用动态内存数组,并具有入队(在开头添加并向右移动)和出队(在最后删除)Show array等函数。代码对我来说似乎很好。 但是,当您运行该程序时,出现了一个问题,即崩溃十分之十分。 我想这是因为错误的新/删除用法。 有人可以告诉我为什么程序崩溃了吗? 以及如何解决?
#include <iostream>
#include <cstdlib>
#include <stdlib.h>
using namespace std;
template <class T>
class Queue
{
public:
Queue(int size);
int add_value(T);
void show_array();
void enqueue(T);
T dequeue();
private:
T *temp;
T *data;
int size;
int index;
};
template<class T>
Queue<T>::Queue(int s)
{
data = new T[s];
if (data == NULL)
{
cout << "Not enough memory, program ends." << endl;
exit(1);
}
size = s;
index = 0;
}
template<class T>
void Queue<T>::show_array()
{
for (int i = 0; i < index; i++)
cout << data[i] << ' ';
cout << endl;
}
template<class T>
int Queue<T>::add_value(T value)
{
if (index == size)
return(1);
else
{
data[index] = value;
index++;
return(0);
}
}
template <class T>
void Queue<T>::enqueue(T X)
{
for(int i = size; i > 0; i--)
{
data[i] = data[i-1];
}
data[0] = X;
}
template <class T>
T Queue<T>::dequeue()
{
size -= 1;
index -= 1;
temp = new T[size];
for (int i=0; i<size; i++)
temp[i] = data[i];
delete[] data;
data = new T[size];
data = temp;
return * data;
}
int main()
{
Queue<double>numbers(10);
for (int i = 0; i < 10; i++)
numbers.add_value(i);
cout << "Array:" << endl;
numbers.show_array();
numbers.enqueue(9.2);
numbers.enqueue(9.1);
cout << endl;
cout << "Array after enqueue:" << endl;
numbers.show_array();
cout << "Array after dequeue:" << endl;
numbers.dequeue();
numbers.dequeue();
numbers.show_array();
system("pause");
return 0;
}
您的代码中有几个错误。
首先,这是实现队列的效率极低的方法,因为每次插入都将涉及复制当前队列中的每个元素。
其次,您无法访问元素:
for(int i = size; i > 0; i--)
{
data[i] = data[i-1];
}
由于您的数组被分配为data = new T[size]
,因此访问data[size]
试图访问传递到数组末尾的1个元素。 那是UB。
第三,您有内存泄漏:
T Queue<T>::dequeue()
{
size -= 1;
index -= 1;
temp = new T[size];
for (int i=0; i<size; i++)
temp[i] = data[i];
delete[] data;
data = new T[size]; // leaked!
data = temp;
return * data;
}
它应该只是data = temp
。
您的入enqueue
内存损坏:
这是您应如何编写for循环的方法:
for (int i = size - 1; i > 1; i--)
代替
for (int i = size; i > 0; i--)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.