专栏首页Java系列文章菜鸟的进阶之路:了解使用多线程

菜鸟的进阶之路:了解使用多线程

大菜鸟,什么是多线程?

多线程其实就是指一个程序运行时产生多个线程去执行。

大菜鸟

小菜鸟

哦哦,那多线程和多进程有什么区别吗?

关于多进程和多线程,教科书上最经典的一句话是“进程是资源分配的最小单位,线程是CPU调度的最小单位”,一般来说进程是独立的而同一进程中的线程是共享的,但是开一个进程的成本远高于线程。但是进程隔离度比较高,线程使用的成本比较低但是对我们的掌控度控制的比较高。线程相互印象出问题的几率也是很高的。然后线程和进程一样分为五个阶段:创建、就绪、运行、阻塞、终止。

大菜鸟

小菜鸟

那他们都各有什么优缺点。

这个的话我给你找了一张图,可以清晰的了解它们之间的优缺点

(源网络。侵删)

大菜鸟

小菜鸟

明白了。但是线程的话在Java中怎么去使用线程呢呢。

在Java中使用线程之前首先你要先了解线程的状态。

大菜鸟

上面就说到。线程和进程一样有五个状态分别是创建、就绪、运行、阻塞、终止。在Java中去实现的话有三种方法去实现,一种就是通过继承Thread类去实现。还有就是通过实现Runable接口,最后一种是实现Callable接口要和线程池配合使用。这个就教你了。这里是线程的状态图

(源网络。侵删)

大菜鸟

小菜鸟

那Thread和Runable有什么区别呢?

简单的来说如果一个类继承Thread,则不适合资源共享。但是如果实现了Runable接口的话,则很容易的实现资源共享。

大菜鸟

小菜鸟

那上面的状态都对应了什么操作?

1、新建状态(New):新创建了一个线程对象。2、就绪状态(Runnable):线程对象创建后,其他线程调用了该对象的start()方法。该状态的线程位于可运行线程池中,变得可运行,等待获取CPU的使用权。3、运行状态(Running):就绪状态的线程获取了CPU,执行程序代码。4、阻塞状态(Blocked):阻塞状态是线程因为某种原因放弃CPU使用权,暂时停止运行。直到线程进入就绪状态,才有机会转到运行状态。阻塞的情况分三种:(一)、等待阻塞:运行的线程执行wait()方法,JVM会把该线程放入等待池中。(wait会释放持有的锁)(二)、同步阻塞:运行的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则JVM会把该线程放入锁池中。(三)、其他阻塞:运行的线程执行sleep()或join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。当sleep()状态超时、join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入就绪状态。(注意,sleep是不会释放持有的锁)5、死亡状态(Dead):线程执行完了或者因异常退出了run()方法,该线程结束生命周期。

大菜鸟

小菜鸟

sleep和wait什么区别?

sleep是Thread类的方法,wait是Object类中定义的方法,sleep睡眠时保持锁,wait睡眠时释放锁。这也是面试官进场问的一个面试题

大菜鸟

小菜鸟

哦哦。都知道了。那我如何去使用呢。

Java中使用的话可以这样通过Thread实现

大菜鸟

运行结果。

大菜鸟

或者通过Runable实现接口。

大菜鸟

运行结果:

大菜鸟

小菜鸟

很简单呀,那我怎么让线程等待呢?

可以使用sleep。注意sleep需要传递等待时间是以毫秒为单位的

大菜鸟

小菜鸟

学到了。我去练习一下。

其实相对来说我给你介绍的很简单很简单。只是给你说一些概念和怎么去使用。更深入的有机会在给你讲解。多线程可不止这一点哦

大菜鸟

本文分享自微信公众号 - 乱敲代码(gh_baf1250e9b02),作者:乱敲代码

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

原始发表时间:2019-05-25

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

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 让人头大的各种锁,从这里让你思绪清晰

    说到了锁我们经常会联想到生活中的锁,在我们日常中我们经常会接触到锁。比如我们的手机锁,电脑锁,再比如我们生活中的门锁,这些都是锁。

    乱敲代码
  • Java 内存模型详解

    Java的内存模型(Java Memory Model )简称JMM。首先应该明白,Java内存模型是一个规范,主要规定了以下两点:

    乱敲代码
  • ThreadLocal可以解决并发问题吗

    到底什么是线程的不安全?为什么会存在线程的不安全?线程的不安全其实就是多个线程并发的去操作同一共享变量没用做同步所产生意料之外的结果。那是如何体现出来的呢?我们...

    乱敲代码
  • 菜鸟的进阶之路:了解使用多线程

    关于多进程和多线程,教科书上最经典的一句话是“进程是资源分配的最小单位,线程是CPU调度的最小单位”,一般来说进程是独立的而同一进程中的线程是共享的,但是开一个...

    码农小胖哥
  • [051]Binder线程优先级继承

    Binder通信需要两个线程,这两个线程的优先级是不同,也就意味着,他们能获取到的cpu的优先级不同。

    王小二
  • C# 基础知识系列- 12 任务和多线程

    照例一份前言,在介绍任务和多线程之前,先介绍一下异步和同步的概念。我们之间介绍的知识点都是在同步执行,所谓的同步就是一行代码一行代码的执行,就像是我们日常乘坐地...

    程序员小高
  • java多线程关键字volatile、lock、synchronized

    总结:volatile关键字的作用是:使变量在多个线程间可见(具有可见性),但是仅靠volatile是不能保证线程的安全性,volatile关键字不具备sync...

    刘文正
  • Java线程Thread的状态解析以及状态转换分析 多线程中篇(七)

    在Thread类中有内部类 枚举State,用于抽象描述Java线程的状态,共有6种不同的状态

    noteless
  • java基础题目总结

    有些基础题目由于工作中用的比较少但却又是不可少的,这样回答起来就会反应慢,不确定,不准确,特此开了文章记录遇到的不确定或者回答比较拗口的问题。 1.servle...

    Ryan-Miao
  • 基于Zmq的后台通信模型介绍

    Zmq是一个简单好用的传输组建,使得socket变成更加简洁、高效、高性能。本文主要介绍后台服务实现、多线程任务实现、线程无锁计数实现。

    airingzeng

扫码关注云+社区

领取腾讯云代金券