多线程技术概述(一)

线程与进程
进程

  • 是指一个内存中运行的应用程序,每个进程都有一个独立的内存空间(每个进程的内存空间是独立的,都有自己的堆、栈,互不共享)

线程

  • 是进程中的一个执行路径,共享一个内存空间,线程之间可以自由切换,并发执行. 一个进程最少 有一个线程
  • 线程实际上是在进程基础之上的进一步划分,一个进程启动之后,里面的若干执行路径又可以划分 成若干个线程

进程就好比软件,执行的事情就是线程。线程是进程的进一步基础,划分的更细。

线程调度

分时调度

  • 所有线程轮流使用 CPU 的使用权,平均分配每个线程占用 CPU 的时间。(把大脑的时间均分,轮流使用)(多线程,是为了让多条线路均分,更合理的交替执行)

抢占式调度

  • 优先让优先级高的线程使用 CPU,如果线程的优先级相同,那么会随机选择一个(线程随机性), Java使用的为抢占式调度。

  • CPU使用抢占式调度模式在多个线程间进行着高速的切换。对于CPU的一个核新而言,某个时刻, 只能执行一个线程,而 CPU的在多个线程间切换速度相对我们的感觉要快,看上去就是 在同一时 刻运行。其实,多线程程序并不能提高程序的运行速度,但能够提高程序运行效率,让CPU的使用率更高。

计算机的大脑数量很少,但是线程会有几千个,为了让计算机能在执行线程时不卡,有以上三种方法,早期的DOS系统只能做一件事情,通过这种方法,给人造成假象,看起来好像在一块执行。线程去抢CPU分出来的时间篇。

不能提高程序的运行速度,但能提高程序的运行效率(一个线程等待用户输入,另一个线程阿巴巴)

  1. 问:1000个人同时访问数据库,是排队快还是同时进行块

答:排队做比较快(不用来回切换)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Fun灬小鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值