首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Java线程--线程各状态如何进行切换

首先要说的是线程状态,了解了线程状态以及状态切换的过程基本上就了解了多线程线程的状态 1、新建状态(New):新创建了一个线程对象。...线程的优先级及设置 线程的优先级是为了在多线程环境中便于系统对线程的调度,优先级高的线程将优先执行。 一个线程的优先级设置遵从以下原则: 线程创建时,子继承父的优先级。...在java中每个对象都有一个锁,一旦这个线程获得了这个对象的锁,这里的锁还有具体分为锁定类实例、锁定类对象两种不同的锁,针对不同的锁会限制其他线程对资源的访问,其他线程则在这个线程没有释放这个对象锁之前去访问锁定的资源了...join()方法的必要性 在很多情况下,主线程生成并起动了子线程,如果子线程里要进行大量的耗时的运算,主线程往往将于子线程之前结束,但是如果主线程处理完其他的事务后,需要用到子线程的处理结果,也就是主线程需要等待子线程执行完成之后再结束...但是,实际中无法保证yield()达到让步目的,因为让步的线程还有可能被线程调度程序再次选中。 这样就基本把java中涉及到的多线程都归纳了。

1.5K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Java线程的6种状态及切换

    Java线程的状态分为6种。 初始(NEW):新创建了一个线程对象,但还没有调用start()方法。...运行(RUNNABLE):Java线程中将就绪(ready)和运行中(running)两种状态笼统的称为“运行”。线程对象创建后,其他线程(比如main线程)调用了该对象的start()方法。...当前线程时间片用完了,调用当前线程的yield()方法,当前线程进入就绪状态。锁池里的线程拿到对象锁后,进入就绪状态。 运行中状态 线程调度程序从可运行池中选择一个线程作为当前线程线程所处的状态。...在一个终止的线程上调用start()方法,会抛出java.lang.IllegalThreadStateException异常。...Java文档就简单的写了句:选择是任意性的(The choice is arbitrary and occurs at the discretion of the implementation)。

    1.3K30

    Java线程生命周期与状态切换

    刚好想重新研读一下JUC线程池的源码实现,在此之前先深入了解一下Java中的线程实现,包括线程的生命周期、状态切换以及线程的上下文切换等等。编写本文的时候,使用的JDK版本是11。...抢占式线程调度 每个线程由操作系统来分配执行时间,线程切换不由线程自身决定 实现相对复杂,操作系统需要控制线程同步和切换 不会出现一个线程阻塞导致系统崩溃的问题 Java线程最终会映射为系统内核原生线程...Java线程的状态切换 Java线程的状态可以从java.lang.Thread的内部枚举类java.lang.Thread$State得知: public enum State {...: 下面通过API注释和一些简单的代码例子分析一下Java线程的状态含义和状态切换。...小结 理解Java线程状态的切换和一些监控手段,更有利于日常开发多线程程序,对于生产环境出现问题,通过监控线程的栈信息能够快速定位到问题的根本原因(通常来说,目前比较主流的MVC应用都是通过一个线程处理一个单独的请求

    86010

    Java线程的上下文切换

    但是,在切换前会保存上一个任务的状态,以便下次切换回这个任务时,可以再加载这个任务的状态。所以任务从保存到再加载的过程就是一次上下文切换。 很明显上下文切换会影响多线程的执行速度。...Java的Atomic包使用CAS(compare and swap)算法来更新数据,而不需要加锁。  3、使用最少线程。...减少上下文切换的例子 下面我们看一个通过减少线上大量WAITING的线程,来减少上下文切换次数的例子:  使用jstack命令dump线程信息,看看pid为3117的进程里的线程都在做什么 sudo...-u admin /opt/java/bin/jstack 31177 > /home/java/dump17 统计所有线程分别处于什么状态,发现300多个线程处于WAITING(onobjectmonitor...这种切换称为“上下文切换”(“context switch”)。CPU会在一个上下文中执行一个线程,然后切换到另外一个上下文中执行另外一个线程。上下文切换并不廉价,是比较耗时的

    65610

    Rxjava 线程切换原理

    前言 rxjava 可以很方便的进行线程切换, 那么rxjava是如何进行线程切换的呢?阅读本文可以了解下rxjava 是如何进行线程切换的及线程切换的影响点。...WanRxjava ", "onComplete td ==" + Thread.currentThread().getName()); } }); 如上代码,实现了线程切换和观察者被观察者绑定的逻辑...调用Observer.OnSubscribe 方法是 不受线程调度影响的 b.subscribeOn 影响的是发送事件的线程 c.observerOn 影响的是观察者处理接受数据的线程,如果没有调用observeOn...则不会进行包装成 ObserveOnObserver,也就是说不会执行观察者的线程切换,和 发送者的线程一致 d.多次调用subscribeOn切换线程,每次都会new ObservableSubscribeOn...,触发事件发送时会往上调用,也就是第一次调用的subscribeOn传入的线程 会执行发送事件,后面的线程切换无效 e.Observer.OnSubscribe 只会执行一次,因为调用DisposableHelper.setOnce

    1.2K00

    java线程状态及线程状态机切换流程,如何查看JVM线程状态

    ---- java线程状态 ---- 线程的6大状态:NEW-新建、RUNNABLE-线程执行、BLOCKED-被阻塞、 WAITING-等待、TIMED_WAITING-计时等待、TERMINATED...我们可以从java源码java.lang.Thread.State中,可得知java线程的状态分类: NEW-新建 A thread that has not yet started is in this...新创建的线程,即java.lang.Thread构造函数被调用后,还没调用 java.lang.Thread#start方法。...线程在JVM中已被执行,即调用java.lang.Thread#start方法后。此时线程占用CPU资源等资源执行中或等待CPU资源等,即将被调度系统调度执行的状态。...线程状态机 ---- 来一张图总结一下 来源:https://www.uml-diagrams.org/java-thread-uml-state-machine-diagram-example.html

    61230

    透彻讲解,Java线程的6种状态及切换

    Java线程的状态分为6种。 1. 初始(NEW):新创建了一个线程对象,但还没有调用start()方法。 2....运行(RUNNABLE):Java线程中将就绪(ready)和运行中(running)两种状态笼统的称为“运行”。 线程对象创建后,其他线程(比如main线程)调用了该对象的start()方法。...运行中状态 线程调度程序从可运行池中选择一个线程作为当前线程线程所处的状态。这也是线程进入运行状态的唯一一种方式。 3....在一个终止的线程上调用start()方法,会抛出java.lang.IllegalThreadStateException异常。...Java文档就简单的写了句:选择是任意性的(The choice is arbitrary and occurs at the discretion of the implementation)。

    86020

    Java线程的6种状态及切换(透彻讲解)

    Java线程的状态分为6种。 1. 初始(NEW):新创建了一个线程对象,但还没有调用start()方法。 2....运行(RUNNABLE):Java线程中将就绪(ready)和运行中(running)两种状态笼统的称为“运行”。 线程对象创建后,其他线程(比如main线程)调用了该对象的start()方法。...运行中状态 线程调度程序从可运行池中选择一个线程作为当前线程线程所处的状态。这也是线程进入运行状态的唯一一种方式。 3....在一个终止的线程上调用start()方法,会抛出java.lang.IllegalThreadStateException异常。...Java文档就简单的写了句:选择是任意性的(The choice is arbitrary and occurs at the discretion of the implementation)。

    1.1K10

    Java线程的6种状态及切换(透彻讲解)

    Java线程的状态分为6种。 1. 初始(NEW):新创建了一个线程对象,但还没有调用start()方法。 2....运行(RUNNABLE):Java线程中将就绪(ready)和运行中(running)两种状态笼统的称为“运行”。 线程对象创建后,其他线程(比如main线程)调用了该对象的start()方法。...运行中状态 线程调度程序从可运行池中选择一个线程作为当前线程线程所处的状态。这也是线程进入运行状态的唯一一种方式。 3....在一个终止的线程上调用start()方法,会抛出java.lang.IllegalThreadStateException异常。...Java文档就简单的写了句:选择是任意性的(The choice is arbitrary and occurs at the discretion of the implementation)。

    1.1K00

    【EventBus】事件通信框架 ( 发送事件 | 判断发布线程是否是主线程 | 子线程切换线程 | 主线程切换线程 )

    , 则需要判定发布线程是否是主线程 ; 如果发布线程是主线程 , 则切换到子线程执行订阅方法 ; 如果发布线程不是主线程 , 则直接执行订阅方法 ; 可参考 【Android 异步操作】Android...线程切换 ( 判定当前线程是否是主线程 | 子线程中执行主线程方法 | 主线程中执行子线程方法 ) 博客的部分操作 ; 一、根据不同的线程模式进行不同的线程切换操作 ---- 首先 , 获取当前线程是否是主线程...】Android 线程切换 ( 判定当前线程是否是主线程 | 子线程中执行主线程方法 | 主线程中执行子线程方法 ) 二、子线程中执行主线程方法 博客章节 ; case MAIN...; import java.lang.reflect.Method; import java.lang.reflect.Modifier; import java.util.ArrayList; import...java.util.HashMap; import java.util.List; import java.util.Map; import java.util.concurrent.CopyOnWriteArrayList

    61510

    RxJava源码浅析(四): observeOn线程切换和多次切换

    上篇文章RxJava源码浅析(三): subscribeOn线程切换和多次切换 我们清楚了subscribeOn线程切换,对于Rxjava线程切换原理有了大致的理解。...subscribeOn线程切换,是整个订阅流程线程切换,而observeOn只是针对下游线程切换。 这篇我们来看下observeOn切换线程以及他多次切换的影响。...接着调用source.subscribe(newObserveOnObserver(observer, w, delayError, bufferSize));这句话我们读出信息:订阅流程的上游没有切换线程...,下游ObserveOnObserver切换线程。...总结下,observeOn就是把下游切换线程,相比subscribeOn好理解些。 二、多次observeOn 如果我们多次调用observeOn呢?是以哪个为准呢?

    1.1K10

    RxJava源码浅析(三): subscribeOn线程切换和多次切换

    一、subscribeOn 这篇不仅看下subscribeOn线程切换本身,我们还要研究下多次subscribeOn为啥只有第一次有效。...(顺便说下,如果切换其他线程,比如subscribeOn(Schedulers.io()),那他最终创建的是IoScheduler类,是不是很好记。)...主线程还是新线程?...上面执行了两次subscribeOn,第一次会把订阅放在新线程中,第二次会把订阅放在主线程中,最终订阅是在主线程中执行。...三、总结 对于OnSubscribe方法而言,不管subscribeOn怎么切换线程,他都不受影响,他是最先开始执行的且只执行一次,只针对最下游有效,对于订阅而言,线程切换只是改变当前observer的所属线程

    1.9K50

    再忆RxJava---线程切换

    重新看一下,一来作为回顾,二来也算是学习一下3.0 在了解线程切换前,先回顾一下简单的同步操作 1.同步 Observable.create(new ObservableOnSubscribe...,启动一个线程处理我们自己写的subscribe方法。...异步线程切换流程图.png 简单来说,就是把所有的操作从右到左包装成一对观察者与被观察者的关系,然后通过发射器使所有的操作连续执行 4 流程举例 4.1 下载并显示图片 创建CreateEmitter,...,subscribe方法在IoScheduler线程中,很明显,其实是有效的,确实切换了。...其实也很好理解,我们的操作在A线程中执行,而A在线程B中执行,请问,我们的操作在哪个线程中执行?肯定是A啊(说B其实也没错,但是从学术角度来讲不准确)。

    51210

    协程简单上手(线程切换

    调度程序也就是launch和async的函数主体会运行在哪个线程中。...比如launch(Dispatchers.IO){ //协程主体函数}Dispatchers.IO 指示此协程应在为 I/O 操作预留的线程上执行。那么当协程内部还需要切换线程的时候呢?...典型的场景比如开启协程获取数据需要进行不同的线程切换:这时候可以使用withContextwithContext(Dispatchers.IO) {            // IO线程运行       ...}当withContext运行完成之后会自动恢复调用withContext的线程中。...由于多线程下的测试是不可预测的,所以正式编码中出现的withContext切换线程应换成单线程的方式因为这样将会**使得结果可预测**,所以再项目中不能使用硬编码去设置调度器Dispatchers,应该使用注入的方式如果是测试注入

    48050

    线程上下文切换

    文章目录 前言 上下文切换 上下文切换会消耗资源吗? 如何减少上下文切换导致额外的开销 前言 曾经有一份丰厚的报酬摆在我面前,我没有珍惜。直到失去之后我才意识到,我可以会写线程上下文切换。...我们具体看一下切换过程: 1、挂起当前任务(线程/进程),将这个任务在 CPU 中的状态(上下文)存储于内存中的某处 2、恢复一个任务(线程/进程),在内存中检索下一个任务的上下文并将其在 CPU 的寄存器中恢复...在一万以下的循环次数时,串联的执行速度比并发的执行速度块。是因为线程上下文切换导致额外的开销。...在Linux系统下可以使用vmstat命令来查看上下文切换的次数(上一篇讲过这个) ---- 如何减少上下文切换导致额外的开销 减少上下文切换次数便可以提高多线程的运行效率。...2、CAS算法:Java提供了一套原子性操作的数据类型(java.util.concurrent.atomic包下),使用CAS算法来更新数据,不需要加锁。

    82310

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券