用两个线程玩猜数字游戏,第一个线程负责随机给出1~100之间的一个整数,第二个线程负责猜出这个数。要求每当第二个线程给出自己的猜测后,第一个线程都会提示“猜小了”、“猜大了”或“猜对了”。猜数之前,要求第二个线程要等待第一个线程设置好要猜测的数。第一个线程设置好猜测数之后,两个线程还要相互等待,其原则是:第二个线程给出自己的猜测后,等待第一个线程给出的提示;第一个线程给出提示后,等待给第二个线程给出猜测,如此进行,直到第二个线程给出正确的猜测后,两个线程进入死亡状态。
public class Guesstest{
public static void main(String[] args) {
Number number = new Number(); //创建实例对象number
number.giveNumberThread.start();//将两个进程都启动
number.guessNumberThread.start();
}
}
class Number implements Runnable {//实现了Runnable接口
int realNumber, guessNumber, min = 0, max = 100, message;
final int SMALLER = -1, LARGER = 1, SUCCESS = 8;
Thread giveNumberThread, guessNumberThread;
Number() {
giveNumberThread = new Thread(this);
guessNumberThread = new Thread(this);
}
@Override
public synchronized void run() {//重写run方法
// TODO Auto-generated method stub
for (int count = 1; true; count++) {
if (Thread.currentThread() == giveNumberThread) {//如果获取的线程是给出的数值则执行
if (count == 1) {
realNumber = (int) (Math.random() * 100) + 1; //获得一个随机数
System.out.println("随机给你一个数为" + realNumber + ",猜猜是多少");
} else {
if (realNumber > guessNumber) {
message = SMALLER;
System.out.println("你猜小了");
} else if (realNumber < guessNumber) {
message = LARGER;
System.out.println("你猜大了");
} else {
message = SUCCESS;
System.out.println("恭喜,你猜对了");
}
}
try {
notify(); //使用notify()方法唤醒该线程
wait();//Thread.sleep(1500);wait()方法时,会使该线程进入阻塞状态
} catch (Exception e) {
}
}
else if (Thread.currentThread() == guessNumberThread) {//如果获取的线程是猜的数值则执行
if (count == 1) {
guessNumber = (min + max) / 2;
System.out.println("我第" + count + "次猜这个数:" + guessNumber);
} else {
if (message == SMALLER) {//如果猜小了则,把猜的数赋给min,下次猜的数值为min,max和的中间值,如果猜大,就把猜的数值赋给max
min = guessNumber; //方法与min相同,一直循环到success
guessNumber = (min + max) / 2;
System.out.println("我第" + count + "次猜这个数是"
+ guessNumber);
} else if (message == LARGER) {
max = guessNumber;
guessNumber = (min + max) / 2;
System.out.println("我第" + count + "次猜这个数是"
+ guessNumber);
} else if (message == SUCCESS) {
System.out.println("我成功了");
System.exit(0);//return;
}
}
try {
notify();
wait();//Thread.sleep();
} catch (Exception e) {
}
}
}
}
}
运行结果: