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");
		}
	}
}

猜你喜欢

转载自blog.csdn.net/xldmx/article/details/88690917