Это хороший способ хранить, повторять и удалять указатели в std :: vector?

#include <iostream>
#include <cstdlib>
#include <ctime>
#include <algorithm>
#include <vector>
using namespace std;

struct delete_ptr
{
template<typename T>
void operator()(T*& t)
{
delete t;
t = 0;
}
};

struct is_null_ptr
{
template<typename T>
bool operator()(T*& t)
{
return t == 0;
}
};

struct A
{
static void removeDead(A*& a)
{
if(a and a->dead)
delete_ptr()(a);
}

static void killSome(A* a)
{
if(a and a->isDead() == false and rand()%100 == 0)
{
static int counter = 0;
cout << "Kill___" << ++counter << endl;
a->kill();
}
}

static void reviveSome(A* a)
{

if(a and a->isDead() and rand()%3 == 0)
{
static int counter = 0;
cout << "Revive___" << ++counter << endl;
a->revive();
}
}

A():dead(false)
{

}

virtual ~A()
{
static int counter = 0;
cout << "Dtor___" << ++counter << endl;
}

bool isDead(){return dead;}
void kill(){dead = true;}
void revive(){dead = false;}

bool dead;
};

int main()
{
srand(time(0));
vector<A*> as;
for(int i = 0; i < 200; ++i)
{
A* a = new A;
as.push_back(a);
}for_each(as.begin(),as.end(),A::killSome);
for_each(as.begin(),as.end(),A::reviveSome);

for_each(as.begin(),as.end(),A::removeDead);
as.erase( std::remove_if(as.begin(),as.end(),is_null_ptr()),as.end());
cout << as.size() << endl;

for_each(as.begin(),as.end(),delete_ptr());
as.clear();

return 0;
}

Он распределяет их и печатает правильный вывод, но я не уверен, что это правильная вещь, которую я делаю. Я просто пытался использовать указатели в векторе и удалять их, когда происходит определенное условие, без использования boost или c ++ 11.
Так что вы думаете об этом?

0

Решение

Поскольку единственный интеллектуальный указатель, присутствующий в текущем STL (auto_ptr), не может использоваться в контейнерах, я бы сказал, что ваш путь хорош в данных условиях.

Однако вы можете подумать о реализации своего собственного unique_ptr или shared_ptr.

PS: Есть много причин использовать указатели вместо реальных объектов в контейнере, одна из них — полиморфизм. Другое — фактические объекты уже хранятся где-то еще (представьте себе структуру индекса для уже сохраненных объектов).

1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]