线程基础概念

1、什么是进程和线程

进程是操作系统为程序运行进行资源分配的最小单位,其中资源包括:CPU、内存空间、磁盘IO等。同一个进程中的多个线程共享该进程中的全部资源。而不同进程之间,进程和进程是相互独立的。

线程是进程的一个实体,是CPU调度的最小单位,必须依赖于线程而存在。它与同属一个进程的其它的线程共享进程所拥有的全部资源。

例如:WPS是一个应用程序,双击后,操作系统就进行资源分配,使其能正常运行,就开启了一个进程,同时也至少开启了一个线程,比如在编写word文档的时候,会不定期的自动保存,这个就是另外一个线程在处理。所以程序是死的、静态的,进程是活的、动态的,一个进程至少存在一个线程。

2、CPU核心数和线程数的关系

CPU核心数是物理概念,是指硬件上存在几个核心。比如,双核就是包括2个相对独立的CPU核心单元组,四核就包含4个相对独立的CPU核心单元组,等等,依次类推。

CPU线程数是逻辑概念,简单地说,就是模拟出的CPU核心数。比如,可以通过一个CPU核心数模拟出2线程的CPU,也就是说,这个单核心的CPU被模拟成了一个类似双核心CPU的功能。这样可以更好的描述CPU的运行能力。

CPU的线程数概念仅仅只针对Intel的CPU才有用。一般情况下它们是1:1对应关系,也就是说四核CPU一般拥有四个线程。但Intel引入超线程技术后,使核心数与线程数形成1:2的关系。目前主流CPU都是多核的,增加核心数目就是为了增加线程数,因为操作系统是通过线程来执行任务的。增加线程数是源于多任务处理的需要,线程数越多,越有利于同时运行多个程序。

实际应用中,线程数远大于CPU核心数,感觉并没有受到CPU核心数的限制,那是因为CPU时间片轮转机制的原因。

3、CPU时间片轮转机制

我们平时在使用电脑时,开启了多个应用程序(也就是启动了多个线程),进行各种复杂的操作任务,系统依然能正常进行,为什么?这是因为操作系统提供了一种CPU时间片轮转机制。

时间片轮转调度是一种最古老、最简单、最公平且使用最广的算法,又称RR调度。时间片轮转法(Round-Robin,RR)主要用于分时系统中的进程调度。为了实现轮转调度,系统把所有就绪进程按先入先出的原则排成一个队列。新来的进程加到就绪队列末尾。每当执行进程调度时,进程调度程序总是选出就绪队列的队首进程,让它在 CPU 上运行一个时间片的时间。时间片是一个小的时间单位,通常为 10~100ms 数量级。当进程用完分给它的时间片后,系统的计时器发出时钟中断,调度程序便停止该进程的运行,把它放入就绪队列的末尾;然后,把 CPU 分给就绪队列的队首进程,同样也让它运行一个时间片,如此往复。

4、什么是并行和并发

并行:指两个或多个事件在同一时刻点发生,CPU同时执行。看的是同一个时刻点上有多少个任务在执行,这个执行的数量叫并行度。

并发:指两个或多个事件在同一时间段内发生,CPU交替执行。看的是在一个时间段内有多少个任务执行,这个执行的数量叫并发数。

比如:高速公路上并排有4条车道,那么同一时刻,高速公路上最多只有4辆车并排而走,那么并行度为4,这就是并行。假设遇到一条单行的隧道时,这4条车道的车都要相互交替的通过隧道,假设10min通过了30辆,那么并发数为30辆/10min=3辆/min,这就是并发。

所以当谈论并发的时候一定要加个单位时间,也就是说单位时间内并发量是多少,否则离开了单位时间其实是没有意义的。

5、高并发编程的好处和注意事项

好处:

(1)充分利用 CPU 的资源

(2)加快响应用户的时间

(3)可以使代码模块化,异步化,简单化

注意事项:

(1)线程之间的安全性

(2)线程之间的死锁

(3)线程太多了会将服务器资源耗尽形成死机宕机

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,172评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,346评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,788评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,299评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,409评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,467评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,476评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,262评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,699评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,994评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,167评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,499评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,149评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,387评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,028评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,055评论 2 352