提出问题:
* 子线程循环 10 次,接着主线程循环 100 次,接着又回到子线程循环 10 次,接着再回到主线程又循环 100 次。如此循环50次。
分析:这个实际上是非常easy的问题。即子线程run,主线程堵塞--->子线程堵塞,主线程run
可以使线程堵塞的方法有非常多,最常见的是sleep与wait。当然,须要控制的话,用wait/notify。
子线程与主线程共同操作一个Resource 对象。而Resource对象中由两个方法分别实现子线程与主线程的操作
对象
代码例如以下:
package treadgame; /** * 线程间的交流1 * 子线程循环 10 次,接着主线程循环 100 次。接着又回到子线程循环 10 次, * 接着再回到主线程又循环 100 次。如此循环50次 * @author lcx * */ public class ThreadExchange1 { public static void main(String[] args) { Resource res=new Resource(); new Thread(new Sub(res)).start(); for(int i=1;i<=50;i++) { res.runMain(); } } } class Resource { boolean isSub=true; public synchronized void runMain() { if(isSub) { try { wait(); } catch (InterruptedException e) { e.printStackTrace(); } } for(int i=1;i<=100;i++) System.out.println("主线程循环次数 "+i); isSub=!isSub; notify(); } public synchronized void runSub() { if(!isSub) { try { wait(); } catch (InterruptedException e) { e.printStackTrace(); } } for(int i=1;i<=10;i++) System.out.println("子线程循环次数 "+i); isSub=!isSub; notify(); } } class Sub implements Runnable { Resource res; public Sub(Resource res) { this.res=res; } public void run() { for(int i=1;i<=50;i++) { res.runSub(); } } }