2018-03-29 理解多线程和多进程

我之前一直把线程和进程搞混,今天准备好好整理一下。

官方解释——什么是进程,什么是线程?

进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。在早期面向进程设计的计算机结构中,进程是程序的基本执行实体;在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体

线程,有时被称为轻量级进程(Lightweight Process,LWP),是程序执行流的最小单元。一个标准的线程由线程ID,当前指令指针(PC),寄存器集合和堆栈组成。另外,线程是进程中的一个实体,是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,只拥有一点儿在运行中必不可少的资源,但它可与同属一个进程的其它线程共享进程所拥有的全部资源。一个线程可以创建和撤消另一个线程,同一进程中的多个线程之间可以并发执行。由于线程之间的相互制约,致使线程在运行中呈现出间断性。线程也有就绪、阻塞和运行三种基本状态。就绪状态是指线程具备运行的所有条件,逻辑上可以运行,在等待处理机;运行状态是指线程占有处理机正在运行;阻塞状态是指线程在等待一个事件(如某个信号量),逻辑上不可执行。每一个程序都至少有一个线程,若程序只有一个线程,那就是程序本身。

看了标准解释,还是有点晕晕的。

形象比喻理解

(我自己的理解哈,不一定正确)

一个进程

比如现在有一个任务,就是要做一个保温杯,只有我一个人,那我拿到材料和工具以后,我就先做了一个杯子的身体,然后我做了杯子的盖子,最好以后把工具还回去去,结束任务。

多个进程

其实可以理解为多个任务,比如现在要做一个保温杯和买暖宝宝。然后有我和小白两个人,然后把工具给我,我去制作保温杯,把钱给小白,他去买暖宝宝,我做完以后把工具还回去,小白把多出来的钱还回去,任务结束

线程

可以理解为一个总任务中的单个小任务(但是离不开开头的环境配置和资源发放),比如有一个任务,就是要做一个保温杯,那个做杯盖和杯子的杯身可以看做线程。

多线程

接上个,就是要做一个保温杯,那个做杯盖和杯子的杯身可以看做线程。现在有两个人,我和小白,我在做杯身的时候,小白同时做杯盖,那么这个就叫多线程,最后我们做完了,都要一起上交工具。

意义何在

多个任务之间切换,节约计算时间

由于CPU与其他PC资源之间速度的不协调,人们想提高资源利用率,所以人们提出了多任务系统。得益于CPU的计算速度,我们可以“同时”运行多个任务,实质上是多个任务之间轮流使用CPU资源,由于速度超快,给用户的感觉就是连续的。

进程之间是相互不影响的,比如小白如果去买暖宝宝没有回来,我还是会做完杯子。但是,线程之间属于同一个任务,小白如果没有把杯盖做完,那么我只做了杯身,所以任务还是没有完成。

当然这个只是我自己想想的,可能不是很清楚。

我们在平时跑生物信息软件的时候,可能会发现,有些软件可以-t 增加线程数量,这可以极大地加快运算速度,因为这里采用了多线程运算,但是千万不要设置太多,因为服务器里面还有其他小伙伴在跑程序,你设置了太多,可能会超过总数,造成服务器压力,其他小伙伴的程序跑的就慢了。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 又来到了一个老生常谈的问题,应用层软件开发的程序员要不要了解和深入学习操作系统呢? 今天就这个问题开始,来谈谈操...
    tangsl阅读 4,172评论 0 23
  • 线程是一种轻量级进程。与进程相比,线程给操作系统带来的创建、维护和管理负担要轻,因为与线程相关的信息非常少。它同时...
    manofmountain阅读 878评论 0 2
  • 操作系统概论 操作系统的概念 操作系统是指控制和管理计算机的软硬件资源,并合理的组织调度计算机的工作和资源的分配,...
    野狗子嗷嗷嗷阅读 12,075评论 3 34
  • 昨天是2015的终结,可是我在最后几个小时的时候接到妈妈打来的电话,妈妈说,姐姐没了。我不知道听到那一刻是一种...
    小不点是没人爱的阅读 406评论 2 2
  • 对呀可能朋友们都会陷入一个这样的情况 不想谈恋爱别人表白拒绝但是又渴望爱呀 你这不是性冷淡 看到帅帅的男神还是会激...
    关耳的关阅读 166评论 0 1