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 ...
随机推荐
- 【HDOJ】4122 Alice's mooncake shop
RMQ的基础题目,简单题. /* 4122 */ #include <iostream> #include <sstream> #include <string> ...
- C语言计算程序运行时间
#include<stdio.h>#include<stdlib.h> #include "time.h" int main( void ) { ...
- nodejs创建express+ejs项目
很多同学跟着 node.js开发指南 学习用 express+ejs 创建项目的时候,却总是无法成功,如: 运行 以下命令去创建 express+ejs 创建项目 $ express -t ejs m ...
- 1471. Tree(LCA)
1471 先学习了下tarjan算法的LCA 离线算法 它是先知道询问的结点对 在遍历的时候就已经算出来了 看篇图解 讲的很清楚 #include <iostream> #include& ...
- bzoj2245
这道题还是比较简单的费用流,由于w是递增的 实际上,这题数据还可以强一点,比如说分段函数不保证费用递增, 就要加一点技巧了(要保证函数的顺序) ; type node=record ne ...
- linq .dbml转化成sql脚本
public String ConvertDBMLToSqlScript(System.Data.Linq.DataContext DBContext) { String DBCon ...
- windows ping RPi 2B
/************************************************************************* * windows ping RPi 2B * 声 ...
- 解决java switch……case不能匹配字符串的问题
java1.7已经支持了匹配字符串 方案1. enum Animal { dog,cat,bear; public static Animal getAnimal(String animal){ re ...
- 关于Azure存储账户中存储虚拟机VHD文件的注意事项
Joy Qiao from MSFT Thu, Mar 12 2015 3:16 PM 我们在使用Azure时经常都会在Azure存储账户中放一些文件,包括Azure虚机的VHD文件也都是放在存储 ...
- Ext入门学习系列(五)表格控件(3)
上节学习了Ext中如何绑定服务器端传递的数据.分别用asp.net和asp.net MVC.PHP.XML为例.本节主要介绍绑定之后的分页功能. 一.Ext的表格控件如何绑定? 分页是Ext自带的一个 ...