#同步机制解决线程安全问题
第一种方法:使用同步代码块
/再java中通过同步机制解决线程的安全问题
/*
方式一: 同步代码块
synchronized(同步监视器){
需要同步的代码
}
说明: 操作共享数据的代码,即为被同步的代码
共享数据: 多个线程的公用的数据 ticket是共享数据
同步监视器:俗称: 锁 任何一个类的对象都可以当锁
**多个线程必须公用同一把锁**
操作同步代码时只能由一个线程参与,相当于一个单线程过程,效率低
*/
class Window1 implements Runnable {
private int ticket = 100;
// Object obj = new Object();
@Override
public void run() {
while (true) {
//synchronized(this){//synchronized (obj) {
//用当前对象充当
//用类充当
synchronized(Window1.calss){
if (ticket > 0) {
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + ": 票号为 " + ticket);
ticket--;
} else {
break;
}
}
}
}
}
public class Test1 {
public static void main(String[] args) {
Window1 w1 = new Window1();
Thread t1 = new Thread(w1);
Thread t2 = new Thread(w1);
Thread t3 = new Thread(w1);
t1.setName("窗口一");
t2.setName("窗口二");
t3.setName("窗口三");
t1.start();
t2.start();
t3.start();
}
}
第二种方法
class Window1 implements Runnable {
private int ticket = 100;
@Override
public void run() {
while (true) {
show();
}
}
private synchronized void show(){ //非静态:默认同步监视器为this 若为static时候 则默认监视器为当前类本身 Window1.class
// synchronized (this){
if (ticket > 0) {
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + ": 票号为 " + ticket);
ticket--;
}
//}
}
}
public class Test1 {
public static void main(String[] args) {
Window1 w1 = new Window1();
Thread t1 = new Thread(w1);
Thread t2 = new Thread(w1);
Thread t3 = new Thread(w1);
t1.setName("窗口一");
t2.setName("窗口二");
t3.setName("窗口三");
t1.start();
t2.start();
t3.start();
}
}