您好,登录后才能下订单哦!
这篇文章主要讲解了“C++怎么将连结线程看作范围化的容器”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++怎么将连结线程看作范围化的容器”吧!
CP.23:将连结线程看作范围化的容器
To maintain pointer safety and avoid leaks, we need to consider what pointers are used by a thread. If a thread joins, we can safely pass pointers to objects in the scope of the thread and its enclosing scopes.
为了维持指针安全并避免泄露,我们需要考虑哪些指针被线程使用。如果存在线程连结,我们可以安全地在线程范围内传递对象的指针并关闭该范围。
Example(示例)
void f(int* p)
{
// ...
*p = 99;
// ...
}
int glob = 33;
void some_fct(int* p)
{
int x = 77;
joining_thread t0(f, &x); // OK
joining_thread t1(f, p); // OK
joining_thread t2(f, &glob); // OK
auto q = make_unique<int>(99);
joining_thread t3(f, q.get()); // OK
// ...
}
gsl::joining_thread是增加了调用了joins的析构函数而不能被detatched的std::thread。通过”OK“这个词我们想表达的是只要使用指针的线程存在,该指针指向的对象就会留在范围内(并保持可用状态)。这里,线程并发的事实不会影响生命周期或者所有权问题;可以认为线程就是一个被somt_ft调用的函数对象。
Enforcement(实施建议)
Ensure that joining_threads don't detach(). After that, the usual lifetime and ownership (for local objects) enforcement applies.
确认连结线程不会被detach。然后确认通常的生命周期和(针对局部对象的)所有权原则被适用了。
感谢各位的阅读,以上就是“C++怎么将连结线程看作范围化的容器”的内容了,经过本文的学习后,相信大家对C++怎么将连结线程看作范围化的容器这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。