线程状态:
线程方法:
一、停止线程
1、不推荐使用jdk提供的stop和destroy方法(已废弃)
2、推荐让线程自己停止下来
3、建议使用一个标志位进行终止变量,当flag = false时,则终止线程。
代码:
package com.nqboot.boot.thread.status;
/**
* 1、不推荐使用jdk提供的stop和destroy方法(已废弃)
* 2、推荐让线程自己停止下来
* 2、建议使用一个标志位进行终止变量,当flag = false时,则终止线程。
*/
public class TestStop implements Runnable {
// 设置一个点标志位
Boolean flag = true;
@Override
public void run() {
int i = 0;
while (flag) {
System.out.println("run Thread" + i++);
}
}
// 通过一个公开的方法设置标志位
private 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 Thread" + i);
// 当主线程跑到900时,调用stop()方法终止run线程
if (i == 900) {
testStop.stop();
System.out.println("线程该停止了");
}
}
}
}
结果:
二、线程休眠
sleep(time)指定当前线程阻塞的毫秒数
sleep存在异常InterruptedException
sleep时间达到后线程进入就绪状态
sleep可以模拟网略延时,倒计时等
没有个对象都有一个,sleep不会释放锁
样例:
package com.nqboot.boot.thread.status;
public class TestSleep implements Runnable {
private int ticketNum = 10;
// 实现run方法,模拟卖票系统卖票
@Override
public void run() {
while (true) {
if (ticketNum <= 0) {
break;
}
// 模拟延时
try {
Thread.sleep(200);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + "拿到了第" + ticketNum + "张票");
ticketNum--;
}
}
public static void main(String[] args) {
// 多个线程操作同一个对象
TestSleep ticket = new TestSleep();
new Thread(ticket, "小王").start();
new Thread(ticket, "小张").start();
new Thread(ticket, "小黄牛").start();
}
}
样例模拟倒计时:
package com.nqboot.boot.thread.status;
public class TestSleep2 {
public static void main(String[] args) {
TestSleep2 testSleep2 = new TestSleep2();
testSleep2.tenDown();
}
// 模拟倒计时
private void tenDown() {
int num = 10;
while (true) {
try {
Thread.sleep(1000);
System.out.println(num + "s");
num--;
if (num <=0) {
break;
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
或者:
public class TestSleep2 {
public static void main(String[] args) {
Date startTime = new Date(System.currentTimeMillis());
try {
while (true) {
Thread.sleep(1000);
System.out.println(new SimpleDateFormat("HH:mm:ss").format(startTime));
startTime = new Date(System.currentTimeMillis());
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
三、线程礼让Yield
让当前正在执行的线程暂停,但不阻塞
将线程从运行状态转为就绪状态
让cpu重新调度,礼让不一定成功,看cpu心情。
package com.nqboot.boot.thread.status;
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 {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + "线程开始执行");
// 线程礼让,礼让不一定成功
Thread.yield();
System.out.println(Thread.currentThread().getName() + "线程执行结束");
}
}
输出:
G:\Java\jdk1.8.0_191\bin\java.exe "-javaagent:G:\Intellij_IDEA\IntelliJ IDEA Community Edition 2022.2.3\lib\idea_rt.jar=60069:G:\Intellij_IDEA\IntelliJ IDEA Community Edition 2022.2.3\bin" -Dfile.encoding=UTF-8 -classpath G:\java\jdk1.8.0_191\jre\lib\charsets.jar;G:\java\jdk1.8.0_191\jre\lib\deploy.jar;G:\java\jdk1.8.0_191\jre\lib\ext\access-bridge-64.jar;G:\java\jdk1.8.0_191\jre\lib\ext\cldrdata.jar;G:\java\jdk1.8.0_191\jre\lib\ext\dnsns.jar;G:\java\jdk1.8.0_191\jre\lib\ext\jaccess.jar;G:\java\jdk1.8.0_191\jre\lib\ext\jfxrt.jar;G:\java\jdk1.8.0_191\jre\lib\ext\localedata.jar;G:\java\jdk1.8.0_191\jre\lib\ext\nashorn.jar;G:\java\jdk1.8.0_191\jre\lib\ext\sunec.jar;G:\java\jdk1.8.0_191\jre\lib\ext\sunjce_provider.jar;G:\java\jdk1.8.0_191\jre\lib\ext\sunmscapi.jar;G:\java\jdk1.8.0_191\jre\lib\ext\sunpkcs11.jar;G:\java\jdk1.8.0_191\jre\lib\ext\zipfs.jar;G:\java\jdk1.8.0_191\jre\lib\javaws.jar;G:\java\jdk1.8.0_191\jre\lib\jce.jar;G:\java\jdk1.8.0_191\jre\lib\jfr.jar;G:\java\jdk1.8.0_191\jre\lib\jfxswt.jar;G:\java\jdk1.8.0_191\jre\lib\jsse.jar;G:\java\jdk1.8.0_191\jre\lib\management-agent.jar;G:\java\jdk1.8.0_191\jre\lib\plugin.jar;G:\java\jdk1.8.0_191\jre\lib\resources.jar;G:\java\jdk1.8.0_191\jre\lib\rt.jar;D:\JavaLearning\springBootStudy\boot\target\classes;D:\repository\org\springframework\boot\spring-boot-starter-web\2.7.12\spring-boot-starter-web-2.7.12.jar;D:\repository\org\springframework\boot\spring-boot-starter\2.7.12\spring-boot-starter-2.7.12.jar;D:\repository\org\springframework\boot\spring-boot\2.7.12\spring-boot-2.7.12.jar;D:\repository\org\springframework\boot\spring-boot-autoconfigure\2.7.12\spring-boot-autoconfigure-2.7.12.jar;D:\repository\org\springframework\boot\spring-boot-starter-logging\2.7.12\spring-boot-starter-logging-2.7.12.jar;D:\repository\ch\qos\logback\logback-classic\1.2.12\logback-classic-1.2.12.jar;D:\repository\ch\qos\logback\logback-core\1.2.12\logback-core-1.2.12.jar;D:\repository\org\apache\logging\log4j\log4j-to-slf4j\2.17.2\log4j-to-slf4j-2.17.2.jar;D:\repository\org\apache\logging\log4j\log4j-api\2.17.2\log4j-api-2.17.2.jar;D:\repository\org\slf4j\jul-to-slf4j\1.7.36\jul-to-slf4j-1.7.36.jar;D:\repository\jakarta\annotation\jakarta.annotation-api\1.3.5\jakarta.annotation-api-1.3.5.jar;D:\repository\org\yaml\snakeyaml\1.30\snakeyaml-1.30.jar;D:\repository\org\springframework\boot\spring-boot-starter-json\2.7.12\spring-boot-starter-json-2.7.12.jar;D:\repository\com\fasterxml\jackson\core\jackson-databind\2.13.5\jackson-databind-2.13.5.jar;D:\repository\com\fasterxml\jackson\core\jackson-annotations\2.13.5\jackson-annotations-2.13.5.jar;D:\repository\com\fasterxml\jackson\core\jackson-core\2.13.5\jackson-core-2.13.5.jar;D:\repository\com\fasterxml\jackson\datatype\jackson-datatype-jdk8\2.13.5\jackson-datatype-jdk8-2.13.5.jar;D:\repository\com\fasterxml\jackson\datatype\jackson-datatype-jsr310\2.13.5\jackson-datatype-jsr310-2.13.5.jar;D:\repository\com\fasterxml\jackson\module\jackson-module-parameter-names\2.13.5\jackson-module-parameter-names-2.13.5.jar;D:\repository\org\springframework\boot\spring-boot-starter-tomcat\2.7.12\spring-boot-starter-tomcat-2.7.12.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-core\9.0.75\tomcat-embed-core-9.0.75.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-el\9.0.75\tomcat-embed-el-9.0.75.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-websocket\9.0.75\tomcat-embed-websocket-9.0.75.jar;D:\repository\org\springframework\spring-web\5.3.27\spring-web-5.3.27.jar;D:\repository\org\springframework\spring-beans\5.3.27\spring-beans-5.3.27.jar;D:\repository\org\springframework\spring-webmvc\5.3.27\spring-webmvc-5.3.27.jar;D:\repository\org\springframework\spring-aop\5.3.27\spring-aop-5.3.27.jar;D:\repository\org\springframework\spring-context\5.3.27\spring-context-5.3.27.jar;D:\repository\org\springframework\spring-expression\5.3.27\spring-expression-5.3.27.jar;D:\repository\org\projectlombok\lombok\1.18.26\lombok-1.18.26.jar;D:\repository\org\slf4j\slf4j-api\1.7.36\slf4j-api-1.7.36.jar;D:\repository\org\springframework\spring-core\5.3.27\spring-core-5.3.27.jar;D:\repository\org\springframework\spring-jcl\5.3.27\spring-jcl-5.3.27.jar;D:\repository\org\testng\testng\6.14.3\testng-6.14.3.jar;D:\repository\com\beust\jcommander\1.72\jcommander-1.72.jar;D:\repository\org\apache-extras\beanshell\bsh\2.0b6\bsh-2.0b6.jar;D:\repository\commons-io\commons-io\2.8.0\commons-io-2.8.0.jar com.nqboot.boot.thread.status.TestYield
a线程开始执行
b线程开始执行
b线程执行结束
a线程执行结束
Process finished with exit code 0
四、线程强制执行Join
1)Join合并线程,待此线程执行完成后,再执行其他线程,其他线程阻塞
2)可以想象成插队
样例:
package com.nqboot.boot.thread.status;
public class TestJoin implements Runnable {
@Override
public void run() {
for (int i = 0; i < 1000; i++) {
System.out.println("vip线程来插队了" + i);
}
}
public static void main(String[] args) throws InterruptedException {
TestJoin testJoin = new TestJoin();
Thread vip = new Thread(testJoin);
vip.start();
for (int i = 0; i < 500; i++) {
if (i == 200) {
vip.join();
}
System.out.println("main" + i);
}
}
}
五、观测线程状态
package com.nqboot.boot.thread.status;
public class TestStatus {
public static void main(String[] args) throws InterruptedException {
StatusThread statusThread = new StatusThread();
Thread thread = new Thread(statusThread);
// 观察线程状态
Thread.State state = thread.getState();
System.out.println(state); // NEW
// 观察启动后
thread.start();
state = thread.getState();
System.out.println(state); //Run
while (state != Thread.State.TERMINATED) { // 只要线程不终止就一直输出线程状态
Thread.sleep(100);
state = thread.getState(); // 更新线程状态
System.out.println(state); // 输出状态
}
}
}
class StatusThread implements Runnable {
@Override
public void run() {
for (int i = 0; i < 5; i++) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
System.out.println("************");
}
}
输出:
G:\Java\jdk1.8.0_191\bin\java.exe "-javaagent:G:\Intellij_IDEA\IntelliJ IDEA Community Edition 2022.2.3\lib\idea_rt.jar=60781:G:\Intellij_IDEA\IntelliJ IDEA Community Edition 2022.2.3\bin" -Dfile.encoding=UTF-8 -classpath G:\java\jdk1.8.0_191\jre\lib\charsets.jar;G:\java\jdk1.8.0_191\jre\lib\deploy.jar;G:\java\jdk1.8.0_191\jre\lib\ext\access-bridge-64.jar;G:\java\jdk1.8.0_191\jre\lib\ext\cldrdata.jar;G:\java\jdk1.8.0_191\jre\lib\ext\dnsns.jar;G:\java\jdk1.8.0_191\jre\lib\ext\jaccess.jar;G:\java\jdk1.8.0_191\jre\lib\ext\jfxrt.jar;G:\java\jdk1.8.0_191\jre\lib\ext\localedata.jar;G:\java\jdk1.8.0_191\jre\lib\ext\nashorn.jar;G:\java\jdk1.8.0_191\jre\lib\ext\sunec.jar;G:\java\jdk1.8.0_191\jre\lib\ext\sunjce_provider.jar;G:\java\jdk1.8.0_191\jre\lib\ext\sunmscapi.jar;G:\java\jdk1.8.0_191\jre\lib\ext\sunpkcs11.jar;G:\java\jdk1.8.0_191\jre\lib\ext\zipfs.jar;G:\java\jdk1.8.0_191\jre\lib\javaws.jar;G:\java\jdk1.8.0_191\jre\lib\jce.jar;G:\java\jdk1.8.0_191\jre\lib\jfr.jar;G:\java\jdk1.8.0_191\jre\lib\jfxswt.jar;G:\java\jdk1.8.0_191\jre\lib\jsse.jar;G:\java\jdk1.8.0_191\jre\lib\management-agent.jar;G:\java\jdk1.8.0_191\jre\lib\plugin.jar;G:\java\jdk1.8.0_191\jre\lib\resources.jar;G:\java\jdk1.8.0_191\jre\lib\rt.jar;D:\JavaLearning\springBootStudy\boot\target\classes;D:\repository\org\springframework\boot\spring-boot-starter-web\2.7.12\spring-boot-starter-web-2.7.12.jar;D:\repository\org\springframework\boot\spring-boot-starter\2.7.12\spring-boot-starter-2.7.12.jar;D:\repository\org\springframework\boot\spring-boot\2.7.12\spring-boot-2.7.12.jar;D:\repository\org\springframework\boot\spring-boot-autoconfigure\2.7.12\spring-boot-autoconfigure-2.7.12.jar;D:\repository\org\springframework\boot\spring-boot-starter-logging\2.7.12\spring-boot-starter-logging-2.7.12.jar;D:\repository\ch\qos\logback\logback-classic\1.2.12\logback-classic-1.2.12.jar;D:\repository\ch\qos\logback\logback-core\1.2.12\logback-core-1.2.12.jar;D:\repository\org\apache\logging\log4j\log4j-to-slf4j\2.17.2\log4j-to-slf4j-2.17.2.jar;D:\repository\org\apache\logging\log4j\log4j-api\2.17.2\log4j-api-2.17.2.jar;D:\repository\org\slf4j\jul-to-slf4j\1.7.36\jul-to-slf4j-1.7.36.jar;D:\repository\jakarta\annotation\jakarta.annotation-api\1.3.5\jakarta.annotation-api-1.3.5.jar;D:\repository\org\yaml\snakeyaml\1.30\snakeyaml-1.30.jar;D:\repository\org\springframework\boot\spring-boot-starter-json\2.7.12\spring-boot-starter-json-2.7.12.jar;D:\repository\com\fasterxml\jackson\core\jackson-databind\2.13.5\jackson-databind-2.13.5.jar;D:\repository\com\fasterxml\jackson\core\jackson-annotations\2.13.5\jackson-annotations-2.13.5.jar;D:\repository\com\fasterxml\jackson\core\jackson-core\2.13.5\jackson-core-2.13.5.jar;D:\repository\com\fasterxml\jackson\datatype\jackson-datatype-jdk8\2.13.5\jackson-datatype-jdk8-2.13.5.jar;D:\repository\com\fasterxml\jackson\datatype\jackson-datatype-jsr310\2.13.5\jackson-datatype-jsr310-2.13.5.jar;D:\repository\com\fasterxml\jackson\module\jackson-module-parameter-names\2.13.5\jackson-module-parameter-names-2.13.5.jar;D:\repository\org\springframework\boot\spring-boot-starter-tomcat\2.7.12\spring-boot-starter-tomcat-2.7.12.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-core\9.0.75\tomcat-embed-core-9.0.75.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-el\9.0.75\tomcat-embed-el-9.0.75.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-websocket\9.0.75\tomcat-embed-websocket-9.0.75.jar;D:\repository\org\springframework\spring-web\5.3.27\spring-web-5.3.27.jar;D:\repository\org\springframework\spring-beans\5.3.27\spring-beans-5.3.27.jar;D:\repository\org\springframework\spring-webmvc\5.3.27\spring-webmvc-5.3.27.jar;D:\repository\org\springframework\spring-aop\5.3.27\spring-aop-5.3.27.jar;D:\repository\org\springframework\spring-context\5.3.27\spring-context-5.3.27.jar;D:\repository\org\springframework\spring-expression\5.3.27\spring-expression-5.3.27.jar;D:\repository\org\projectlombok\lombok\1.18.26\lombok-1.18.26.jar;D:\repository\org\slf4j\slf4j-api\1.7.36\slf4j-api-1.7.36.jar;D:\repository\org\springframework\spring-core\5.3.27\spring-core-5.3.27.jar;D:\repository\org\springframework\spring-jcl\5.3.27\spring-jcl-5.3.27.jar;D:\repository\org\testng\testng\6.14.3\testng-6.14.3.jar;D:\repository\com\beust\jcommander\1.72\jcommander-1.72.jar;D:\repository\org\apache-extras\beanshell\bsh\2.0b6\bsh-2.0b6.jar;D:\repository\commons-io\commons-io\2.8.0\commons-io-2.8.0.jar com.nqboot.boot.thread.status.TestStatus
NEW
RUNNABLE
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
TIMED_WAITING
RUNNABLE
************
TERMINATED
Process finished with exit code 0
六、线程优先级
注:
线程优先级低,只是意味着获得cpu调度的概率低,并不是优先级低,cpu就不会调用了。主要是看cpu的调度。
package com.nqboot.boot.thread.status;
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, "t1");
t1.setPriority(1);
t1.start();
Thread t2 = new Thread(myPriority, "t2");
t2.setPriority(2);
t2.start();
Thread t3 = new Thread(myPriority, "t3");
t3.setPriority(3);
t3.start();
Thread t4 = new Thread(myPriority, "t4");
t4.setPriority(6);
t4.start();
Thread t5 = new Thread(myPriority, "t5");
t5.setPriority(10);
t5.start();
}
}
class MyPriority implements Runnable {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + "优先级为:" + Thread.currentThread().getPriority());
}
}
输出:
G:\Java\jdk1.8.0_191\bin\java.exe "-javaagent:G:\Intellij_IDEA\IntelliJ IDEA Community Edition 2022.2.3\lib\idea_rt.jar=61100:G:\Intellij_IDEA\IntelliJ IDEA Community Edition 2022.2.3\bin" -Dfile.encoding=UTF-8 -classpath G:\java\jdk1.8.0_191\jre\lib\charsets.jar;G:\java\jdk1.8.0_191\jre\lib\deploy.jar;G:\java\jdk1.8.0_191\jre\lib\ext\access-bridge-64.jar;G:\java\jdk1.8.0_191\jre\lib\ext\cldrdata.jar;G:\java\jdk1.8.0_191\jre\lib\ext\dnsns.jar;G:\java\jdk1.8.0_191\jre\lib\ext\jaccess.jar;G:\java\jdk1.8.0_191\jre\lib\ext\jfxrt.jar;G:\java\jdk1.8.0_191\jre\lib\ext\localedata.jar;G:\java\jdk1.8.0_191\jre\lib\ext\nashorn.jar;G:\java\jdk1.8.0_191\jre\lib\ext\sunec.jar;G:\java\jdk1.8.0_191\jre\lib\ext\sunjce_provider.jar;G:\java\jdk1.8.0_191\jre\lib\ext\sunmscapi.jar;G:\java\jdk1.8.0_191\jre\lib\ext\sunpkcs11.jar;G:\java\jdk1.8.0_191\jre\lib\ext\zipfs.jar;G:\java\jdk1.8.0_191\jre\lib\javaws.jar;G:\java\jdk1.8.0_191\jre\lib\jce.jar;G:\java\jdk1.8.0_191\jre\lib\jfr.jar;G:\java\jdk1.8.0_191\jre\lib\jfxswt.jar;G:\java\jdk1.8.0_191\jre\lib\jsse.jar;G:\java\jdk1.8.0_191\jre\lib\management-agent.jar;G:\java\jdk1.8.0_191\jre\lib\plugin.jar;G:\java\jdk1.8.0_191\jre\lib\resources.jar;G:\java\jdk1.8.0_191\jre\lib\rt.jar;D:\JavaLearning\springBootStudy\boot\target\classes;D:\repository\org\springframework\boot\spring-boot-starter-web\2.7.12\spring-boot-starter-web-2.7.12.jar;D:\repository\org\springframework\boot\spring-boot-starter\2.7.12\spring-boot-starter-2.7.12.jar;D:\repository\org\springframework\boot\spring-boot\2.7.12\spring-boot-2.7.12.jar;D:\repository\org\springframework\boot\spring-boot-autoconfigure\2.7.12\spring-boot-autoconfigure-2.7.12.jar;D:\repository\org\springframework\boot\spring-boot-starter-logging\2.7.12\spring-boot-starter-logging-2.7.12.jar;D:\repository\ch\qos\logback\logback-classic\1.2.12\logback-classic-1.2.12.jar;D:\repository\ch\qos\logback\logback-core\1.2.12\logback-core-1.2.12.jar;D:\repository\org\apache\logging\log4j\log4j-to-slf4j\2.17.2\log4j-to-slf4j-2.17.2.jar;D:\repository\org\apache\logging\log4j\log4j-api\2.17.2\log4j-api-2.17.2.jar;D:\repository\org\slf4j\jul-to-slf4j\1.7.36\jul-to-slf4j-1.7.36.jar;D:\repository\jakarta\annotation\jakarta.annotation-api\1.3.5\jakarta.annotation-api-1.3.5.jar;D:\repository\org\yaml\snakeyaml\1.30\snakeyaml-1.30.jar;D:\repository\org\springframework\boot\spring-boot-starter-json\2.7.12\spring-boot-starter-json-2.7.12.jar;D:\repository\com\fasterxml\jackson\core\jackson-databind\2.13.5\jackson-databind-2.13.5.jar;D:\repository\com\fasterxml\jackson\core\jackson-annotations\2.13.5\jackson-annotations-2.13.5.jar;D:\repository\com\fasterxml\jackson\core\jackson-core\2.13.5\jackson-core-2.13.5.jar;D:\repository\com\fasterxml\jackson\datatype\jackson-datatype-jdk8\2.13.5\jackson-datatype-jdk8-2.13.5.jar;D:\repository\com\fasterxml\jackson\datatype\jackson-datatype-jsr310\2.13.5\jackson-datatype-jsr310-2.13.5.jar;D:\repository\com\fasterxml\jackson\module\jackson-module-parameter-names\2.13.5\jackson-module-parameter-names-2.13.5.jar;D:\repository\org\springframework\boot\spring-boot-starter-tomcat\2.7.12\spring-boot-starter-tomcat-2.7.12.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-core\9.0.75\tomcat-embed-core-9.0.75.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-el\9.0.75\tomcat-embed-el-9.0.75.jar;D:\repository\org\apache\tomcat\embed\tomcat-embed-websocket\9.0.75\tomcat-embed-websocket-9.0.75.jar;D:\repository\org\springframework\spring-web\5.3.27\spring-web-5.3.27.jar;D:\repository\org\springframework\spring-beans\5.3.27\spring-beans-5.3.27.jar;D:\repository\org\springframework\spring-webmvc\5.3.27\spring-webmvc-5.3.27.jar;D:\repository\org\springframework\spring-aop\5.3.27\spring-aop-5.3.27.jar;D:\repository\org\springframework\spring-context\5.3.27\spring-context-5.3.27.jar;D:\repository\org\springframework\spring-expression\5.3.27\spring-expression-5.3.27.jar;D:\repository\org\projectlombok\lombok\1.18.26\lombok-1.18.26.jar;D:\repository\org\slf4j\slf4j-api\1.7.36\slf4j-api-1.7.36.jar;D:\repository\org\springframework\spring-core\5.3.27\spring-core-5.3.27.jar;D:\repository\org\springframework\spring-jcl\5.3.27\spring-jcl-5.3.27.jar;D:\repository\org\testng\testng\6.14.3\testng-6.14.3.jar;D:\repository\com\beust\jcommander\1.72\jcommander-1.72.jar;D:\repository\org\apache-extras\beanshell\bsh\2.0b6\bsh-2.0b6.jar;D:\repository\commons-io\commons-io\2.8.0\commons-io-2.8.0.jar com.nqboot.boot.thread.status.TestPriority
main优先级为:5
t3优先级为:3
t5优先级为:10
t4优先级为:6
t1优先级为:1
t2优先级为:2
Process finished with exit code 0