首页 > 编程语言 >Java并发(六)----线程start、run、state方法

Java并发(六)----线程start、run、state方法

时间:2023-05-15 19:46:56浏览次数:43  
标签:... run 19 t1 ---- start main

1、start 与 run

调用 run

public static void main(String[] args) {
    Thread t1 = new Thread("t1") {
        @Override
        public void run() {
            log.debug(Thread.currentThread().getName());// 打印线程名称
            FileReader.read(Constants.MP4_FULL_PATH);// 输出start 和 end  具体逻辑可忽略,只关注输出即可
        }
    };
​
    t1.run();
    log.debug("do other things ...");
}

输出

19:39:14 [main] c.TestStart - main
19:39:14 [main] c.FileReader - read [1.mp4] start ...
19:39:18 [main] c.FileReader - read [1.mp4] end ... cost: 4227 ms
19:39:18 [main] c.TestStart - do other things ...

程序仍在 main 线程运行,FileReader.read() 方法调用还是同步的

调用 start

将上述代码的 t1.run() 改为

t1.start();

输出

19:41:30 [main] c.TestStart - do other things ...
19:41:30 [t1] c.TestStart - t1
19:41:30 [t1] c.FileReader - read [1.mp4] start ...
19:41:35 [t1] c.FileReader - read [1.mp4] end ... cost: 4542 ms

程序在 t1 线程运行,FileReader.read() 方法调用是异步的

小结

  • 直接调用 run 是在主线程中执行了 run,没有启动新的线程

  • 使用 start 是启动新的线程,通过新的线程间接执行 run 中的代码

2、state

    public static void main(String[] args) {
        Thread t1 = new Thread("t1") {
            @Override
            public void run() {
                log.debug("running...");
            }
        };
​
        System.out.println(t1.getState());
        t1.start();
        System.out.println(t1.getState());
    }

输出

NEW
RUNNABLE
22:19:28.957 c.Test5 [t1] - running...

标签:...,run,19,t1,----,start,main
From: https://www.cnblogs.com/xiaoyh/p/17092278.html

相关文章

  • 每日打卡一小时(第二十五天)
    一.问题描述请使用模板参数设计实现双倍功能函数,函数功能要求实现返回值为输入参数的两倍,函数参数应能适应整型、浮点型、双精度型等各种类型,返回值类型与参数一样。二.设计思路注意函数模板参数的设计格式,按要求完成即可。三.代码实现#include<iostream>usingnamespace......
  • 5.15 2.8
    一、问题魔术师利用一副牌中的13张黑桃,预先将它们排好后迭在一起,并使牌面朝下。然后他对观众说:我不看牌,只要数数就可以猜到每张牌是什么,我大声数数,你们听,不信?你们就看,魔术师将最上面的那张牌数为1,把它翻过来正好是黑桃A,他将黑桃A放在桌子上,然后按顺序从上到下数手中的余牌......
  • LeetCode 周赛 345(2023/05/14)体验一题多解的算法之美
    本文已收录到AndroidFamily,技术和职场问题,请关注公众号[彭旭锐]提问。往期回顾:LeetCode双周赛第104场·流水的动态规划,铁打的结构化思考周赛概览T1.找出转圈游戏输家(Easy)标签:模拟、计数T2.相邻值的按位异或(Medium)标签:模拟、数学、构造T3.矩阵中移动的最......
  • 序列解包
    序列解包a={10:500,20:200,30:300,40:400,'委员会设立情况':'公司治理'}z,b,c,d,e=a#返回键print(z)print(e)f,j,h,i,g=a.values()#返回值print(f)print(g)k,l,m,n,o=a.items()#返回键值对print(k)print(o)10委员会设立......
  • 数组排序输出
    一.问题描述:对于输入的每一批数,按从小到大排序后输出。一行输入为一批数,第一个输入为数据类型(1表示整数,2表示字符型数,3表示有一位小数的浮点数,4表示字符串,0表示输入结束),第二个输入为该批数的数量size(0<size<=10),接下来为size个指定类型的数据。输出将从小到大顺序输出数据。#i......
  • 多项式全家桶
    跑的很慢。因为没有用什么看不懂的东西。刚刚写完比较基本的东西,持续更新。要是内存爆就把多点求值和快速插值干掉。示例代码为挑战多项式,2077ms。(多项式全家桶2077)#include<cstdio>#include<algorithm>#include<cstring>#include<cmath>#include<iostream>#includ......
  • hdu:六度分离(最短路)
    ProblemDescription1967年,美国著名的社会学家斯坦利·米尔格兰姆提出了一个名为“小世界现象(smallworldphenomenon)”的著名假说,大意是说,任何2个素不相识的人中间最多只隔着6个人,即只用6个人就可以将他们联系在一起,因此他的理论也被称为“六度分离”理论(sixdegreesofsepa......
  • 本人NAS中常用docker配置文件分享
    由于重装系统的时候,备份docker备份有误,现在所有的docker都得重新安装,想着在安装的时候顺便分享一下使用的镜像吧系统:Ubuntu23.04(GNU/Linux6.2.0-20-genericx86_64)配置:cpu:8700tes内存:16g*2固态:1t机械:4t+4t+12t+8tGPU:Teslap4机箱:T48......
  • 5.15
    #include<stdio.h>voidmain(){longmul,number,k,a,b;printf("Itexistsfollowingautomorphicnmberssmallthan100000:\n");for(number=0;number<100000;number++){for(mul=number,k=1;(mul/=10)>0;k*=10);a=k*10;mul=0;b=10;while(k>0){mul=......
  • Matlab中编程细节
    W频率轴的设置频率轴的设置的参考链接:fftshift详解-CSDN1.3.DFT的特性-CSDNfftshift讲解-信号处理小王子的文章-知乎VMatlab的fft函数掌握Matlab中IFFT/FFT注意事项及在OFDM仿真中的应用问题-CSDN数字信号处理1:完全掌握Matlab中的FFT-hal3515的文章-知乎......