并发编程: 2. 线程管控

这篇具有很好参考价值的文章主要介绍了并发编程: 2. 线程管控。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

给定一个线程,只要令std::thread对象与之关联,就能管控该线程的几乎每个细节。

2.1 线程的基本管控

2.1.1 发起线程

线程通过构建std::thread对象而启动,该对象指明线程要运行的任务(函数)。简单的任务,函数结束返回,线程随即终止。复杂的任务情况下,函数可以由函数对象表示,还接受参数,并在运行中经由某种消息系统协调,按照指定执行一系列操作。只有收到某指示信号时,线程才会停止。

任何函数对象都适用于std::thread。

针对存在二义性的c++语句,只要它有可能被解释成函数声明,编译器就肯定将其解释为函数声明,针对这种情况,可以采用临时函数对象命名(多加一对括号)或者采用新的统一初始化语法{ 。。。 }来解决歧义。

std::thread my_thread(background_task())

本意是发起线程(background_task是一个重载了括号运算符的类,却被解释成了,函数声明。函数名my_thread,只接受一个参数,返回std::thread对象,接受的参数是函数指针,指针所指向的函数是没有参数输入,返回background_task对象。

解决方案:

std::thread my_thread((background_task()));
// 或者
std::thread my_thread{background_task()};

也可以使用lambda表达式,它属于可调用对象,准许我们编写局部函数,能捕获某些局部变量,又无需传递参数。

std::thread my_thread([]{
        do_something();
        do_something_else(); 
});

启动线程之后,就需要明确等他结束,还是任由它独自运行。如果thread对象销毁之际还没决定好,thread的析构函数调用std::terminate()终止整个应用程序。 

如果选择了detach新线程,在主线程结束后,子线程就存在外部数据是否合法的问题。解决的方法,就是领线程完全自含,将数据复制到新线程内部,而不是共享外部主线程数据。

2.1.2 等待线程完成

通过与线程关联的std::thread实例上,通过调用成员函数join(),控制等待子线程完成。join简单粗暴,如果需要更细粒度的控制,比如查验线程结束与否,或限定只等待一段时间,那我们便得改用其他方式,如条件变量和future

2.1.3在出现异常情况下的等待

在std::thread对象被销毁前,需要确保已经调用join()或detech()。如果要分离,在启动后调用detach即可,然而,如果打算join,就需要挑选位置。因为,如果启动后有异常抛出,而join尚未执行,则该join调用会被略过。一般可以用try-catch来做。以保证新线程在主线程函数退出前终结,且一定能够执行到join函数。

 2.1.4在后台运行线程

2.2 向线程函数传递参数

2.3 移交线程归属权

附:

1. lambda表达式全解

https://www.cnblogs.com/DswCnblog/p/5629165.htmlhttps://www.cnblogs.com/DswCnblog/p/5629165.html2. C++中的function和bind

【精选】【C++】C++11的std::function和std::bind用法详解_c++中的std中的方法-CSDN博客

3. 左值,右值,左值引用,右值引用https://www.cnblogs.com/SZxiaochun/p/8017475.html 

4. C++ std::ref————详解-CSDN博客

5. 详解C++移动语义std::move()_子木呀的博客-CSDN博客 

6. 现代 C++ 性能飞跃之:移动语义 - 知乎 

 文章来源地址https://www.toymoban.com/news/detail-745461.html

到了这里,关于并发编程: 2. 线程管控的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 多线程与高并发——并发编程(4)

    1.1 生产者消费者概念 生产者-消费者是设计模式的一种,让生产者和消费者基于一个容器来解决强耦合的问题。生产者与消费者彼此之间不会直接通讯,而是通过一个容器(队列)进行通讯。 生产者生产完数据后扔到容器中,不用等消费者来处理; 消费者也不需要去找生产

    2024年02月10日
    浏览(48)
  • 多线程与高并发——并发编程(5)

    为什么要使用线程池? 在开发中,为了提升效率,我们需要将一些业务采用多线程的方式去执行。比如,有一个比较大的任务,可以将任务分成几块,分别交给几个线程去执行,最终做一个汇总即可。再比如,做业务操作时,需要发送短信或邮件,这些操作也可以基于异步的

    2024年02月09日
    浏览(45)
  • 并发编程 ---为何要线程池化

    众所周知,使用线程可以极大的提高应用程序的效率和响应性,提高用户体验,但是不可以无节制的使用线程,为什么呢? 线程的开销实际上是非常大的,我们从空间开销和时间开销上分别讨论。 线程的空间开销来自这四个部分: 线程内核对象(Thread Kernel Object)。每个线程都

    2024年02月16日
    浏览(38)
  • C++线程入门:轻松并发编程

            在现代计算机应用程序中,我们经常需要处理并发任务,这就需要使用多线程来实现。C++是一种功能强大的编程语言,提供了丰富的线程支持,使得并发编程变得相对容易。         C++ 线程是一种多线程编程模型,可以在同一个程序中同时执行多个独立的任务

    2024年02月04日
    浏览(41)
  • 并发编程 --- 信号量线程同步

    上文编码技巧 --- 同步锁对象的选定中,提到了在C#中,让线程同步有两种方式: 锁(lock、Monitor等) 信号量(EventWaitHandle、Semaphore、Mutex) 加锁是最常用的线程同步的方法,就不再讨论,本篇主要讨论使用信号量同步线程。 实际上,再C#中 EventWaitHandle 、 Semaphore 、 Mutex 都是

    2024年02月16日
    浏览(42)
  • 【Java 并发编程】一文读懂线程、协程、守护线程

    在 Java 线程的生命周期一文中提到了 就绪状态的线程在获得 CPU 时间片后变为运行中状态 ,否则就会在 可运行状态 或者 阻塞状态 ,那么系统是如何分配线程时间片以及实现线程的调度的呢?下面我们就来讲讲线程的调度策略。 线程调度是指系统为线程分配 CPU 执行时间片

    2023年04月08日
    浏览(60)
  • 并发编程系列---【线程池七大核心参数】

    一、七大核心参数 1.corePoolSize                            核心线程数 2.maximumPoolSize                   最大线程池参数 3.keepAliveTime                         任务结束后,线程存活此处指定时间后才会被释放 4.TimeUnit                                  上一个参数的

    2024年02月13日
    浏览(42)
  • Java并发编程面试题——线程池

    参考文章: 《Java 并发编程的艺术》 7000 字 + 24 张图带你彻底弄懂线程池 (1) 线程池 (ThreadPool) 是一种用于 管理和复用线程的机制 ,它是在程序启动时就预先创建一定数量的线程,将这些线程放入一个池中,并对它们进行有效的管理和复用,从而在需要执行任务时,可以从

    2024年02月07日
    浏览(51)
  • Java并发编程之线程池详解

    目录 🐳今日良言:不悲伤 不彷徨 有风听风 有雨看雨 🐇一、简介 🐇二、相关代码 🐼1.线程池代码 🐼2.自定义实现线程池 🐇三、ThreadPoolExecutor类 首先来介绍一下什么是线程池,线程池是一种利用池化技术思想来实现的线程管理技术,主要是为了复用线程、便利地管理线程

    2024年02月12日
    浏览(46)
  • Python之并发编程多线程理论

    在传统操作系统中,每个进程有一个地址空间,而且默认就有一个控制线程 线程顾名思义,就是一条流水线工作的过程,一条流水线必须属于一个车间,一个车间的工作过程是一个进程 车间负责把资源整合到一起,是一个资源单位,而一个车间内至少有一个流水线 流水线的

    2024年02月07日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包