首页 >后端开发 >C++ >为什么 `std::async` Future 的析构函数会阻塞?

为什么 `std::async` Future 的析构函数会阻塞?

Susan Sarandon
Susan Sarandon原创
2024-11-26 03:22:17171浏览

Why Does the Destructor of a `std::async` Future Block?

为什么从 std::async 阻塞返回 Future 的析构函数?

在 C 11 中,future 的析构函数由std::async 块,导致潜在的死锁。这种行为引发了关注,引发了标准化委员会内部的一系列提案和讨论。

问题的症结在于确保线程安全。如果没有阻塞行为,可能会出现这样的情况:关联的线程在 future 被销毁后继续执行,而无法同步其完成。这可能会导致内存损坏,甚至损害系统安全性。

正如 Hans Boehm 在 N3679 中所解释的,未处理的异常可能会绕过旨在等待完成的代码,从而加剧了这种情况。因此,阻塞析构函数起到了安全网的作用,防止了这种灾难性的结果。

尽管进行了广泛的审议,C 社区尚未就此事达成共识。从 C 14 开始,std::future 和 std::thread 的析构函数仍然阻塞。

但是,这种情况将来可能会发生变化。 Michael Wong 2013 年的旅行报告表明,虽然弃用 std::async 的动议失败了,但人们越来越认识到其阻塞行为所带来的潜在危险。

同时,程序员应该意识到这一点发出并采用适当的措施,例如范围保护或显式同步机制,以确保处理从 std::async 返回的 future 时的线程安全。

以上是为什么 `std::async` Future 的析构函数会阻塞?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn