多线程
发布日期:2021-06-27 12:56:01 浏览次数:34 分类:技术文章

本文共 675 字,大约阅读时间需要 2 分钟。

文章目录

线程与进程

进程: 是指一个内存中运行的应用程序,每个进程都有一个独立的内存空间

线程: 是进程中的一个执行路径,共享一个内存空间,线程之间可以自由切换,并发执行. 一个进程最少有一个线程

线程实际上是在进程基础之上的进一步划分,一个进程启动之后,里面的若干执行路径又可以划分成若干个线程

线程调度

分时调度

  • 所有线程轮流使用 CPU 的使用权,平均分配每个线程占用 CPU 的时间

抢占式调度

  • 优先让优先级高的线程使用 CPU,如果线程的优先级相同,那么会随机选择一个(线程随机性),Java使用的为抢占式调度
  • CPU使用抢占式调度模式在多个线程间进行着高速的切换。某个时刻,cpu的一个核心只能执行一个线程,而 CPU在多个线程间切换速度相对我们的感觉要快,看上去仿佛在同一时刻运行。 其实,多线程程序并不能提高程序的运行速度,但能够提高程序运行效率,让CPU的 使用率更高。

同步与异步

  • 同步:排队执行,效率低但是安全
  • 异步:同时执行 , 效率高但是数据不安全.

并发与并行

  • 并发:指两个或多个事件在同一个时间段内发生。
  • 并行:指两个或多个事件在同一时刻发生(同时发生)。

线程的六种状态

  • NEW
    尚未启动的线程处于此状态
  • RUNNABLE
    在Java虚拟机中执行的线程处于此状态
  • BLOCKED
    被阻塞等待监视器锁定的线程处于此状态
  • WAITING
    无限期等待另一个线程执行特定操作的线程处于此状态
  • TIMED_WAITING
    正在等待另一个线程执行最多指定等待时间操作的线程处于此状态
  • TERMINATED
    已退出的线程处于此状态

转载地址:https://blog.csdn.net/weixin_43454088/article/details/117307512 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:多线程的实现
下一篇:IO流

发表评论

最新留言

能坚持,总会有不一样的收获!
[***.219.124.196]2024年04月22日 19时38分55秒