public class TestThread {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
MyThread t1 = new MyThread();
new Thread(t1,"n1").start();
new Thread(t1,"n2").start();
}
}
class MyThread implements Runnable {
private int tickes =100;
@Override
public void run() {
// TODO Auto-generated method stub
while(tickes>0){
synchronized(this) {
//if(tickes>0) {
System.out.println(Thread.currentThread().getName() + " sell tickes " + tickes);
tickes--;
//}
}
}
}
}
以上代码是一个简单的模拟售票程序 ,但是我不明白为何运行时会出现买到第0张票的情况
请各位大侠解释下 万分感激!!
[b]问题补充:[/b]
但是在 synchronized(this) 后别的线程不是就应该无法访问this对象了吗
[b]问题补充:[/b]
哦 知道啦 是我理解错啦 我还以为只要已锁定 不管在哪都不能访问了 谢谢哦
我知道啊,
当有一种情况是,当tickes==1的时候,两个线程都执行到while(tickes>0),那也就是进入了while的循环,然后执行synchronized(this),那一定是有一个线程被阻塞了,但当一个线程执行完tickes--后释放锁(则tickes==0了),这边另外一个线程就能得到锁,这边tickes已经等于0了,自然就打印出0了
while(tickes>0){
//两个线程都执行到这个点了,
synchronized(this) { //你只是在这里进行了同步锁定
//if(tickes>0) {
System.out.println(Thread.currentThread().getName() + " sell tickes " + tickes);
tickes--;
//}
}
while(tickes>0){ //这个地方没有加锁定,但却要依赖tickes>0这个条件,所以自然就会出问题
synchronized(this) { //你只是在这里进行了同步锁定
//if(tickes>0) {
System.out.println(Thread.currentThread().getName() + " sell tickes " + tickes);
tickes--;
//}
}
你要锁定整个while才行的