面试被问java线程状态,一脸茫然?莫慌!看完这篇 从容应对!

2024-03-17 16:59

本文主要是介绍面试被问java线程状态,一脸茫然?莫慌!看完这篇 从容应对!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

面试被问java线程状态,一脸茫然?莫慌!看完这篇 从容应对!

  • Java的线程状态
    • 线程方法
    • 停止线程
    • 线程休眠
    • 线程礼让
    • 线程强制执行
    • 线程状态观测
    • 线程的优先级
    • 守护(deamon)线程

Java的线程状态

线程方法

方法说明
setPriority(int newPriority)更改线程的优先级
static void sleep(long millis)在指定的毫秒数内让当前正在执行的线程休眠
void join()等待该线程终止
static void yield()暂停当前正在执行的线程对象,并执行其他线程
void interrupt()中断线程,别用这个方式
boolean isAlive()测试线程是否处于活动状态

停止线程

  • 不推荐使用JDK提供的stop()、destroy()方法。【已废弃】
  • 推荐线程自己停下来
  • 建议使用一个标志位进行终止变量 当flag=false,则终止线程运行。
package com.cnblogs.thread;
/*
测试stop*/
public class TestStop implements Runnable{//设置标志位private boolean flag = true;@Overridepublic void run() {int i = 0;while(flag){System.out.println("run...." + i++);}}//设置一个公开的方法停止线程,转换标志位public void stop(){this.flag = false;}public static void main(String[] args) {TestStop testStop = new TestStop();new Thread(testStop).start();for (int i = 0; i < 1000; i++) {System.out.println("main" + i);if(i == 520){testStop.stop();System.out.println("该线程停止了");}}}
}

线程休眠

  • sleep(时间)指定当前线程阻塞的毫秒数
  • sleep存在异常InterruptedException;
  • sleep时间达到后线程进入就绪状态
  • sleep可以模拟网络延时,倒计时等。
  • 每个对象都有一个锁,sleep不会释放锁
package com.cnblogs.thread;import java.util.Date;/*
模拟倒计时*/
public class TestSleep {public static void tenDown() throws InterruptedException {int num = 10;while(true){Thread.sleep(1000);System.out.println(num--);if(num <= 0){break;}}}public static void main(String[] args) {Date startTime = new Date(System.currentTimeMillis());//获取系统时间try {tenDown();} catch (InterruptedException e) {e.printStackTrace();}}
}
package com.cnblogs.thread;import java.text.SimpleDateFormat;
import java.util.Date;/*
打印时间*/
public class TestSleep {public static void tenDown() throws InterruptedException {int num = 10;while(true){Thread.sleep(1000);System.out.println(num--);if(num <= 0){break;}}}public static void main(String[] args) {Date startTime = new Date(System.currentTimeMillis());//获取系统时间while(true){try {Thread.sleep(1000);System.out.println(new SimpleDateFormat("HH:mm:ss").format(startTime));startTime = new Date(System.currentTimeMillis());//更新当前时间} catch (InterruptedException e) {e.printStackTrace();}}}
}

线程礼让

