linux cpu占用率如何看
336
2023-02-18
Java实现多线程模拟龟兔赛跑
java多线程模拟龟兔赛跑,供大家参考,具体内容如下
笔者利用Java多线程技术,将兔子和乌龟的跑步以两个线程的方式模拟出来,以达到一个初步的效果。
题目如下:路程总距离为35米
兔子:每秒跑5米,每跑10米,休息2秒;
乌龟:每秒跑3米,不休息。
所用工具
JDK1.8+IntelliJ IDEA 2020.1
代码
Race.java:(线程类,通过new出来的对象的不同线程名,然后分别模拟兔子和乌龟的跑步)
package task;
import org.omg.Messaging.SYNC_WITH_TRANSPORT;
public class Race extends Thread {
private int mile=35;//剩下的路程
public int getMile() {
return mile;
}
public void setMile(int mile) {
this.mile = mile;
}
public void run(){
long time1=System.currentTimeMillis();//记录开始跑的时间
if(getName().equals("兔子")){
while(mile>0) {
if ((int)(System.currentTimeMillis()-time1) % 2000 == 0 && (int)(System.currentTimeMillis()-time1) != 0) {//每跑10米即每过2秒休息2秒
try {
System.out.println("兔子正在休息2秒");
Thread.sleep(2000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
if((int)(System.currentTimeMillis()-time1)%1000==0&& (int)(System.currentTimeMillis()-time1) != 0) {
try {
Thread.sleep(1000);
mile -= 5;
System.out.println("兔子跑了"+(35-mile)+"米");//35-mile即为跑过的距离
}catch(InterruptedException e){
e.printStackTrace();
}
}
}
System.out.println("兔子到达终点");
}else if(getName().equals("乌龟")){
while(mile>0){
if((int)(System.currentTimeMillis()-time1)%1000==0&& (int)(System.currentTimeMillis()-time1) != 0) {
try {
Thread.sleep(1000);
fiGUVPi mile -= 3;
if(mile<0){
mile=0;
}
System.out.println("乌龟跑了"+(35-mile)+"米");//35-mile即为跑过的距离
}catch(InterruptedException e){
e.printStackTrace();
}
}
}
System.out.println("乌龟到达终点");
}else{
}
}
}
测试类demoo.java:(通过设置线程优先级来实现乌龟先跑,否则线程执行顺序不可控!!!)
package task;
public class demoo {
public static void main(String[] args) {
Thread rabbit=new Race();
rabbit.setName("兔子");
Thread turtle=new Race();
turhttp://tle.setName("乌龟");
turtle.setPriority(Thread.MAX_PRIORITY);
rabbit.setPriority(Thread.MIN_PRIORITY);
turtle.start();
rabbit.start();
}
}
测试结果:
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~