#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.
Так что вы думаете об этом?
Поскольку единственный интеллектуальный указатель, присутствующий в текущем STL (auto_ptr), не может использоваться в контейнерах, я бы сказал, что ваш путь хорош в данных условиях.
Однако вы можете подумать о реализации своего собственного unique_ptr или shared_ptr.
PS: Есть много причин использовать указатели вместо реальных объектов в контейнере, одна из них — полиморфизм. Другое — фактические объекты уже хранятся где-то еще (представьте себе структуру индекса для уже сохраненных объектов).
Других решений пока нет …