Qt中的智能指针
-QPointer
  .当其指向的对象被销毁时,它会被自动置空
  .析构时不会自动销毁所指向的对象
-QSharedPointer
  .引用计数型智能指针
  .可以被自由的拷贝和赋值
  .当引用计数为0时才删除指向的对象

#include <QPointer>
#include <QDebug> using namespace std; class Test : public QObject //在进行Qt开发时,所定义的类都必须继承自Qt中的顶层父类QObject,这样才符合Qt开发中的一些规范。 {
QString m_name;
public:
Test(const char* name)
{
qDebug() << "Test(const char* name)" << endl;
m_name = name;
}
void print()
{
qDebug() << "I'm" << m_name << endl;
}
~Test()
{
qDebug() << "~Test()" << endl;
}
}; int main()
{ QPointer<Test> pt(new Test("hello world") );
pt->print();
qDebug() << "pt= " << pt << endl;
return ;
}

智能指针类模板(中)——Qt中的智能指针-LMLPHP

析构函数没有被调用,意味着pt这个智能指针对象,它在生命周期结束时并没有同时的销毁所指向的堆空间里面的对象。一定要注意。此时需要手工的删除。

delete pt;

#include <QPointer>
#include <QDebug> using namespace std; class Test : public QObject //在进行Qt开发时,所定义的类都必须继承自Qt中的顶层父类QObject,这样才符合Qt开发中的一些规范。 {
QString m_name;
public:
Test(const char* name)
{
qDebug() << "Test(const char* name)" ;
m_name = name;
}
void print()
{
qDebug() << "I'm" << m_name;
}
~Test()
{
qDebug() << "~Test()" ;
}
}; int main()
{ QPointer<Test> pt(new Test("hello world") );
QPointer<Test> pt1(pt);
QPointer<Test> pt2(pt); pt->print();
pt1->print();
pt2->print(); delete pt; qDebug() << "pt= " << pt;
qDebug() << "pt1= " << pt1 ;
qDebug() << "pt2= " << pt2 ; return ;
}

智能指针类模板(中)——Qt中的智能指针-LMLPHP

打印结果说明:

意味着QPointer类模板的对象所指向的堆空间,如果被释放了,那么所有指向这个堆空间的智能指针都会被置空。这是一个非常有用的特性,可以避免内存多次释放的问题。

QSharePointer的使用

#include <QSharedPointer>
#include <QDebug> using namespace std; class Test : public QObject //在进行Qt开发时,所定义的类都必须继承自Qt中的顶层父类QObject,这样才符合Qt开发中的一些规范。 {
QString m_name;
public:
Test(const char* name)
{
qDebug() << "Test(const char* name)" ;
m_name = name;
}
void print()
{
qDebug() << "I'm" << m_name;
}
~Test()
{
qDebug() << "~Test()" ;
}
}; int main()
{
QSharedPointer<Test> pt(new Test("hello world") );
pt->print(); QSharedPointer<Test> pt1(pt);
QSharedPointer<Test> pt2(pt);
pt1->print();
pt2->print(); return ;
}

智能指针类模板(中)——Qt中的智能指针-LMLPHP

05-08 08:15