多线程 -- sleep()方法和wait()方法区别 - Lai18.com IT技术文章收藏夹 http://www.lai18.com/content/1751290.html
Java 线程 sleep wait 深入解析 Thread - Lai18.com IT技术文章收藏夹 http://www.lai18.com/content/2439587.html
如何理解sleep持有锁,wait释放锁?
如果sleep出现在synchronize块中,sleep之后线程依然占有锁,其他线程不能访问synchronize块的代码或函数。
如果wait出现在synchoronize块中,wait之后线程释放锁,其他线程可以访问synchronize块的代码或函数
如下的程序执行结果如下:
窗口二---卖出20 time=1455509031298
窗口二---卖出19 time=1455509031299
窗口二---卖出18 time=1455509031315
窗口二---卖出17 time=1455509031332
窗口二---卖出16 time=1455509031348
窗口二---卖出15 time=1455509031349
窗口二---卖出14 time=1455509031350
窗口二---卖出13 time=1455509031351
窗口二---卖出12 time=1455509031352
窗口二---卖出11 time=1455509031353
窗口二---卖出10 time=1455509031354
窗口二---卖出9 time=1455509031355
窗口二---卖出8 time=1455509031356
窗口二---卖出7 time=1455509031357
窗口二---卖出6 time=1455509031358
窗口二---卖出5 time=1455509031359
窗口二---卖出4 time=1455509031360
窗口二---卖出3 time=1455509031361
窗口二---卖出2 time=1455509031362
窗口二---卖出1 time=1455509031363
窗口二---卖出0 time=1455509031364
窗口三---卖出0 time=1455509031365
窗口一---卖出0 time=1455509031366
窗口四---卖出0 time=1455509031367
package testSynchronized;
import java.nio.charset.MalformedInputException;
public class demo2 {
public static void main(String[] args) {
Ticket2 t = new Ticket2();
Thread t1 = new Thread(t, "窗口一");
Thread t2 = new Thread(t, "窗口二");
Thread t3 = new Thread(t, "窗口三");
Thread t4 = new Thread(t, "窗口四");
t1.start();
t2.start();
t3.start();
t4.start();
}
}
class Ticket2 implements Runnable {
private int ticket = 20;
public void run() {
synchronized (this) {
while (true) {
try {
Thread.sleep(1);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
if (ticket <= 0) {
System.out.println(Thread.currentThread().getName()
+ "---卖出" + ticket + " time="
+ System.currentTimeMillis());
break;
}
System.out.println(Thread.currentThread().getName() + "---卖出"
+ ticket-- + " time=" + System.currentTimeMillis());
}
}
}
}