Java 线程的调度与时间片

🙈作者简介:练习时长两年半的Java up主

🙉个人主页:程序员老茶

🙊 ps:点赞👍是免费的,却可以让写博客的作者开兴好久好久😎

📚系列专栏:Java全栈,计算机系列(火速更新中)

💭 格言:种一棵树最好的时间是十年前,其次是现在

🏡动动小手,点个关注不迷路,感谢宝子们一键三连

目录

  • 课程名:Java
  • [Java 线程的调度与时间片](#Java 线程的调度与时间片)
    • [1. 线程调度](#1. 线程调度)
      • [1.1 分时调度](#1.1 分时调度)
      • [1.2 抢占式调度](#1.2 抢占式调度)
    • [2. 时间片](#2. 时间片)
    • [3. 总结](#3. 总结)

课程名:Java

内容/作用:知识点/设计/实验/作业/练习

学习:Java 线程的调度与时间片

Java 线程的调度与时间片

在 Java 中,线程调度是通过操作系统来完成的。Java 提供了一些方法来控制线程的执行,但是具体的调度策略是由操作系统来决定的。本文将介绍 Java 线程的调度与时间片的概念,并通过代码示例进行详细解释。

1. 线程调度

线程调度是指在多线程环境下,操作系统如何分配 CPU 时间片给各个线程。Java 中的线程调度主要有两种:分时调度和抢占式调度。

1.1 分时调度

分时调度是指操作系统将 CPU 时间片分配给每个线程,让它们轮流执行。这种调度策略可以保证每个线程都能得到一定的 CPU 时间,但是不能保证执行顺序。

在 Java 中,可以通过 Thread.yield() 方法来实现分时调度。当一个线程调用 yield() 方法时,它会放弃当前正在执行的 CPU 时间片,让其他线程有机会执行。

java 复制代码
class MyThread extends Thread {
    @Override
    public void run() {
        for (int i = 0; i < 5; i++) {
            System.out.println(Thread.currentThread().getName() + " is running: " + i);
            Thread.yield(); // 让出 CPU 时间片
        }
    }
}

public class Main {
    public static void main(String[] args) throws InterruptedException {
        MyThread thread1 = new MyThread();
        MyThread thread2 = new MyThread();
        thread1.start();
        thread2.start();
        Thread.sleep(1000); // 等待线程执行完毕
    }
}

1.2 抢占式调度

抢占式调度是指操作系统在适当的时候主动中断某个线程的执行,并将其资源分配给其他线程。这种调度策略可以更有效地利用 CPU 资源,但是可能会导致线程执行顺序的不确定性。

在 Java 中,可以通过 wait()notify()synchronized 关键字来实现抢占式调度。这些方法可以让线程在特定条件下进入等待状态,并在满足条件时被唤醒。

java 复制代码
class MyThread extends Thread {
    private Object lock = new Object();

    @Override
    public void run() {
        synchronized (lock) {
            try {
                System.out.println(Thread.currentThread().getName() + " is waiting...");
                lock.wait(); // 进入等待状态
                System.out.println(Thread.currentThread().getName() + " is running...");
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

public class Main {
    public static void main(String[] args) throws InterruptedException {
        MyThread thread1 = new MyThread();
        MyThread thread2 = new MyThread();
        thread1.start();
        thread2.start();
        Thread.sleep(1000); // 等待线程执行完毕
        thread1.lock.notify(); // 唤醒 thread1
    }
}

2. 时间片

时间片是指操作系统为每个线程分配的最小 CPU 执行时间。时间片的大小通常取决于操作系统的设计和硬件的支持。在分时调度策略中,线程的时间片是相等的;而在抢占式调度策略中,线程的时间片可能会有所不同。

在 Java 中,可以通过 Thread.sleep(long millis) 方法来让线程暂停执行一段时间,这段时间就是线程的时间片。例如,以下代码会让线程暂停 1000 毫秒(即 1 秒):

java 复制代码
try {
    Thread.sleep(1000); // 让线程暂停 1 秒
} catch (InterruptedException e) {
    e.printStackTrace();
}

3. 总结

本文介绍了 Java 线程的调度与时间片的概念,并通过代码示例进行了详细解释。在实际应用中,可以根据需要选择合适的线程调度策略,以提高程序的性能和响应速度。

往期专栏
Java全栈开发
数据结构与算法
计算机组成原理
操作系统
数据库系统
物联网控制原理与技术
相关推荐
期待のcode18 小时前
MyBatisX插件
java·数据库·后端·mybatis·springboot
醇氧20 小时前
【Windows】优雅启动:解析一个 Java 服务的后台启动脚本
java·开发语言·windows
sunxunyong20 小时前
doris运维命令
java·运维·数据库
菜鸟起航ing20 小时前
Spring AI 全方位指南:从基础入门到高级实战
java·人工智能·spring
古城小栈20 小时前
Docker 多阶段构建:Go_Java 镜像瘦身运动
java·docker·golang
MapGIS技术支持21 小时前
MapGIS Objects Java计算一个三维点到平面的距离
java·开发语言·平面·制图·mapgis
Coder_Boy_21 小时前
业务导向型技术日志首日记录(业务中使用的技术栈)
java·驱动开发·微服务
程序员zgh21 小时前
C++ 互斥锁、读写锁、原子操作、条件变量
c语言·开发语言·jvm·c++
小灰灰搞电子21 小时前
Qt 重写QRadioButton实现动态radioButton源码分享
开发语言·qt·命令模式
by__csdn1 天前
Vue3 setup()函数终极攻略:从入门到精通
开发语言·前端·javascript·vue.js·性能优化·typescript·ecmascript