Java開発練習8マルチスレッド

3620 ワード

マルチスレッドプログラムを作成し、複数の人が洞窟を通過することをシミュレートします.この洞窟は毎回一人しか通れず、一人一人が洞窟を通る時間は2秒(sleep).ランダムに10人を生成するには、この洞窟を通過し、ランダム値に対応する文字列で人名を表し、洞窟を通過するたびに人名を印刷出力します.ヒント:スレッド同期メカニズムを利用して、洞窟を通過するのは1本の出力文で表して、この出力文は現在の洞窟を通過する人の名前を印刷して出力して、すべての人は洞窟を通過して1つのスレッドに対応して、どのスレッドはこの出力文を実行して、どの人が洞窟を通過することを表します.
package org.gerrysu;

import java.util.Random;

public class shandong implements Runnable{
    private Object lock=new Object();    
    public void run(){    
        synchronized(lock){    
            System.out.println(Thread.currentThread().getName()+"  ");    
            try{    
                Thread.sleep(2000);    
            }catch(InterruptedException e){    
                e.printStackTrace();    
            }    
        }    
    }   

	public static void main(String[] args) {
		shandong sd = new shandong();

		for(int j=0;j<10;j++)
		{
		String rs;
		   String base = "abcdefghijklmnopqrstuvwxyz0123456789";     
		    Random random = new Random();     
		    StringBuffer sb = new StringBuffer();     
		    for (int i = 0; i < 5; i++) {     
		        int number = random.nextInt(base.length());     
		        sb.append(base.charAt(number));        //       
		    }     
		    rs = sb.toString();     
		 new Thread(sd,rs).start();
	}

	}	
}

   
  :
89zjj  
al59q  
1fz8v  
2d2pa  
rvq1q  
1f9n2  
sqwkv  
cgvcq  
7aerc  
ko56j  

     
2つのスレッドでデジタルゲームを当てて、最初のスレッドはランダムに与えることを担当します
1~100の間の整数で、2番目のスレッドはこの数を推測する責任を負います.2番目のスレッドが自分の推測を与えるたびに、1番目のスレッドは「小さく当てた」、「大きく当てた」、または「正しい」と提示するように要求されます.推測する前に、2番目のスレッドに1番目のスレッドが推測する数を設定するのを待つように要求します.第1のスレッドが推測数を設定した後、2つのスレッドは互いに待たなければならない.その原則は、第2のスレッドが自分の推測を与えた後、第1のスレッドが与えたヒントを待つことである.最初のスレッドがヒントを与えた後、2番目のスレッドに推測を与えるのを待って、2番目のスレッドが正しい推測を与えた後、2つのスレッドは死亡状態に入ります.
class Number implements Runnable {  
    int giveNumber,answerNumber,min = 1,max = 100;
    Thread   NumberThread,answerThread;
    Number() {  
    	 NumberThread = new Thread(this);  
    	 answerThread = new Thread(this);  
    }  
      
    public void run() {  
  
    for (int count = 1; true; count++) {  
    if (Thread.currentThread() == NumberThread) {  
    if (count == 1) {  
    	giveNumber = (int) (Math.random() * 100) + 1;  
    System.out.println("    "+giveNumber);  
    } else {  
    if (giveNumber > answerNumber) {  
    System.out.println("   ");  
    } else if (giveNumber < answerNumber) {  
   
    System.out.println("   ");  
    } else {  
   
    System.out.println("    ");  
    return;  
    }  
    }  
    try {  
    Thread.sleep(2000);  
    } catch (Exception e) {  
    }  
    }  
    if (Thread.currentThread() == answerThread) {  
    if (count == 1) {  
    	answerNumber = (min + max) / 2;  
    System.out.println("  " + count + "     :" + answerNumber);  
    } else {  
    if (giveNumber > answerNumber) {  
    min = answerNumber;  
    answerNumber = (min + max) / 2;  
    System.out.println("  " + count + "      "  
    + answerNumber);  
    } else if (giveNumber < answerNumber) {  
    max = answerNumber;  
    answerNumber = (min + max) / 2;  
    System.out.println("  " + count + "      "  
    + answerNumber);  
    }  
    try {  
    Thread.sleep(1500);  
    } catch (Exception e) {  
    			}  
    		}  
    	}  
    }
   }
}


public class Test {  
    public static void main(String[] args) {  
      Number number = new Number();  
      number.NumberThread.start();  
      number.answerThread.start();  
      }  
      }