当前位置: 首页 > news >正文

线程的礼让和加入

1、线程的礼让是一种让当前正在执行的线程主动暂停、并允许其他具有相同优先级的线程获取 CPU 执行权的机制。这种机制可以帮助线程间更公平地共享 CPU 资源,但它并不保证一定会让出执行权。

Thread.yield() 是一个静态方法,用于提示线程调度器当前线程愿意让出 CPU 执行权。但调度器可以选择忽略这个提示。

Thread.yield();

注意事项

  1. 不保证切换yield() 只是建议线程调度器切换线程,但调度器可能忽略这个建议,导致当前线程继续执行。
  2. 与 sleep() 的区别
    • yield():暂停当前线程,可能立即恢复执行。
    • sleep():强制当前线程暂停指定时间,期间不会被调度。
  3. 优先级影响:如果存在高优先级线程,yield() 可能无法让低优先级线程获得 CPU。

在操作系统层面,yield() 会使当前线程从 运行状态(Running) 转换为 就绪状态(Runnable),然后重新参与 CPU 竞争。

2、线程的加入(Join) 是一种让一个线程等待另一个线程完成执行的机制。通过 join() 方法,一个线程可以阻塞自己的执行,直到目标线程执行完毕。这在需要确保线程执行顺序或等待其他线程结果的场景中非常有用。

join() 是 Thread 类的实例方法,用于等待调用该方法的线程执行完成。

  • join():无限等待,直到目标线程终止。
  • join(long millis):最多等待 millis 毫秒,如果超时则不再等待。
  • join(long millis, int nanos):更精确的等待时间(毫秒 + 纳秒)。

底层原理

  • join() 的本质是调用 Object.wait() 方法,使当前线程进入等待状态,直到目标线程终止。
  • 当目标线程终止时,JVM 会自动调用 notifyAll() 唤醒所有等待该线程的其他线程。
http://www.dtcms.com/a/267113.html

相关文章:

  • 1004、最大连续1的个数 III
  • SpringBatch使用介绍
  • 任务调度器(Scheduler)实现逻辑
  • Java 创建对象过程 JVM 内存分配并发安全笔记
  • JVM与JMM
  • Mysql底层专题(四)索引优化实战一
  • DeepSeek与诡秘之主
  • 在SoC数据加解密验证中使用 Python 的 gmssl 库
  • 03_性能优化:让软件呼吸更顺畅
  • 计算机网络(网页显示过程,TCP三次握手,HTTP1.0,1.1,2.0,3.0,JWT cookie)
  • 【网络协议安全】任务12:二层物理和单臂路由及三层vlanif配置方法
  • HarmonyOS:创建ArkTS卡片
  • 从零开始开发纯血鸿蒙应用之探析仓颉语言与ArkTS的差异
  • Vuex身份认证
  • 《C++初阶之类和对象》【经典案例:日期类】
  • Java创建型模式---单例模式
  • WSL命令
  • C#每日学习日记
  • 3dmax烘焙插件3dmax法线贴图烘焙教程glb和gltf元宇宙灯光效果图烘焙烘焙光影贴图支持VR渲染器
  • AWS WebRTC:通过shell分析viewer端日志文件
  • 深入解析享元模式:通过共享技术高效支持大量细粒度对象
  • 【力扣 简单 C】70. 爬楼梯
  • 【鸿蒙】鸿蒙操作系统发展综述
  • 递归与循环
  • 深入理解Reactor调试模式:Hooks.onOperatorDebug() vs ReactorDebugAgent.init()
  • 软件工程经济与伦理
  • 流水线(Jenkins)打包拉取依赖的时候提示无法拉取,需要登录私仓的解决办法
  • HTML知识复习2
  • HuggingFists: 无代码处理复杂PDF
  • 一个简单的网页设计