线程作业

1、编写多线程程序,模拟多个人通过一个山洞。这个山洞每次只能通过一个人,每个人通过山洞的时间为2秒(sleep)。随机生成10个人,都要通过此山洞,用随机值对应的字符串表示人名,打印输出每次通过山洞的人名。提示:利用线程同步机制,过山洞用一条输出语句表示,该输出语句打印输出当前过山洞的人名,每个人过山洞对应一个线程,哪个线程执行这条输出语句,就表示哪个人过山洞
代码如下:
package baggage;

public class test {
    static Object clock=new Object();
    public static void main(String[] args) {
        Tunner tunner=new Tunner(clock);

        for(int i=0;i<10;i++){
            new Thread(tunner,""+Math.random()*100).start();
        }
        
    }
}
class Tunner implements Runnable{
    private Object clock;
    public Tunner(Object clock2) {
        this.clock=clock2;
        // TODO Auto-generated constructor stub
    }
    @Override
    public void run() {
        // TODO Auto-generated method stub
        synchronized (clock) {
            System.out.println(Thread.currentThread().getName()+"正在过山洞");
            try {
                Thread.sleep(10000);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName()+"过完了");
        }
    }

}
运行结果:
2、用两个线程玩猜数字游戏,第一个线程负责随机给出1~100之间的一个整数,第二个线程负责猜出这个数。要求每当第二个线程给出自己的猜测后,第一个线程都会提示“猜小了”、“猜大了”或“猜对了”。猜数之前,要求第二个线程要等待第一个线程设置好要猜测的数。第一个线程设置好猜测数之后,两个线程还要相互等待,其原则是:第二个线程给出自己的猜测后,等待第一个线程给出的提示;第一个线程给出提示后,等待给第二个线程给出猜测,如此进行,直到第二个线程给出正确的猜测后,两个线程进入死亡状态。

代码如下:
package baggage;
import java.util.Random;
public class test {  
  
    public static void main(String[] args) {  
        Num proNum=new Num();  
        Thread tPro =new Thread(proNum);      //设置正确数字线程  
        tPro.run();  
        try {  
            Thread.sleep(10);                  
            Num gueNum=new Num();  
            Thread tGue=new Thread(gueNum);       //猜数字线程  
              
            while(true) {  
                tGue.interrupt();  
                tGue.run();                   //每个循环调用一次猜数字线程生成一个随机数  
                Thread.sleep(10);             
                tPro.interrupt();          //唤醒第一个线程  
                if(gueNum.getNum()==proNum.getNum())  
                {  
                    System.out.println("猜测数字为:"+gueNum.getNum()+"猜对了");  
                    break;  
                }  
                else if(gueNum.getNum()<proNum.getNum())  
                    System.out.println("猜测数字为:"+gueNum.getNum()+"猜小了");  
                else  
                    System.out.println("猜测数字为:"+gueNum.getNum()+"猜大了");       
            }  
        } catch (InterruptedException e) {  
            e.printStackTrace();  
        }  
    }  
  
}  
class Num implements Runnable{  
  
    int num;  
    @Override  
    public synchronized void run() {  
        Random n=new Random();  
        num=n.nextInt(100);  
    }  
    public int getNum() {  
        return num;  
    }  
    public void setNum(int num) {  
        this.num = num;  
    }     
}  
运行结果:





  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值