栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

java-日常练习-多线程-统计两个线程消耗的时间

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

java-日常练习-多线程-统计两个线程消耗的时间

场景如下:
我想看下多线程一共消耗了多少时间,请看下这个例子 ,关键是这个类 CommonUtils 里的static 方法。

package a;
class CommonUtils{
    public static  long beginTime1;
    public static  long beginTime2;
    public static  long endTime1;
    public static  long endTime2;

}
class  Test {
    public  int a=0;

    synchronized public void test() throws InterruptedException {
        Thread.sleep(3000);
        a++;
        System.out.println(Thread.currentThread().getName()+"  a的值  "+a);
    }
    }

class RunA extends  Thread{
    Test a;
    public RunA(Test a){
        this.a=a;
    }
    @Override
    public void run() {
        CommonUtils.beginTime1=System.currentTimeMillis();
        super.run();
        try {
            a.test();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        CommonUtils.endTime1=System.currentTimeMillis();
    }
}
class RunB extends  Thread{
    Test a;
    public RunB(Test a){
        this.a=a;
    }
    @Override
    public void run() {
        super.run();
        CommonUtils.beginTime2=System.currentTimeMillis();
        try {
            a.test();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        CommonUtils.endTime2=System.currentTimeMillis();
    }
}
public class Sender extends Thread {

    public static void main(String[] args) throws InterruptedException {

    Test a= new Test();
    RunA A=new RunA(a);
    RunB B=new RunB(a);
    A.setName("A");
    A.start();
    B.setName("B");
    B.start();
    Thread.sleep(10000); //主线程等待下多线程运行完
    long begin=CommonUtils.beginTime1;
    if (begin>CommonUtils.beginTime2){
        begin=CommonUtils.beginTime2;
    }
    long end=CommonUtils.endTime1;
    if(end
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/332786.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号