QT 控件定义为智能指针引发的bug

问题描述:

std::unique_ptr<QStackedLayout> m_stacked_layout;

如上为定义;

调用:

Line13ABClient::Line13ABClient(QWidget *parent)

: BaseWidget(parent)

{

// 成员变量初始化

m_get_ready = false;

m_tittle_wnd = nullptr;

m_form_wdg = nullptr;

m_surveillance_wnd = nullptr;

m_form_wdg.reset(new QWidget(this));

m_form_wdg->setObjectName("MainFormContainerWnd");

m_stacked_layout.reset(new QStackedLayout(m_form_wdg.get()));

m_form_wdg->setLayout(m_stacked_layout.get());

//智能指针的所有权,交给m_form_wdg ,双重释放程序会崩溃

........

}

Line13ABClient::~Line13ABClient()

{

//ExitSystem();// 不通过右上角X,直接关闭软件需要调用,否则会崩溃,原因是双重释放stacklayout

}

void Line13ABClient::ExitSystem()

{

DynamicMsgBoxM::GetInstance().Clear();

if (m_stacked_layout) {

m_stacked_layout.reset();

}

.....

}

如上述所示,m_stacked_layout 定义为了一个智能指针,但是m_form_wdg->setLayout(m_stacked_layout.get()); 之后,按理说setlayout之后所有权交给了m_form. 不需要再析构函数中再次清除m_stacked_layout, 但是实际情况是,程序直接关闭,程序崩溃!

原因就是 m_stacked_layout的所有权混乱了。建议直接将m_stacked_layout定义为裸指针 QStackLayout* 。智能指针使用慎重!

如果 std::unique_ptr<QStackedLayout> 也尝试管理同一个 QStackedLayout 对象,那么当 std::unique_ptr 被销毁时,它也会尝试释放这个对象,导致双重释放或未定义行为。

最后,QT 控件还是建议使用父子关系来管理内存,不要使用智能指针!

相关推荐
boonya1 天前
国内外常用的免费BUG管理工具选型
bug
10岁的博客1 天前
Bug排查日记:高效记录与解决之道
bug
彭刷子1 天前
【Bug】Nexus无法正常启动的五种解决方法
bug·nexus
黑客飓风2 天前
从基础功能到自主决策, Agent 开发进阶路怎么走?
面试·log4j·bug
mahuifa2 天前
C++(Qt)软件调试---bug排查记录(36)
c++·bug·软件调试
Kyln.Wu2 天前
【python实用小脚本-205】[HR揭秘]手工党逐行查Bug的终结者|Python版代码质量“CT机”加速器(建议收藏)
开发语言·python·bug
2501_930104042 天前
Bug 排查日记:打造高效问题定位与解决的技术秘籍
bug
weixin_377634842 天前
【YOLO】数据增强bug
yolo·bug
伍哥的传说2 天前
还在为第三方包 bug 头疼?patch-package 让你轻松打补丁!
bug·开发效率·前端工具·第三方包bug·前端开发痛点·npm包修复·依赖包定制
黑客飓风2 天前
Bug排查日记:从崩溃到修复的实战记录
log4j·bug