模拟售票: 很多个售票点; 用的是同一份数据; 数据的一致性,也就是每个售票点理解为一个线程操作的话,这些售票点对票的数量应该是”共享”的;
代码展示:
package com.eth.ticket;
/**
- 模拟多线程售票
- @author Administrator
*/
public class TestTicket {
public static void main(String[] args) {
TreadTicket tt = new TreadTicket();
//第一个卖票点
new Thread(tt).start();
//第二个卖票点
new Thread(tt).start();
//第三个卖票点
new Thread(tt).start();
//第四个卖票点
new Thread(tt).start();
//第五个卖票点
new Thread(tt).start();
}
}
//TreadTicket 实现Runnable接口 多线程
class TreadTicket implements Runnable{
private int TicketCount = 100;
//synchronized 线程安全关键字
public synchronized void sale() {
if (TicketCount>0) {
System.out.println(Thread.currentThread().getName()+“正在卖第 “+TicketCount–+” 张票”);
}
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
@Override
public void run() {
while (TicketCount>0) {
//调用sale方法
sale();
}
}
}
结果显示:
synchronized 是Java中的关键字,是一种同步锁,它修饰的对象有以下几种:
1. 修饰一个代码块,被修饰的代码块称为同步语句块,其作用的范围是大括号{}括起来的代码,作用的对象是调用这个代码块的对象;
2. 修饰一个方法,被修饰的方法称为同步方法,其作用的范围是整个方法,作用的对象是调用这个方法的对象;
3. 修改一个静态的方法,其作用的范围是整个静态方法,作用的对象是这个类的所有对象;
4. 修改一个类,其作用的范围是synchronized后面括号括起来的部分,作用主的对象是这个类的所有对象。
如果刚才上面代码未加synchronized关键字,运行结果会重复售出同张票。