Java多线程 6 静态同步方法的锁

对于静态同步方法,加在上面的锁就是其存在的类本身

package thread;

/*
如果同步函数被静态修饰后,使用的锁是什么呢?

通过验证,发现不在是this。因为静态方法中也不可以定义this。

静态进内存是,内存中没有本类对象,但是一定有该类对应的字节码文件对象。
类名.class  该对象的类型是Class

静态的同步方法,使用的锁是该方法所在类的字节码文件对象。 类名.class


对于单例模式,如果是使用懒汉模式(延迟加载)(饿汉模式是类加载的时候直接初始化对象),则其getInstance方法需要加锁:
public static  Single getInstance(){
	if(s==null){							//建立实例之后就不用再检查锁,提高效率
		synchronized(Single.class){			//同步锁使用该类
			if(s==null)
				s = new Single();
		}
	}
	return s;
}

*/

public class Thread_4_SynMethodDemo3 {
	
	public static void main(String[] args){
		Ticket4 t = new Ticket4();

		Thread t1 = new Thread(t);
		Thread t2 = new Thread(t);
		t1.start();
		try{Thread.sleep(10);}catch(Exception e){}
		t.flag = false;
		t2.start();
	}
}



class Ticket4 implements Runnable{
	private static  int tick = 100;
	Object obj = new Object();
	boolean flag = true;
	
	public  void run(){
		if(flag){
			while(true)	{
				synchronized(Ticket4.class)	{	//这样就喝静态同步方法一样了,用了同样的锁
				//synchronized(obj){			//这样会导致危险
					if(tick>0){
						try{Thread.sleep(10);}catch(Exception e){}
						System.out.println(Thread.currentThread().getName()+"....code : "+ tick--);
					}
				}
			}
		}
		else
			while(true)
				show();
	}
	public static synchronized void show(){
		if(tick>0){
			try{Thread.sleep(10);}catch(Exception e){}
			System.out.println(Thread.currentThread().getName()+"....show.... : "+ tick--);
		}
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值