多线程时使用shared_from_this的一个注意问题

      发生场景:类中带线程成员变量,线程是带消息循环的,用来做异步实际操作;类对象创建的时候启动线程,类析构的时候停止线程;在外来线程控制本对象的时候通过传进shared_from_this来抛到对象线程中执行任务;本地执行任务的函数通过传进shared_from_this传给对象线程,不管是外来线程还是对象线程。

      问题:当对象析构的时候,还没调用结束线程动作时,正好对象线程执行shared_from_this动作,把ref加了1,抛到对象线程里,而此时对象析构完了。对象线程还在等最后一个任务,这个任务拿着已经析构的指针做操作。。。这时候就崩溃了。

      示例代码:目前还没空写,后续补充。

`std::shared_ptr<logger>` 是 C++ 标准库中用于管理动态内存资源的一种智能指针,它通过引用计数机制保证资源在不再被引用自动释放。`logger` 可能是一个日志记录器或者类似类的实例。而 `qt_color_logger_mt` 指的是一种带有多线程支持的彩色日志记录器,可能是在 Qt 库中使用的。 下面是一个简单的示例: ```cpp #include <iostream> #include <memory> // 包含 shared_ptr #include <thread> // 如果需要支持多线程 #include "logger.h" // 假设 logger.h 是定义 logger 类的地方 #include "qt_color_logger.h" // 假设 qt_color_logger 是 qt_color_logger_mt 的别名 class Logger : public logger { public: void log(const std::string& message) override { // 日志记录逻辑... } }; int main() { // 创建一个共享所有权的日志记录器实例 std::shared_ptr<logger> qt_color_logger = std::make_shared<qt_color_logger_mt>(); // 使用智能指针 qt_color_logger->log("This is a colored log message in multiple threads!"); // 在另一个线程中也使用一个日志记录器 std::thread worker_thread([=] { qt_color_logger->log("Another log from a separate thread!"); }); // 等待工作线程结束 worker_thread.join(); return 0; } ``` 在这个例子中,`qt_color_logger` 是一个可以在主线程和其他线程中安全使用的日志记录器实例。当 `main()` 函数结束,`shared_ptr` 自动会销毁 `qt_color_logger`,释放其占用的资源。如果你的应用程序有多个线程同访问该日志记录器,每个线程都会增加引用计数,直到最后一个引用消失,资源才会被回收。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值