首页 > 其他分享 >wait sleep 线程切换 IO阻塞 轮询 锁是否释放和当前线程是否占用CPU资源问题

wait sleep 线程切换 IO阻塞 轮询 锁是否释放和当前线程是否占用CPU资源问题

时间:2022-09-27 01:33:37浏览次数:59  
标签:释放 占用 CPU 线程 IO 轮询 资源

1 wait 以后的 notify()函数释放锁,不占用CPU资源,线程暂定,CPU资源被让出。

 

2 sleep()函数 不释放锁,但是让出CPU资源,确定唤醒时间。

 

3 yield()函数 和操作系统的 自发的切换执行的线程,不释放锁,不确定唤醒时间。

 

4 因为等待网络IO阻塞/磁盘IO导致的线程阻塞,线程不暂停,依旧是活动状态,不存在是否释放锁的问题,占用CPU资源。

 

5 自旋,轮询,空转等行为 占用CPU资源。

 

标签:释放,占用,CPU,线程,IO,轮询,资源
From: https://www.cnblogs.com/cxygg/p/16733130.html

相关文章

  • 开源动态可监控线程池DynamicTp介绍
    前言使用线程池ThreadPoolExecutor过程中你是否有以下痛点呢?代码中创建了一个ThreadPoolExecutor,但是不知道那几个核心参数设置多少比较合适凭经验设置参数值,上......
  • Java SE 19 虚拟线程
    JavaSE19虚拟线程作者:Grey原文地址:博客园:JavaSE19虚拟线程CSDN:JavaSE19虚拟线程说明虚拟线程(VirtualThreads)是在ProjectLoom中开发的,并从JavaSE19开......
  • 虚拟线程
    Java19新特性:虚拟线程(VirtualThreads)......
  • C++多线程编程之【线程管理】
    1.如何启动线程?构建std::thread对象即可。直接传函数名(地址)创建一个类并创建伪函数。构建对象(实例化),将对象作为参数传入thread对象实例化。2.为什么要等待线程?首先......
  • 多线程
    1.线程和进程区别线程的划分尺度小于进程,这使多线程程序拥有高并发性,进程在运行时各内存单元之间相互独立,线程之间内存共享,这使多线程拥有更好的性能和用户体验。线程......
  • 【转载】Python -- 多进程、多线程 的基本使用
    https://www.cnblogs.com/jiyu-hlzy/p/15948408.html 单进程单线程importtimedefproduction():"""间隔一秒,模拟一秒生产一个任务,生产10个任务:ret......
  • Java多线程
    join()方法使用:【已经开了3个线程ABC,要求线程A在线程B的前面执行,线程B在线程C的前面执行】https://blog.csdn.net/zds448588952/article/details/99613648......
  • 多线程——Robyn编程学习(Java)
    多线程的作用能够创建多个线程,此外线程可以体现程序的动态性,提高效率,在抢票以及各种游戏之中具有非常重要的作用。(线程的魅力在坦克大战中体现的淋漓尽致)多线程的知识体......
  • C#中的前台线程和后台线程
    转载于:c#前台线程与后台线程的区别和联系-田志良-博客园(cnblogs.com)Net的公用语言运行时(CommonLanguageRuntime,CLR)能区分两种不同类型的线程:前台线程和后台线程......
  • 多线程批量删除后再查询所遇到的坑
    问题:以前对于多线程异步执行没有细想,认为已经采用的countdownlatch,保证了任务全部执行完毕。实际上,并不是我认为的那样。首先,一个方法是多线程异步批量删除数据,另一个方......