进程与线程小结

前言

向前面文章开头所说的,当一个计算机进行运行的时候会出现好多进程(如下图),而对于cpu来说,一个普遍的cpu也就是几个核心,几十个线程。那么问题来了,这么多程序是如何才能正常运行呢?
在这里插入图片描述

认识线程

是啥

一个线程就是一个 “执行流”. 每个线程都是独立的,每个线程之间都可以按照顺序执行自己的代码. 多个线程之间 “同时” 执行着多份代码
简单理解就是好多人一起干一件事或多件事,但它们相互不影响。
还可以这样理解,当你运行音乐播放器时(进程),你会听歌曲,搜索歌曲,评论歌曲,将歌词置于桌面等等…这都是线程,此时一个进程下就有好多个线程 ,多个线程之间是 “并发” 执行的

为啥要有

》如前言所说,一个程序运行会出现进程,计算机在运行时会出现好多进程,而对于这么多进程,cpu明显吃不消,则人们引入了线程,而对于线程来说,一个程序的运行往往会有好多个线程,称为多线程多线程是java的特性,因为现在cpu都是多核多线程的,可以同时执行几个任务,为了提高jvm的执行效率,java提供了这种多线程的机制,以增强数据处理效率
这样以来就处理cpu吃不消的问题,更充分利用了cpu的资源。
对于多线程:多线程是处理并发的一种编程方法,即并发需要用多线程实现。
》有些任务场景需要 “等待 IO”, 为了让等待 IO 的时间能够去做一些其他的工作, 也需要用到并发编程.即多线程
》在前面也提到了进程也可以实现并发编程那为什么还要用线程呢?
其1:创建线程要比进程快
其2:销毁线程要比进程快
其3:调度线程要比进程快
:以“三快”达到比进程更轻量
线程轻量化加以解释:进程看作一个工作间,工作间里面有好多(即线程)。
其1:创建线程可以看作给工作间添加新人,而创建进程可以看作创建一个工作间,可想而知线程快
其2:开除一个员工当然比销毁一个工作间快
其3:同理,调走一个员工比“搬工作间”快

进程与线程的区别与联系

进程包含线程一个进程里面可以有单个或多个线程
内存空间共享进程和进程之间不共享内存空间的,一个进程里面多个线程之间可以共享内存空间
简单的理解:将进程看作一个工作间,而工作间里面有好多人(即线程),这么多人一起在工作间工作当然共享该工作间的资源(内存空间)。而另一个工作间自然不会共享该工作间的资源的。
进程是系统分配资源的最小单位,线程是系统调度的最小单位
》》那么如何创建线程以及Thread类的基本用法实例,后面文章会进一步说明

  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值