专栏首页我是攻城师Java线程的基本知识总结

Java线程的基本知识总结

(一)创建线程的方式

(1)实现Runnable接口

(2)继承Thread类

推荐使用接口,能够做到定义与实现分离,耦合更低

(二)关于线程的优先级

thread2.setPriority(Thread.MAX_PRIORITY)

等级越高,优先运行

(三)关于线程的yield的方法

关于yield方法,是指当前线程可能运行不太重要的任务,可以通过这个方法暗示操作系统线程调度我可以晚点执行,先把CPU资源让给优先级给我一样或者大于我的任务,如果没有没有发现符合条件的线程,那么还会执行该线程的任务

(四)关于线程的join方法

在main方法中,启动一个线程A,如果执行了A.join()方法,那么主线程必须等待A线程执行完,才能执行join之后的代码。

(五)关于线程的sleep方法

让当前线程沉睡一定的周期

(六)关于线程的interrupt方法

用来告诉某个线程应该停止,如果这个线程当前正在执行wait,sleep,join方法时会抛出 InterruptedException ,如果正常状态下,我们可以通过isInterrupted()=true的时候,来停止线程使用return方法。

(七)关于线程的start和run方法

注意,要让线程运行,只能执行start方法,这个方法是native方法,run方法是我们定义任务的地方,单独的调用run方法,就和调用正常方法是一样的。start方法只能调用一次,超过一次则会抛出不合法状态异常。

(八)关于线程的状态

在Oracle的官网文档中,定义了线程有六种状态分别是:

(1)NEW,执行new Thread()后,还没启动的线程

(2)RUNNABLE ,执行完new后,又执行了start方法

(3)BLOCKED 等待获得一个锁的监视器,或者等待进入一个同步块或者方法

(4)WATTING 等待其他的线程执行一个特定的操作,没有任何时间限制

(5)TIMED_WAITING 等待其他的线程在一定的时间周期内

(6)TERMINATED 完成任务后的线程

这有一幅图,总结的比较全面大家可以看下:

(九)总结

本篇文章主要介绍了Java里面一些线程基本的方法和概念,最后又叙述了关于线程运行时的状态,尤其是线程调度这块依赖底层的操作系统,在不同的系统上运行可能得到不同的结果,这一点需要注意。

本文分享自微信公众号 - 我是攻城师(woshigcs)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2018-06-27

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 理解Java并发工具包线程池的设计

    创建线程的流程依赖底层的操作系统,不同的操作系统可能不一样,此外更多的线程意味着 OS调度需要做更多的工作来决定哪一个线程可以访问资源,并且要通过OS调度切换维...

    我是攻城师
  • 关于线程中的sleep,wait,yield的区别

    在Java的线程里面有几个比较常见的方法如sleep,wait,yield,但是你知道它们之间的区别吗?

    我是攻城师
  • 多线程协作打印ABC之ReentrantLock版本

    我们介绍了在Java里面使用synchronized + wait/notifyAll实现的多线程轮流打印特定的字符串,输出的结果如下:

    我是攻城师
  • 说说Netty的线程模型

    最近发现极客时间的很多课程中,都穿插到了 Netty,可见 Netty 的重要性。基于此,给大家推荐一下这篇文章!

    黄泽杰
  • 100道Java并发和多线程基础面试题大集合(含解答),这波面试稳了~

    这些多线程的问题来源于各大网站,可能有些问题网上有、可能有些问题对应的答案也有、也可能有些各位网友也都看过,但是本文写作的重心就是所有的问题都会按照自己的理解回...

    程序员白楠楠
  • 面试必考——线程池原理概述

    线程池的源码解析较为繁琐。各位同学必须先大体上理解线程池的核心原理后,方可进入线程池的源码分析过程。

    黑洞代码
  • 图文介绍进程和线程的区别

    先了解一下操作系统的一些相关概念,大部分操作系统(如Windows、Linux)的任务调度是采用时间片轮转的抢占式调度方式,也就是说一个任务执行一小段时间后强制...

    趣学程序-shaofeer
  • 笔记09 - 线程池刨根问底

    我们知道CPU运行的最小单位是线程,Java中实现并发是通过多线程来完成的,利用多线程提高了对CPU资源的利用率,但是线程的创建和销毁是很消耗性能的。线程的创建...

    码农帮派
  • Java多线程概念(一)

    1.等待阻塞(无限期等待):运行的线程执行wait()方法,该线程会释放占用的资源,JVM会把该线程放入等待池.进入这个状态后,线程不会自动唤醒,必须依靠其它线...

    入门小站
  • 线程间到底共享了哪些进程资源?

    进程和线程这两个话题是程序员绕不开的,操作系统提供的这两个抽象概念实在是太重要了。

    黄泽杰

扫码关注云+社区

领取腾讯云代金券