(C++ code) Suppose I have a class like:
class A {
public:
int * ptr;
int size;
A();
~A();
}
A::A()
{
ptr = new int[10]; // memory allocation is dependent upon user input into size variable
}
A::~A()
{
delete [] ptr;
}
According to what I could find (sample link: How delete a pointer of classes which has pointer members?) this seems to be the correct way of defining the destructor here. But I tried this and it runs into run time exception.
Even tried, delete ptr;
but no luck
Is this the correct way of doing things?
The array based implementation of queue :
#include<iostream>
#include<string>
using namespace std;
class ArrayQueue
{
public:
int front, size, rear, curr;
int * elem;
ArrayQueue():size(10),rear(-1),curr(0),front(-1){}
ArrayQueue(int n);
void enqueue(int& e);
void dequeue();
bool empty()const;
int& getFront() const;
int& getRear() const;
int& getSize();
~ArrayQueue();
};
ArrayQueue::ArrayQueue(int n)
{
size = n;
front = -1;
rear=-1;
curr=0;
elem = new int[size];
}
ArrayQueue::~ArrayQueue()
{ cout<<"running destructor";
delete[] elem;
}
bool ArrayQueue::empty()const
{
return curr==0;
}
int& ArrayQueue::getSize()
{
return curr;
}
int& ArrayQueue::getFront()const
{
return elem[front];
}
int& ArrayQueue::getRear()const
{
return elem[rear];
}
void ArrayQueue::enqueue(int& e)
{
if(getSize()==size){cout<<"Queue full"<<'\n'; return;}
rear = ((rear+1)%size);
elem[rear]=e;
++curr;
}
void ArrayQueue::dequeue()
{
if(empty()){cout<<"Queue empty"<<'\n';return;}
front = ((front+1)%size);
--curr;
}
int main()
{
ArrayQueue object;
cout<<"Size of the queue"<<object.size<<'\n';
cout<<"Current size:"<<object.getSize()<<'\n';
object.dequeue();
for(int i =0 ; i<15; i++)
{
object.enqueue(i);
}
cout<<"front element : "<<object.front<<'\n';
cout<<"rear element : "<<object.rear<<'\n';
cout<<"Current size:"<<object.getSize()<<'\n';
object.dequeue();
object.dequeue();
object.dequeue();
cout<<"front element : "<<object.front<<'\n';
cout<<"rear element : "<<object.rear<<'\n';
return 0;
}