本文主要解释“C如何将线程视为全局容器”。感兴趣的朋友不妨看看。本文介绍的方法简单、快速、实用。让边肖带你学习“C如何将线程视为全局容器”!
CP.24:将线程看作全局容器
Reason(原因)
为了维护指针安全和避免泄漏,我们需要考虑athread使用了哪些指针。如果athreadis被分离,我们可以安全地传递指向静态和自由存储对象的指针(仅限)。
为了保证指针安全,避免泄露。我们需要考虑线程使用什么指针。如果线程被分离,我们可以安全地将指向静态变量的指针和自由存储对象传递给线程。
Example(示例)
无效f(int* p)
{
//.
* p=99
//.
}
int glob=33
void some_fct(int* p)
{
int x=77
std:thread t0(f,x);//坏
std:thread t1(f,p);//坏
std:thread t2(f,glob);//好的
auto q=make _ uniqueint(99);
std:thread t3(f,q . get());//坏
//.
t0 . detach();
t1 . detach();
T2 . detach();
T3 . detach();
//.
}通过“OK”这个词,我们想表达的是,只要线程继续使用指针,指针所指向的对象就会保持在作用域内(并且保持可用)。通过“坏”这个词,我们想表达的是线程在对象被破坏后会使用指向对象的指针。这里,线程并发执行的事实不会影响生命周期和所有权主题;您可以将这些线程视为由some_fct调用的函数对象。
Note(注意)
如果被已经脱离的线程使用,即使是静态存储期的对象也会出现问题:如果线程执行到程序结束,可能会与静态存储期对象的析构器进程并发执行,对这类对象的访问可能会产生竞争。
Note(注意)
如果你不知道分离线程和使用GSL gsl:joining_thread,这个指导方针是多余的。但是,很难转换代码以符合这个标准,如果它是第三方库,可能根本不可能实现它。在这种情况下,为了确保生命周期安全和类型安全,该代码变得非常必要。
一般来说,判断一个线程是否会执行分离操作是不可能的,但是在简单的常见情况下很容易检测到。如果我们不能证明线程不会调用detach,那么我们必须假设它会调用并且它的生存期会超出它构造的范围;然后可以应用通常的生命周期和所有权建议。
Enforcement(实施建议)
标志试图将局部变量传递给可能分离()的线程。
标记试图将局部变量传递给可能分离的线程的情况。
至此,相信大家对“C如何将线程视为全局容器”有了更深的理解。让我们做一些实际工作吧!这是网站。更多相关内容,可以去相关渠道查询,关注我们,继续学习!
内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/116971.html