刚刚写了下Java的并发程序,在此做个笔记。对于线程a和b,在线程b中调用a.join(),那么此时线程b将会被挂起,直至线程a执行完才会有线程b执行的机会,若想打破这种机制,可以调用a.interrupt(),这时,线程b可以不必受刚才的约束。
import java.util.concurrent. * ; class Sleeper extends Thread { // private String name; private int duration; public Sleeper(String name, int duration){ super (name); this .duration = duration; start(); } public void run(){ try { System.out.println(getName() + " before sleep. " ); TimeUnit.MILLISECONDS.sleep(duration); System.out.println(getName() + " is asleep. " ); } catch (InterruptedException e){ System.out.println(getName() + " was interrupted. " + " isInterrupted(): " + isInterrupted()); return ; } System.out.println(getName() + " has awakened. " ); } } class Joiner extends Thread{ private Sleeper sleeper; public Joiner(String name, Sleeper sleeper){ super (name); this .sleeper = sleeper; start(); } public void run(){ try { System.out.println(getName() + " before join. " ); sleeper.join(); System.out.println(getName() + " after join. " ); } catch (InterruptedException e) { System.out.println(getName() + " was interrupted. " ); } System.out.println(getName() + " join completed. " ); } } public class ConcurrentBasic { public static void main(String args[]){ Sleeper sleepy = new Sleeper( " Sleepy " , 3000 ); Sleeper grumpy = new Sleeper( " Grumpy " , 3000 ); Joiner dopey = new Joiner( " Dopey " , sleepy); Joiner doc = new Joiner( " Doc " , grumpy); grumpy.interrupt(); } }
grumpy在这被打断了,那么和它join的doc将会被唤醒,从而导致doc线程的执行,这里可以把grumpy.interrupt()改为doc.interrupt(),运行情况与预想差不多。