Cosa ne pensi? È corretto o ci sono perdite di memoria?QList e shared_ptr
Fonte:
#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;
}
uscita:
6
destroying A(6)
Come sidenote: non utilizzare 'QList' 'dove sizeof (T)> sizeof (void *)' (e sizeof (shared_ptr ) == '2 * sizof (void *)', di solito), dato che in quel caso 'QList' copia-'nuova' gli elementi nella lista (invece di mantenerla per valore). Usa invece 'QVector' o' std :: vector'. –