Java多线程 同步代码块 synchronized
问题:synchronized锁住的是代码还是对象?
代码如下:
public class Demo012 {
public static void main(String[] args) {
Thread t1 = new Thread(){
@Override
public void run() {
for(int i=1;i<=100;i++){
new Print().print1();
}
}
};
Thread t2 = new Thread(){
@Override
public void run() {
for(int i=1;i<=100;i++){
new Print().print2();
}
}
};
t1.start();
t2.start();
}
}
class Print{
Object mutex = new Object();
public void print1(){
synchronized (mutex) {
System.out.print("黑");
System.out.print("马");
System.out.print("程");
System.out.print("序");
System.out.print("员");
System.out.print("\r\n");
}
}
public void print2(){
synchronized (mutex) {
System.out.print("传");
System.out.print("智");
System.out.print("播");
System.out.print("客");
System.out.print("\r\n");
}
}
}
执行之后结果如下:synchronized失效
原因:synchronized锁住的是括号里的对象,而不是代码,只能防止多个线程同时执行同一个对象的这个代码段。
上述代码因为两个线程都是创建新的Print对象,所以导致synchronized失效
解决方式1:可以让多线程访问的是同一个Print对象
public static void main(String[] args) {
Print print = new Print();
Thread t1 = new Thread(){
@Override
public void run() {
for(int i=1;i<=100;i++){
print.print1();
}
}
};
Thread t2 = new Thread(){
@Override
public void run() {
for(int i=1;i<=100;i++){
print.print2();
}
}
};
t1.start();
t2.start();
}
解决方式2:如果每一个线程都new一个Print对象,那么synchronized锁这个类对应的Class对象即可。
class Print{
public void print1(){
synchronized (Print.class) {
System.out.print("黑");
System.out.print("马");
System.out.print("程");
System.out.print("序");
System.out.print("员");
System.out.print("\r\n");
}
}
public void print2(){
synchronized (Print.class) {
System.out.print("传");
System.out.print("智");
System.out.print("播");
System.out.print("客");
System.out.print("\r\n");
}
}
}