Qu'en pensez-vous? Est-ce correct ou y a-t-il des fuites de mémoire?QList and shared_ptr
Source:
#include <QList.h>
#include <boost/shared_ptr.hpp>
#include <iostream>
class A {
private:
int m_data;
public:
A(int value=0) { m_data = value; }
~A() { std::cout << "destroying A(" << m_data << ")" << std::endl; }
operator int() const { return m_data; }
};
int _tmain(int argc, _TCHAR* argv[])
{
QList<boost::shared_ptr<A> > list;
list.append(boost::shared_ptr<A>(new A(6)));
std::cout << int(*(list.at(0))) << std::endl;
return 0;
}
Sortie:
6
destroying A(6)
En tant que sidenote: ne pas utiliser '' QList où 'sizeof (T)> sizeof (void *)' (et 'sizeof (shared_ptr ) == 2 * sizof (void *)', en général), puisque dans ce cas, 'QList' copiera-'new' les éléments dans la liste (au lieu de le garder par valeur). Utilisez 'QVector' ou' std :: vector' à la place. –