zoukankan      html  css  js  c++  java
  • synchronized(this)与synchronized(class)

    synchronized(class)很特别,它会让另一个线程在任何需要获取class做为monitor的地方等待.class与this做为不同的监视器可以同时使用,不存在一个线程获取了class,另一个线程就不能获取该class的一切实例.

    根据下面的代码自行修改,分别验证下面的几种情况:

    synchronized(class)
    synchronized(this)
    ->线程各自获取monitor,不会有等待.
    synchronized(this)
    synchronized(this)
    ->如果不同线程监视同一个实例对象,就会等待,如果不同的实例,不会等待.
    synchronized(class)
    synchronized(class)
    ->如果不同线程监视同一个实例或者不同的实例对象,都会等待.

    package thread.sync;

    import java.util.concurrent.ExecutorService;
    import java.util.concurrent.Executors;

    public class RunnableTest implements Runnable {

    private static boolean flag = true;

    // private static synchronized void testSyncMethod() { // 注意static修改的同步方法,监视器=class
    // for (int i = 0; i < 100; i++) {
    // System.out.println("testSyncMethod:" + i);
    // }
    // }

    private void testSyncMethod() {
    synchronized (this) {
    for (int i = 0; i < 100; i++) {
    System.out.println("testSyncMethod:" + i);
    }
    }
    }

    private void testSyncBlock() {

    synchronized (this) { // 注意this做为监视器.它与class分别是二个不同监视器.不会存在class被获取,this就要等的现象.这也是我以前关于监视器的一个误区.
    for (int i = 0; i < 100; i++) {
    System.out.println("testSyncBlock:" + i);
    }
    }

    // synchronized (RunnableTest.class) { // 显示使用获取class做为监视器.它与static synchronized method隐式获取class监视器一样.
    // for (int i = 0; i < 100; i++) {
    // System.out.println("testSyncBlock:" + i);
    // }
    // }
    }

    public void run() {

    // flag是static的变量.所以,不同的线程会执行不同的方法,只有这样才能看到不同的锁定效果.
    if (flag) {
    flag = false;
    testSyncMethod();
    } else {
    flag = true;
    testSyncBlock();
    }
    }

    public static void main(String[] args) {
    ExecutorService exec = Executors.newFixedThreadPool(2);
    RunnableTest rt = new RunnableTest();
    RunnableTest rt1 = new RunnableTest();
    exec.execute(rt);
    exec.execute(rt1);
    exec.shutdown();
    }
    }



    参考:http://wangym.iteye.com/blog/1265973

  • 相关阅读:
    word(2)--如何解决word中首行失效的问题?
    Google AK47 的设计者 阿米特 辛格(Amit Singhal)博士如何评价机器学习?
    技术人如何克服拖延症?
    解决WebService 中泛型接口不能序列化问题
    如何减少每次同步数据量
    C#开源系统大汇总
    log4.net
    C#自定义控件背景色透明的方法
    [p2p]UDP用打洞技术穿透NAT的原理与实现
    商品管理方案V2.0
  • 原文地址:https://www.cnblogs.com/highriver/p/2291965.html
Copyright © 2011-2022 走看看