Здравствуйте,
Есть класс, реализующий динамический массив. Предполагается хранить в нем указатели на любые динамические структуры, которые создаются вызовом new() ВНЕ этого класса. Чтобы не зависеть от типа указателя, есть смысл написать этот класс в виде шаблона. Вопрос в том, как особождать память, которую занимают созданные объекты. Очень удобно было бы автоматически зачищать ее ВНУТРИ деструктора шаблонного класса. Такое возможно? Если да, то как? Ниже мой вариант. Для проверки зачистки я использую модуль MemWatch, так он ругается на всех выделениях памяти, и говорит, что память unfreeed. Поэтому и возник этот вопрос. Очень нуждаюсь в помощи - работа стоит, т.к. может всю базу нахрен нужно переписывать.
template <class AnyType> class DynArray
{
private:
AnyType *items; // сам массив
long int ntotal; // всего выделено памяти
long int ncurrent; // всего занято памяти
long int nstep; // шаг выделения
public:
DynArray() {};
DynArray(long int ArraySizeExpansion);
~DynArray();
AnyType operator[](long int index);
int append(AnyType item);
void remove(long int index);
long int length() { return ncurrent; };
enum {
NO_ERRORS=0,
NOT_ENOUGH_MEMORY
};
};
template<class AnyType> DynArray<AnyType>::DynArray(long int ArraySizeExpansion)
{
ntotal = nstep = (ArraySizeExpansion==0)?1:ArraySizeExpansion;
ncurrent = 0;
items = (AnyType*) malloc(sizeof(AnyType)*nstep); << MemWatch материться на этой строке
memset(items,0,sizeof(AnyType)*nstep);
};
template<class AnyType> DynArray<AnyType>::~DynArray()
{
for (long int i=0;i<ncurrent;i++) delete items[i]; //<< очень удобный вариант зачистки
free(items);
};
template<class AnyType> AnyType DynArray<AnyType>::operator[](long int index)
{
return items[index];
};
template<class AnyType> int DynArray<AnyType>::append(AnyType item)
{
if (ncurrent>=ntotal) {
AnyType *newitems = (AnyType*)realloc(items,sizeof(AnyType)*(ntotal+nstep));
if (newitems==NULL) {
return NOT_ENOUGH_MEMORY;
};
items = newitems;
memset(&items[ncurrent],0,sizeof(AnyType)*nstep);
ntotal+=nstep;
items[ncurrent] = item;
ncurrent++;
return NO_ERRORS;
};
template<class AnyType> void DynArray<AnyType>::remove(long int index)
{
delete items[index]; //<< здесь тоже
memset(items+ncurrent-1,0,sizeof(AnyType)*(ntotal-ncurrent+1));
ncurrent--;
};