java多线程-竞态条件的形成模拟,锁的使用,volatile关键字的使用
2018-03-26 15:16
369 查看
很简单的一次尝试。
售票的机器类public class TicketSell implements Runnable{
private volatile int number = 10; //第四次尝试去掉了volatile
@Override
public void run() {
while (number > 0) {
sold();
}
}
public synchronized void sold(){ //只有第三次的时候加了synchronized
if (number > 0) {
System.out.println(Thread.currentThread().getName()+"sold "+number);
number--;
}
}
}售票主函数public class TicketMain {
public static void main(String[] args) {
TicketSell thread = new TicketSell();
TicketSell thread2 = new TicketSell();
Thread t1 = new Thread(thread);
Thread t2 = new Thread(thread);
t1.setName("t1");
t2.setName("t2");
t1.start();
t2.start();
}
}第一次:
使用thread和thread1对象 两个线程分别跑起来,把thread对象和thread1对象传进去,相当于两个机器分别卖各自的票,各自有10张票
运行结果:t2 sold 10
t2 sold 9
t1 sold 10
t2 sold 8
t1 sold 9
t2 sold 7
t1 sold 8
t2 sold 6
t1 sold 7
t2 sold 5
t1 sold 6
t1 sold 5
t1 sold 4
t1 sold 3
t1 sold 2
t1 sold 1
t2 sold 4
t2 sold 3
t2 sold 2
t2 sold 1
Process finished with exit code 0互相不受影响,按照10-1顺序减下来
第二次:
然后将thread都传进t1和t2,类似于一个售票机分身两个(这样好理解?)然后类似于同时工作
运行结果是这样的(可能还有很神奇的负数或者0出现,因为出现了竞态条件)t2 sold 10
t1 sold 10
t2 sold 9
t1 sold 8
t2 sold 7
t1 sold 6
t2 sold 5
t2 sold 3
t1 sold 4
t2 sold 2
t1 sold 1
Process finished with exit code 0第三次:
加上了synchronized之后,就实现了正常的效果t1 sold 10
t1 sold 9
t1 sold 8
t1 sold 7
t1 sold 6
t2 sold 5
t2 sold 4
t2 sold 3
t2 sold 2
t2 sold 1
Process finished with exit code 0第四次:
volatile作用:用于状态的存放,共享,确保变量的更新操作通知到其他线程。
前面几次都是在volatile变量使得可见性得到确保 然后不会出现这样的情况t2 sold 10
t1 sold 10
t2 sold 9
t2 sold 7
t2 sold 6
t2 sold 5
t2 sold 4
t2 sold 3
t2 sold 2
t2 sold 1
t1 sold 8
Process finished with exit code 0t1最后还在卖8号票 说明可见性出现了问题。
售票的机器类public class TicketSell implements Runnable{
private volatile int number = 10; //第四次尝试去掉了volatile
@Override
public void run() {
while (number > 0) {
sold();
}
}
public synchronized void sold(){ //只有第三次的时候加了synchronized
if (number > 0) {
System.out.println(Thread.currentThread().getName()+"sold "+number);
number--;
}
}
}售票主函数public class TicketMain {
public static void main(String[] args) {
TicketSell thread = new TicketSell();
TicketSell thread2 = new TicketSell();
Thread t1 = new Thread(thread);
Thread t2 = new Thread(thread);
t1.setName("t1");
t2.setName("t2");
t1.start();
t2.start();
}
}第一次:
使用thread和thread1对象 两个线程分别跑起来,把thread对象和thread1对象传进去,相当于两个机器分别卖各自的票,各自有10张票
运行结果:t2 sold 10
t2 sold 9
t1 sold 10
t2 sold 8
t1 sold 9
t2 sold 7
t1 sold 8
t2 sold 6
t1 sold 7
t2 sold 5
t1 sold 6
t1 sold 5
t1 sold 4
t1 sold 3
t1 sold 2
t1 sold 1
t2 sold 4
t2 sold 3
t2 sold 2
t2 sold 1
Process finished with exit code 0互相不受影响,按照10-1顺序减下来
第二次:
然后将thread都传进t1和t2,类似于一个售票机分身两个(这样好理解?)然后类似于同时工作
运行结果是这样的(可能还有很神奇的负数或者0出现,因为出现了竞态条件)t2 sold 10
t1 sold 10
t2 sold 9
t1 sold 8
t2 sold 7
t1 sold 6
t2 sold 5
t2 sold 3
t1 sold 4
t2 sold 2
t1 sold 1
Process finished with exit code 0第三次:
加上了synchronized之后,就实现了正常的效果t1 sold 10
t1 sold 9
t1 sold 8
t1 sold 7
t1 sold 6
t2 sold 5
t2 sold 4
t2 sold 3
t2 sold 2
t2 sold 1
Process finished with exit code 0第四次:
volatile作用:用于状态的存放,共享,确保变量的更新操作通知到其他线程。
前面几次都是在volatile变量使得可见性得到确保 然后不会出现这样的情况t2 sold 10
t1 sold 10
t2 sold 9
t2 sold 7
t2 sold 6
t2 sold 5
t2 sold 4
t2 sold 3
t2 sold 2
t2 sold 1
t1 sold 8
Process finished with exit code 0t1最后还在卖8号票 说明可见性出现了问题。
相关文章推荐
- 初学Java多线程:慎重使用volatile关键字
- [转]Java多线程:慎重使用volatile关键字
- 6. 初学Java多线程:慎重使用volatile关键字
- Java多线程:慎重使用volatile关键字
- Java中竞态条件和使用synchronized关键字同步
- java多线程关键字volatile的使用
- java多线程-慎重使用volatile关键字
- 六、初学Java多线程:慎重使用volatile关键字(看完感觉是不是就等于不用?)
- [转]Java多线程:慎重使用volatile关键字
- 高级java必会系列二:多线程经常使用的3个关键字:synchronized、ReentrantLock、volatile
- 初学Java多线程:慎重使用volatile关键字
- (转)初学Java多线程:使用Synchronized关键字同步类方法
- Java多线程的volatile关键字
- Java多线程(七)、Volatile 关键字
- java关键字volatile和synchronized在多线程中的应用
- 记录Java多线程的同步问题---synchronized关键字的使用
- (转)初学Java多线程:使用Synchronized关键字同步类方法
- Java中的transient、volatile、strictfp关键字使用
- 学习java多线程的笔记3-使用BlockingQueue阻塞队列来模拟两个线程之间的通信
- Java多线程初学者指南(6):慎重使用volatile关键字