sleep 是 Thread 的方法,wait 是 Object 的方法
sleep 是休眠,不会释放锁,wait 是挂起,会释放锁
wait 唤醒需要用 notify 或者 notifyAll;如果没有被唤醒,则会无止境的等待下去
而 sleep 则是休眠一段时间自己就恢复,继续执行下面代码;执行完synchronize中的代码块之后,才会释放锁
wait方法需要在synchronize块或者synchronize方法里调用,然而 sleep 不需要
notify:随机唤醒一个调用了wait方法的线程:只会随机选取一个处于等待池中的线程进入锁池去竞争获取锁的机会
notifyAll:唤醒了所有调用wait方法的线程:会让所有处于等待池的线程全部进入锁池去竞争获取锁的机会
=====
只有当调用notify 的线程自己执行完synchronize代码块之后,那些被唤醒后的线程才有机会继续竞争锁;
2、Join方法的使用join在线程里面意味着“插队”,哪个线程调用join代表哪个线程插队先执行——但是插谁的队是有讲究了,不是说你可以插到队头去做第一个吃螃蟹的人,而是插到在当前运行线程的前面,比如系统目前运行线程A,在线程A里面调用了线程B.join方法,则接下来线程B会抢先在线程A面前执行,等到线程B全部执行完后才继续执行线程A。
在JDK的解释中,join方法被解释成等待这个线程死亡,也就是等待这个线程全部执行完后才继续执行接下来的进程。
package duoxiancheng;
import java.util.Iterator;
public class ThreadCmj {
public static void main(String[] args) throws InterruptedException {
// TODO Auto-generated method stub
MyThread my1=new MyThread();
MyThread my2=new MyThread();
MyThread my3=new MyThread();
my1.setName("张飞");
my2.setName("关于");
my3.setName("3333");
my1.start();
my1.join();
my2.start();
my3.start();
}
}
从代码中可以看到。在这段代码中,有三个线程在执行,但是在代码中我们进行my1.join的调用,由此可以看出,他会先将my1的线程先执行完成之后,才会开始执行,my2与my3两个线程;这个就是join的用法,优先先执行my1,等到my1死亡后,才会开始后面的线程执行



