Thread学习
1.定义
2.作用
3.和进程的比较
4.多线程(multithreading)的优点和缺陷
5.调度(scheduling)
6.线程相关概念
定义
线程就是最小的可编程指令序列,是进程的子集。一个进程由一个或多个线程组成。
作用
线程的作用就是要加速程序的执行,提高计算机的性能,满足多任务需求。比如word,你可以编辑,同时语法检查也正在进行,至少就是两个线程了。再比如播放电影,视频线程和音频线程同时执行,同时有两种可能,一种是在多核cpu下,每个进程在不同的cpu,是真正的同时执行;另一种是单核cpu,这时可以采用time_sliced策略来实现同时的效果。
和进程的比较
|
process |
thread |
|
|
是否独立 |
独立 |
不独立,作为进程的子集存在 |
|
状态信息 |
更多 |
没进程多,一个进程的thread共享状态信息 |
|
是否有分隔的地址空间 |
有 |
没有 |
|
交互 |
process之间通过inter-process |
thread之间的交互通过他们已经共享了的data,code,files |
|
context switching速度 |
慢 |
快 |
多线程的优点和缺陷
多线程主要用于多任务操作系统中,多线程作为一个广泛使用的编程和执行模型允许多个线程存在于一个单独的进程里。这些线程共享进程的资源,但是能够单独的执行任务。
多线程应用程序有以下优点:
(1)负责任:单线程程序,如果主进程被要执行很久的任务阻塞,那整个应用程序就卡死了。如果是多线程就不存在这个问题,多线程的话,让子线程来执行,就算这个子线程被阻塞了,其他子线程和主线程还可以等待用户输入。
(2)更快的执行:当有多个CPU或多核CPU的情况下,多线程就会是真正的同时执行(每个cpu执行一个thread),而不是time_sliced。
(3)更低的资源消耗:单进程多线程比多进程消耗的资源要少很多。比如,Apache就是利用多个listener
threads来监听请求和多个server
threads来处理请求。
(4)更好的系统利用:比如,一个文件系统用多线程可以达到更高的吞吐量和更低的延迟。因为在更快的中介(比如缓存)里的数据可以被一个线程获取,另外一个线程可以去低速中介(比如硬盘)获取数据而不需要等待其他线程完成操作。
(5)简化共享和交互:线程之间的通信主要通过它们已经共享的数据,代码和文件。
(6)平行化:通过处理让多个任务同时执行。
多线程的缺陷:
(1)同步的麻烦:因为一个进程的多个线程共享地址空间,程序员需要非常小心的来避免race
conditions和其他非直观的行为。为了正确的操作数据,多个线程通常需要及时集合来确保按正确的顺序来处理数据。
这个时候可能需要用锁(更多的用信号量,其实信号量可以看成是多个锁的集合)来阻止同一数据被同时修改或读取当这个数据正在被修改。
(2)一个线程摧毁一个进程:一个线程的非法操作会摧毁整个进程。
调度
操作系统调度线程的两种方式:
(1)抢占式多任务是优先选择的方式。它允许操作系统来决定什么时候切换上下文来让更重要的线程来获得cpu资源。抢占式多任务的缺点:当操作系统切换上下文的时候不合适时,可能会导致不好的结果,比如lock
convoy(多个优先级一样的线程重复竞争同一个锁)
和 priority
inversion(优先级低的线程抢到了cpu资源)。为了避免这个缺陷,于是就有了合作式多线程。
(2)合作式多线程。这个方式依赖于多线程自己来决定在什么点来放弃对cpu资源的控制。
显然,第一种调度方式,主导者是操作系统;第二种调度方式,主导者是多线程。
线程相关概念
green thread:被虚拟机调度的thread。
software thread:被操作系统调度的thread。
Thread学习的更多相关文章
- InnoDB master thread学习
很久很久没有写博客了,工作比较忙,也没什么时间学习了,恰逢国庆放假,安心的学习一下,其实只是把之前学习过的知识再温习了一下而已.InnoDB 有众多的线程,其中非常核心的就是master thread ...
- thread学习笔记--BackgroundWorker 类
背景: 在 WinForms 中,有时要执行耗时的操作,比如统计某个磁盘分区的文件夹或者文件数目,如果分区很大或者文件过多的话,处理不好就会造成“假死”的情况,或者报“线程间操作无效”的异常,或者在该 ...
- c++11: <thread>学习
<thread>头文件中包含thread类与this_thread命名空间,下面逐一介绍. thread类 1. 构造函数 (1)默认构造函数 thread() noexcept; 默认构 ...
- Boost Thread学习笔记五
多线程编程中还有一个重要的概念:Thread Local Store(TLS,线程局部存储),在boost中,TLS也被称作TSS,Thread Specific Storage.boost::thr ...
- Boost Thread学习笔记四
barrierbarrier类的接口定义如下: 1 class barrier : private boost::noncopyable // Exposition only 2 { 3 pub ...
- Boost Thread学习笔记三
下面先对condition_impl进行简要分析.condition_impl在其构造函数中会创建两个Semaphore(信号量):m_gate.m_queue,及一个Mutex(互斥体,跟boost ...
- Boost Thread学习笔记二
除了thread,boost种:boost::mutexboost::try_mutexboost::timed_mutexboost::recursive_mutexboost::recursive ...
- Boost Thread学习笔记
thread自然是boost::thread库的主 角,但thread类的实现总体上是比较简单的,前面已经说过,thread只是一个跨平台的线程封装库,其中按照所使用的编译选项的不同,分别决定使用 W ...
- thread 学习
#include <thread> #include <cstdio> #include <utility> #include <iostream> v ...
随机推荐
- C#读取注册表信息
注册表是视窗系统的一个核心的数据库,在这个数据库中存放中与系统相关的各种参数,这些参数直接控制中系统的启动.硬件的驱动程序安装信息以及在视窗系统上运行的各种应用程序的注册信息等.这就意味着,如果注册表 ...
- UVa 1642 (综合) Magical GCD
题意: 给出一个数列,求一个连续的子序列,使得MGCD(i, j) = 该子序列的长度(j-i+1) × 子序列的gcd 最大,并输出这个最大值. 分析: 感觉可能要用优先队列,但貌似也用不上. 但 ...
- UVa 1393 (容斥原理、GCD) Highways
题意: 给出一个n行m列的点阵,求共有多少条非水平非竖直线至少经过其中两点. 分析: 首先说紫书上的思路,编程较简单且容易理解.由于对称性,所以只统计“\”这种线型的,最后乘2即是答案. 枚举斜线包围 ...
- 《C#并行编程高级教程》第8章 线程池 笔记
主要的几个概念(详细最好还是看书,配合插图看) 任务是会被分配到线程上的,而这些线程都在线程池引擎下管理 线程池引擎管理着合适数量的线程池,线程从全局队列获取工作项执行. .NET4 Framew ...
- Hibernate4.x之Session
Hibernate Session概述 Session接口是Hibernate向应用程序提供的操纵数据库的最主要的接口,它提供了基本的保存.更新.删除和加载Java对象的方法. Session具有一个 ...
- Oracle ORA-00119和ORA-00132的解决方案
今天在启动服务器上的ORACLE时遇到如下错误: SQL> startup; ORA-00119: invalid specification for system parameter LOCA ...
- Python中,如何初始化不同的变量类型为空值
参考文章 Python中,如何初始化不同的变量类型为空值 常见的数字,字符,很简单,不多解释. 列表List的其值是[x,y,z]的形式 字典Dictionary的值是{x:a, y:b, z:c} ...
- hbase分页查询
为了广大技术爱好者学习netty,在这里帮新浪微博@nettying宣传下他出版的新书 <netty权威指南>@nettying兄在华为NIO实践多年,这本书是他的技术和经验的一个结晶.N ...
- linux 查看用户所在组(groups指令的使用) 含实例
经常将某个文件夹的权限赋给某个用户的时候,也需要配置该用户所在的组,因此,我们需要查看该用户有哪些组,我们可以使用如上命令查看用户所在组 [oracle@gl ~]$ vi /etc/group ro ...
- Apache Mina原理及典型例子分析
Apache Mina ,一个高性能 Java 异步并发网络通讯框架.利用 Mina 可以高效地完成以下任务: TCP/IP 和 UDP/IP 通讯 串口通讯 VM 间的管道通讯 SSL/TLS JX ...