Java并发编程:进程和线程之由来

 

一:什么是进程?

百度百科解释如下:

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

初看这段文字比较懵逼和抽象,但是看到下图后还不能理解进程吗?(windows10中任务管理器进程列表)

一句话总结:进程就是操作系统中正在运行的一个.exe程序。

二:什么是线程?

线程可以理解为进程中独立运行的子任务。比如QQ.exe运行的时候就有很多子任务,我们在和好友A进行文字聊天的时候还可以同时和好友B进行视频语言聊天,还可以发送文件接收文件等操作。这些不同的操作(功能)都可以同时运行。其中每一项任务就可以理解是一个“线程”在工作,出啊文件,听音乐,发送表情,视频聊天等都有对应的线程在后头默默的运行。

三:多线程有什么好处?

现在的操作系统都是支持多任务的操作系统,比如Windows,Linux,Mac 我们可以“同时”运行很多软件,这样做的目的就是“可以最大限度的利用CUP”,避免一个线程阻塞的时候CUP进行闲置的等待状态。比如我们可以一边处理正在打印的数据,一边使用word编辑文档。此时CPU就在不停的在这些任务之间切换。由于切换速度非常快,给人的感觉就是同时在运行。所以使用多线程技术以后,可以在同一时间内运行更多的不同类型的任务。

为了能更有效的理解多线程的优势,如图所示的场景:

一个人大任务有两个子任务1和2组成,在任务的操作系统中子任务1和2是顺序执行,这个时候在执行子任务1的时候子任务等待着,假如子任务1这个时候处于IO阻塞中的话CPU就处于“空置”状态CUP利用率低下,最终这个大任务完成需要的时间是15秒。

使用多线程并发编程可以将任务1和任务2由串行改为并行执行如下图:

这个时候子任务1和子任务2并行执行,CUP在子任务1和子任务2中来回切换,使子任务2不必要等到子任务1执行10秒完毕后才允许,系统运行效率大大提升,这就是多线程的优势,使用多线程也就是在使用异步。

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值