java中的synchronize(修饰类)

Synchronized还可作用于一个类,用法如下:

<span style="font-size:18px;">public class ClassName {
  public void method() {
     synchronized(ClassName.class) {
        // TODO
     }
   }
}</span>


具体的实例如下:

<span style="font-size:18px;">public class SyncThread implementsRunnable{
  private static int count;
 
  public SyncThread() {
     count = 0;
   }
 
   public static void method() {
     synchronized(SyncThread.class) {
        for (int i = 0; i < 5; i ++) {
           try {
              System.out.println(Thread.currentThread().getName() + ":" +(count++));
               Thread.sleep(1000);
           } catch (InterruptedException e) {
               e.printStackTrace();
           }
        }
     }
   }
 
  public void run() {
      method();
}
 
  public int getCount() {
     return count;
   }
 
         publicstatic void main(String[] args){
                   SyncThreadsyncThread1 = new SyncThread();
                   SyncThreadsyncThread2 = new SyncThread();
                   SyncThreadsyncThread3 = new SyncThread();
                   Threadthread1 = new Thread(syncThread1, "SyncThread1");
                   Threadthread2 = new Thread(syncThread2, "SyncThread2");
                   Threadthread3 = new Thread(syncThread3, "SyncThread3");
                   thread1.start();
                   thread2.start();
                   thread3.start();
         }
}</span>


运行结果:

        代码的差异不大,运行的结果是一样的,当synchronized修饰一个类的时候,是给这个类加锁,类的所有实例化出来的对象用的是同一把锁。

 

        再做一个实验,在以上的代码中添加一个方法method2,但是不使用synchronize进行修饰,代码如下:

<span style="font-size:18px;">public class SyncThread implementsRunnable{
  private static int count;
 
  public SyncThread() {
     count = 0;
   }
 
   public static void method() {
     synchronized(SyncThread.class) {
        for (int i = 0; i < 5; i ++) {
           try {
              System.out.println(Thread.currentThread().getName() + ":" +(count++));
               Thread.sleep(1000);
           } catch (InterruptedException e) {
               e.printStackTrace();
            }
        }
     }
   }
 public static void method2() {
   for (int i = 100; i < 105; i ++) {
        try {
            System.out.println(Thread.currentThread().getName() + ":" +(count++)+ "——" + "method2");
            Thread.sleep(1000);
         } catch (InterruptedException e) {
            e.printStackTrace();
         }
     } 
   }
 
  public void run() {
      method2();
    }
  public int getCount() {
     return count;
   }
 
         publicstatic void main(String[] args){
                   SyncThreadsyncThread1 = new SyncThread();
                   SyncThreadsyncThread2 = new SyncThread();
                   SyncThreadsyncThread3 = new SyncThread();
                   Threadthread1 = new Thread(syncThread1, "SyncThread1");
                   Threadthread2 = new Thread(syncThread2, "SyncThread2");
                   Threadthread3 = new Thread(syncThread3, "SyncThread3");
                   thread1.start();
                   thread2.start();
                   thread3.start();
         }
}</span>


运行结果如下:

        虽然这里的synchronize修饰的是一个类,但并不是对类的所有方法都统一的修饰了,只是修饰了某个方法,使得这个类的所有对象在使用这个被修饰的方法时保持同步。

 

总结:

         一、 无论synchronized关键字加在方法上还是对象上,如果被作用的是非静态的,则它取得的锁是对象;如果synchronized作用的是一个静态方法或一个类,则它取得的锁是对类,该类所有的对象同一把锁。 

         二、 谁拿到这个锁谁就可以运行它锁控制的那段代码,其他的必须等待。 

评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值