Java设计三个线程的睡眠,分别每隔1秒,5秒,10秒运行一次

编写三个线程分别显示各自的运行时间,第一个线程每隔1秒钟运行一次,第二个线程每隔5秒钟运行一次,第三个线程每隔10秒钟运行一次。

源代码

线程类Sleep类

package experiment.exp8;
public class Sleep extends Thread{
	public int SleepTime=0;
	public long time=0;
	public int i=0;
	public int k=1;
	public Sleep(String s) {
		super(s);
	}
	public synchronized void run()
	{
		long start=System.currentTimeMillis();
		while(i==0)
		{
			System.out.println(Thread.currentThread().getName()+"正在运行第"+k+++"次");
			try
			{
				sleep(SleepTime);
			}
			catch(InterruptedException e)
			{
				e.getStackTrace();
			}
			long end=System.currentTimeMillis();
			time=time+end-start;
		}
	}
}

测试类Sleep_test类

package experiment.exp8;
import java.util.Scanner;
public class Sleep_test {

	public static void main(String[] args) {
		Scanner sc=new Scanner(System.in);
		Sleep s1=new Sleep("线程一");
		s1.SleepTime=1000;
		s1.start();
		s1.i=sc.nextInt();
		System.out.println("线程一结束运行,启动线程二");
		Sleep s2=new Sleep("线程二");
		s2.SleepTime=5000;
		s2.start();
		s2.i=sc.nextInt();
		System.out.println("线程二结束运行,启动线程三");
		Sleep s3=new Sleep("线程三");
		s3.SleepTime=10000;
		s3.start();
		s3.i=sc.nextInt();
		System.out.println("线程三结束运行");
		System.out.println("线程一运行时间:"+s1.time+"\n"+"线程二运行时间:"+s2.time+"\n"+"线程三运行时间:"+s3.time);
		sc.close();
	}

}

运行结果

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

玖语巴黎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值