博客
关于我
java多线程(5)——龟兔赛跑程序
阅读量:333 次
发布时间:2019-03-04

本文共 1238 字,大约阅读时间需要 4 分钟。

新创一个类

public class Race implements Runnable {    private static String winner;    @Override    public void run() {        for (int i = 1; i <= 100; i++) {            if (Thread.currentThread().getName().equals("兔子") && i % 10 == 0) {                try {                    Thread.sleep(10);                } catch (InterruptedException e) {                    e.printStackTrace();                }            }            if (gameOver(i)) {                break;            }            System.out.println(Thread.currentThread().getName()+"-->跑了"+i+"步");        }    }    private boolean gameOver(int steps) {        if (winner != null) {            return true;        }        if (steps >= 100) {            winner = Thread.currentThread().getName();            System.out.println("winner is "+winner);            return true;        }        return false;    }}

运行

public static void main(String[] args) {    Race race = new Race();    new Thread(race,"兔子").start();    new Thread(race,"乌龟").start();}

运行结果

通过代码实现了一个简单的赛跑逻辑,两个参与者分别是"兔子"和"乌龟"。在运行过程中,兔子每跑完10步会暂停10毫秒,而乌龟则一直保持稳定的速度。最终的胜利者将通过`gameOver`方法自动判定,当某个参与者完成全部步数或首先完成比赛时,游戏将结束。

在实际运行中,乌龟通常会比兔子先完成比赛,因为兔子需要定期暂停,增加了额外的时间消耗。通过这种方式,可以直观地观察到不同参与者的速度差异以及暂停策略对最终结果的影响。

转载地址:http://nieq.baihongyu.com/

你可能感兴趣的文章
Netty源码—5.Pipeline和Handler一
查看>>
Netty源码—6.ByteBuf原理二
查看>>
Netty源码—7.ByteBuf原理三
查看>>
Netty源码—7.ByteBuf原理四
查看>>
Netty源码—8.编解码原理二
查看>>
Netty源码解读
查看>>
Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
查看>>
Netty相关
查看>>
Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
查看>>
Network Sniffer and Connection Analyzer
查看>>
NetworkX系列教程(11)-graph和其他数据格式转换
查看>>
Networkx读取军械调查-ITN综合传输网络?/读取GML文件
查看>>
Net与Flex入门
查看>>
net包之IPConn
查看>>
NFinal学习笔记 02—NFinalBuild
查看>>
NFS共享文件系统搭建
查看>>
nfs复习
查看>>
NFS网络文件系统
查看>>
nft文件传输_利用remoting实现文件传输-.NET教程,远程及网络应用
查看>>
ng 指令的自定义、使用
查看>>