同步方法和同步代码块

public class Foo implements Runnable{ 
	private static byte[] lock = new byte[0]; 
	
	public void run() { 
		methodA(); 
	} 
	//同步方法
	public synchronized void methodA(){ 
		System.out.println(this); 
	} 
	//同步代码块
	public void methodB(){ 
		synchronized(this){ 
			System.out.println(this); 
		} 
	} 
	//同步代码块
	public void methodC(){ 
		synchronized(lock){ 
			System.out.println(lock); 
		} 
	} 

	public static void main(String[] args) {  
        	Foo f1=new  Foo();  
        	Foo f2=new  Foo();  
        	new Thread(f1).start();  
        	new Thread(f2).start();  
   	 } 
}

无论synchronized关键字加在方法上还是对象上,它取得的锁都是对象,而不是把一段代码或函数当作锁
methodA和methodB的效果是一样的。


methodA的synchronized锁定的是哪个对象呢?它锁定的是调用这个同步方法的对象。也就是说,当同一个对象f1在不同的线程中执行这个同步方法时,它们之间会形成互斥,达到同步的效果。
new Thread(f1).start();
new Thread(f1).start();


但是这个对象所属类的另一对象f2却可以任意调用这个被加了synchronized关键字的方法。
new Thread(f1).start();
new Thread(f2).start();
f1、f2 可以同时访问方法,这样达不到同步的效果


如果要保持即使不同对象也只能有一个线程来访问可以创建一个特殊的instance变量(它得是一个对象)来充当锁
用byte数组对象比Object lock = new Object()高效,注意这个得是static的,让不同对象竞争同一个byte数组对象的锁
像method3 这样,谁拿到这个锁谁就可以运行它所控制的那段代码




转载:http://blog.sina.com.cn/s/blog_4ae8f77f0101iifx.html


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值