  • 礼让线程,让当前正在执行的线程暂停,但不阻塞
  • 将线程从运行状态转为就绪状态
  • 注意:让cpu重写调度,礼让不一定成功!看CPU心情
package com.cnblogs.thread;
/*
测试礼让线程*/
public class TestYield {public static void main(String[] args) {MyYield myYield = new MyYield();new Thread(myYield,"a").start();new Thread(myYield,"b").start();}
}class MyYield implements Runnable{@Overridepublic void run() {System.out.println(Thread.currentThread().getName() + "线程开始执行");Thread.yield();//礼让System.out.println(Thread.currentThread().getName() + "线程结束执行");}
}
/*
礼让前效果:
a线程开始执行
a线程结束执行
b线程开始执行
b线程结束执行
礼让后结果:
a线程开始执行
b线程开始执行
a线程结束执行
b线程结束执行*/

线程强制执行

  • Join合并线程,待此线程执行完成后,再执行其他线程,其他线程阻塞
  • 可以想象成插队
package com.cnblogs.thread;public class TestJoin implements Runnable{@Overridepublic void run() {for (int i = 0; i < 50; i++) {System.out.println("VIP线程来了!!!" + i);}}public static void main(String[] args) throws InterruptedException {//启动线程TestJoin testJoin = new TestJoin();Thread thread = new Thread(testJoin);thread.start();for (int i = 0; i < 1000; i++) {if(i >= 200){thread.join();}System.out.println("main线程!!!" + i);}}
}

线程状态观测

Thread.State

线程可以处于以下状态之一:

  • New

    • 尚未启动的线程处于此状态
  • RUNNABLE

    • 在Java虚拟机中执行的线程处于此状态
  • BLOCKED

    • 被阻塞等待监视器锁定的线程处于此状态
  • WAITING

    • 正在等待另一个线程执行特定动作的线程处于此状态
  • TIMED_WAITING

    • 正在等待另一个线程执行动作达到指定等待时间的线程处于此状态
  • TERMINATED

    • 已退出的线程处于此状态

一个线程可以在给定时间点处于一个状态。这些状态是不反映任何操作系统线程状态的虚拟机状态。

package com.cnblogs.thread;public class TestState {public static void main(String[] args) throws InterruptedException {Thread thread = new Thread(()->{for (int i = 0; i < 5; i++) {try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}}System.out.println("0.0");});//观测状态Thread.State state = thread.getState();System.out.println(state);//NEW//观测启动后thread.start();state = thread.getState();System.out.println(state);//RUNNABLE//监听while (state != Thread.State.TERMINATED){Thread.sleep(100);state = thread.getState();System.out.println(state);//这段时间   TIMED_WAITING}//线程结束后 TERMINATED}
}

线程的优先级

  • Java提供一个线程调度器来监控程序中启动后进入就绪状态的所有线程,线程调度器按照优先级决定应该调度哪个线程来执行。

  • 线程的优先级用数字表示,范围从1~10

    • Thread.MIN_PRIORITY = 1;
    • Thread.MAX_PRIORITY = 10;
    • Thread.NORM_PRIORITY = 5;
  • 使用以下方式改变或获取优先级

    • getPriority.setPriority(int xxx);
package com.cnblogs.thread;public class TestPriority{public static void main(String[] args) {//主线程默认优先级System.out.println(Thread.currentThread().getName() + "-->" + Thread.currentThread().getPriority());MyPriority myPriority = new MyPriority();Thread t1 = new Thread(myPriority);Thread t2 = new Thread(myPriority);Thread t3 = new Thread(myPriority);Thread t4 = new Thread(myPriority);//默认为5t1.start();t2.setPriority(7);t2.start();t3.setPriority(Thread.MAX_PRIORITY);t3.start();t4.setPriority(Thread.MIN_PRIORITY);t4.start();/*main-->5Thread-2-->10Thread-1-->7Thread-0-->5Thread-3-->1*/}
}class MyPriority implements Runnable{@Overridepublic void run() {System.out.println(Thread.currentThread().getName() + "-->" + Thread.currentThread().getPriority());}
}

守护(deamon)线程

  • 线程分为用户线程和守护线程
  • 虚拟机必须确保用户线程执行完毕
  • 虚拟机不用等待守护线程执行完毕
  • 如,后台记录操作日志,监控内存,垃圾回收等
package com.cnblogs.thread;
/*
测试守护线程*/
public class TestDeamon {public static void main(String[] args) {God god = new God();You1 you1 = new You1();Thread thread = new Thread(god);thread.setDaemon(true);thread.start();//上帝线程启动new Thread(you1).start();}
}//上帝
class God implements Runnable{@Overridepublic void run() {while(true){System.out.println("上帝守护着你...");}}
}//你
class You1 implements Runnable{@Overridepublic void run() {for (int i = 0; i < 36500; i++) {System.out.println("你每天都开心的活着!!!");}System.out.println("再见了,世界");}
}

标签: [线程]
在这里插入图片描述

这篇关于面试被问java线程状态,一脸茫然?莫慌!看完这篇 从容应对!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/819572

相关文章

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直