并行与并发,进程与线程

虽然对于基本概念了然于心,但是每隔一段时间看到别人写的,总是会再点进去看看,哎,就会有不一样的感受。

并行与并发。

并行: 同一时刻,两个线程都在执行。
并发 :是同一时刻,只有一个执行,但是一个时间段内,两个线程都执行了。
并行与并发的图例

————————————————————————————————————————————
有次同事开玩笑说,写什么多线程,cpu 就那么一个或者两个,有些还是伪双核,同一时刻执行的肯定只有一个线程在运行计算,你写多线程不也没什么用吗,忽然之间有点蒙,好似是这个道理啊,同一时刻只有一个线程在跑啊,做什么多线程啊。
待了一会儿想了想不对:

  • 同一时刻的确只有一个核 在执行一个线程,但是多核就不一样了,现在服务器都是双核四核什么的,效率肯定会提高,
  • 线程会偷懒,一个任务需要多方面写作,io ,cpu计算、、、 有时会阻塞等待等待io或者其他完成之后再cpu上完成剩下的,多线程的话就会提高cpu的利用率,而NIO 及AIO和由此产生的netty,mina框架之类都是一样的作用。

进程与线程

加粗的部分有些词语用的很好,有一语中的的赶脚
  • 一个程序至少一个进程,一个进程至少一个线程
  • 每个进程都有独立的内存地址空间;系统不会为线程分配内存,线程组之间只能共享所属进程的资源
  • 程序之间的切换会有较大的开销;线程之间切换的开销小
  • 进程是系统进行资源分配和调度的一个独立单位;线程是进程的一个实体,是CPU调度和分派的基本单位
  • 根本区别:进程是操作系统资源分配的基本单位,而线程是任务调度和执行的基本单位
  • 在开销方面:每个进程都有独立的代码和数据空间(程序上下文),程序之间的切换会有较大的开销;线程可以看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数器(PC),线程之间切换的开销小。
  • 所处环境:在操作系统中能同时运行多个进程(程序);而在同一个进程(程序)中有多个线程同时执行(通过CPU调度,在每个时间片中只有一个线程执行)
  • 内存分配方面:系统在运行的时候会为每个进程分配不同的内存空间;而对线程而言,除了CPU外,系统不会为线程分配内存(线程所使用的资源来自其所属进程的资源),线程组之间只能共享资源。
  • 包含关系:没有线程的进程可以看做是单线程的,如果一个进程内有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的;线程是进程的一部分,所以线程也被称为轻权进程或者轻量级进程。

借鉴两位大佬的,本文是转载综合,整合加上自己今天的体悟。

原文链接:kingdoooom
原文链接:ConstXiong

Guess you like

Origin blog.csdn.net/weixin_41086086/article/details/102466861