7.3.1 - 并发多线程 线程

线程与进程解析
本文详细阐述了进程与线程的基本概念,强调了线程作为CPU执行单位的重要性,并通过实例说明了多线程的应用场景。此外,还对比了创建线程与创建进程的成本差异。

一 什么是线程

在传统操作系统中,每个进程有一个地址空间,而且默认就有一个控制线程

线程顾名思义,就是一条流水线工作的过程(流水线的工作需要电源,电源就相当于cpu),而一条流水线必须属于一个车间,一个车间的工作过程是一个进程,车间负责把资源整合到一起,是一个资源单位,而一个车间内至少有一条流水线。

所以,进程只是用来把资源集中到一起(进程只是一个资源单位,或者说资源集合),而线程才是cpu上的执行单位。

多线程(即多个控制线程)的概念是,在一个进程中存在多个线程,多个线程共享该进程的地址空间,相当于一个车间内有多条流水线,都共用一个车间的资源。例如,北京地铁与上海地铁是不同的进程,而北京地铁里的13号线是一个线程,北京地铁所有的线路共享北京地铁所有的资源,比如所有的乘客可以被所有线路拉。

 

总结上述区别,无非两个关键点,这也是我们在特定的场景下需要使用多线程的原因:

  1. 同一个进程内的多个线程共享该进程内的地址资源
  2. 创建线程的开销要远小于创建进程的开销(创建一个进程,就是创建一个车间,涉及到申请空间,而且在该空间内建至少一条流水线,但创建线程,就只是在一个车间内造一条流水线,无需申请空间,所以创建开销小)

三 多线程应用举例

开启一个字处理软件进程,该进程肯定需要办不止一件事情,比如监听键盘输入,处理文字,定时自动将文字保存到硬盘,这三个任务操作的都是同一块数据,因而不能用多进程。只能在一个进程里并发地开启三个线程,如果是单线程,那就只能是,键盘输入时,不能处理文字和自动保存,自动保存时又不能输入和处理文字。

 

四 总结

1. 每启动一个进程,至少启动一个线程

2. 进程内的线程才是运行单位也就是线程才是真正干活的

3.同一 进程内的多个线程之间共享资源

4. 开进程比线程开销大

 

转载于:https://www.cnblogs.com/caimengzhi/p/8516480.html

std::_Deque_iterator<esw::SingleProcessedData, esw::SingleProcessedData&, esw::SingleProcessedData*>::_M_set_node ( __new_node=<optimized out>, this=<optimized out>) at /usr/gcc-linaro-7.3.1-2018.05-x86_64_aarch64-linux-gnu/aarch64-linux-gnu/include/c++/7.3.1/bits/stl_deque.h:257 #1 std::_Deque_iterator<esw::SingleProcessedData, esw::SingleProcessedData&, esw::SingleProcessedData*>::operator+= (__n=10, this=<synthetic pointer>) at /usr/gcc-linaro-7.3.1-2018.05-x86_64_aarch64-linux-gnu/aarch64-linux-gnu/include/c++/7.3.1/bits/stl_deque.h:219 #2 std::_Deque_iterator<esw::SingleProcessedData, esw::SingleProcessedData&, esw::SingleProcessedData*>::operator+ (__n=10, this=0xffff9002c620) at /usr/gcc-linaro-7.3.1-2018.05-x86_64_aarch64-linux-gnu/aarch64-linux-gnu/include/c++/7.3.1/bits/stl_deque.h:230 #3 std::deque<esw::SingleProcessedData, std::allocator<esw::SingleProcessedData> >::_M_reserve_elements_at_back (__n=10, this=0x0) at /usr/gcc-linaro-7.3.1-2018.05-x86_64_aarch64-linux-gnu/aarch64-linux-gnu/include/c++/7.3.1/bits/stl_deque.h:2129 #4 std::deque<esw::SingleProcessedData, std::allocator<esw::SingleProcessedData> >::_M_range_insert_aux<esw::SingleProcessedData*> ( __last=0xffff9d7eb3c0, __first=0xffff9d7eaf10, __pos=..., this=0x0) at /usr/gcc-linaro-7.3.1-2018.05-x86_64_aarch64-linux-gnu/aarch64-linux-gnu/include/c++/7.3.1/bits/deque.tcc:608 #5 std::deque<esw::SingleProcessedData, std::allocator<esw::SingleProcessedData> >::_M_insert_dispatch<esw::SingleProcessedData*> ( __last=0xffff9d7eb3c0, __first=0xffff9d7eaf10, __pos=..., this=0x0) at /usr/gcc-linaro-7.3.1-2018.05-x86_64_aarch64-linux-gnu/aarch64-linux-gnu/include/c++/7.3.1/bits/stl_deque.h:2011 #6 std::deque<esw::SingleProcessedData, std::allocator<esw::SingleProcessedData> >::insert<esw::SingleProcessedData*, void> ( __last=0xffff9d7eb3c0, __first=0xffff9d7eaf10, __position=..., this=0x0) at /usr/gcc-linaro-7.3.1-2018.05-x86_64_aarch64-linux-gnu/aarch64-linux-gnu/include/c++/7.3.1/bits/stl_deque.h:1739 #7 esw::MagTracking::SolveDoubleSensors (this=0xffff9002ae50, vecRawData=..., trackingResult=...) at /mnt/v1/wenzhao.huang/Emts-alg/BoardSoftware/Algorithm/src/emts_alg_mag_tracking.cpp:325 #8 0x0000000000436934 in esw::TerminalController::GetTrackingResult (this=this@entry=0xffff90014778, singleDataVec=..., singleUnit=false, exception=@0xffff9001bd9a: 0, location=...) at /mnt/v1/wenzhao.huang/Emts-alg/BoardSoftware/Feature/src/emts_feature_terminal_controller.cpp:198 #9 0x0000000000434d2c in esw::TrackingManager::Run (this=0xffff90013bf0) at /mnt/v1/wenzhao.huang/Emts-alg/BoardSoftware/Feature/src/emts_feature_tracking_manager.cpp:192 #10 0x0000ffffb065bf9c in ?? () from /lib/aarch64-linux-gnu/libstdc++.so.6 #11 0x0000ffffb0793624 in start_thread (arg=0xffffb065bf80) at pthread_create.c:477 #12 0x0000ffffb03d062c in thread_start () at ../sysdeps/unix/sysv/linux/aarch64/clone.S:78 析奔溃原因
最新发布
08-26
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值