网上看到很多对关键字synchronized继承性的描述只有一句"关键字synchronized不能被继承",并没有描述具体场景,于是自己做了以下测试。

//父类

public class Super {

static Logger logger = Logger.getLogger(Super.class);

// 同步方法
    @SuppressWarnings("static-access")
    public synchronized void testMothed() {
         try {
                Thread.currentThread().sleep(5000);//休眠5秒。
         } catch (InterruptedException e) {
                e.printStackTrace();
         }
          logger.info(Thread.currentThread().getName() + "," + this);
    }

}

//子类1

public class Sub1 extends Super {

// 不重写父类的同步方法
}

//子类2

public class Sub2 extends Super {

// 重写父类的同步方法,但不加synchronized。

@SuppressWarnings("static-access")
    public void testMothed() {
        try {
               Thread.currentThread().sleep(3000);//为区别与父类中休眠时间,改为3秒。
        } catch (InterruptedException e) {
                  e.printStackTrace();
        }
        logger.info(Thread.currentThread().getName() + "," + this);
    }
}

//测试类

public class SynchronizedTest {

static Logger logger = Logger.getLogger(SynchronizedTest.class);

public static void main(String[] args) throws Exception {
            // 子类对象1
            final Sub1 sub1 = new Sub1();
            final int count = 5;
            // 创建count个不同线程,调用子类对象1同一方法
            for (int i = 0; i < count; i++) {
                   new Thread() {
                           public void run() {
                                  sub1.testMothed();
                           }
                    }.start();
              }

// 让上面所有子线程有足够时间执行结束
             TimeUnit.SECONDS.sleep((count+1)*5);

logger.info("===============================================");

// 子类对象2
             final Sub2 sub2 = new Sub2();
             // 创建count个不同线程,调用子类对象2同一方法
             for (int i = 0; i < count; i++) {
                     new Thread() {
                          public void run() {
                               sub2.testMothed();
                         }
                     }.start();
              }
    }
   
}

执行结果:

12:40:18,043 [INFO]----> Thread-0,java_lang.thread_synchronized.Sub1@86f241
 12:40:23,044 [INFO]----> Thread-4,java_lang.thread_synchronized.Sub1@86f241
 12:40:28,044 [INFO]----> Thread-3,java_lang.thread_synchronized.Sub1@86f241
 12:40:33,044 [INFO]----> Thread-2,java_lang.thread_synchronized.Sub1@86f241
 12:40:38,045 [INFO]----> Thread-1,java_lang.thread_synchronized.Sub1@86f241
 12:40:43,044 [INFO]----> ===============================================
 12:40:46,045 [INFO]----> Thread-6,java_lang.thread_synchronized.Sub2@15dfd77
 12:40:46,045 [INFO]----> Thread-7,java_lang.thread_synchronized.Sub2@15dfd77
 12:40:46,045 [INFO]----> Thread-5,java_lang.thread_synchronized.Sub2@15dfd77
 12:40:46,046 [INFO]----> Thread-8,java_lang.thread_synchronized.Sub2@15dfd77
 12:40:46,046 [INFO]----> Thread-9,java_lang.thread_synchronized.Sub2@15dfd77

从上面可以看出,

不同线程对子类Sub1的同一对象sub1,调用testMothed,有同步效果,分别进入该方法,分别等待5秒。(红色与红色时间差)

不同线程对子类Sub2的同一对象sub2,调用testMothed,没有同步效果,所有线程同时进入该方法并同时等待3秒(蓝色到绿色时间差),然后同时执行(绿色时间一样)。

因此,对"关键字synchronized不能被继承",完整描述应该是:

1、子类继承父类时,如果没有重写父类中的同步方法,子类同一对象,在不同线程并发调用该方法时,具有同步效果。

2、子类继承父类,并且重写父类中的同步方法,但没有添加关键字synchronized,子类同一对象,在不同线程并发调用该方法时,不再具有同步效果,这种情形即是"关键字synchronized不能被继承"的转述。(貌似很多人在这一点上存在疑惑)。

最新文章

  1. UGUI全面实践教程
  2. ecshop后台新功能及权限的添加
  3. mysql源码解读之事务提交过程(一)
  4. GTID复制之二
  5. HDU 1568 double 快速幂
  6. oracle 的安装脚本
  7. Sublime text 3 中文文件名显示方框怎么解决?
  8. 4.1.1 A - Calendar(简单线性表)(日期查找)(数组应用)
  9. NavigationBar的简单设置
  10. A Statistical View of Deep Learning (IV): Recurrent Nets and Dynamical Systems
  11. 杂题 SPOJ MOBILE2 - Mobiles
  12. 基于visual Studio2013解决C语言竞赛题之1009补数
  13. 如何打开USB OTG功能:
  14. Python笔记(十七):生成器
  15. CocosCreator引擎修改与定制
  16. winserver2012 自启动软件
  17. opencv学习之路(14)、形态学之膨胀腐蚀
  18. ELASTIC制图等高级使用
  19. 依赖注入(DI)在PHP中的实现
  20. Broadcast总结 service

热门文章

  1. Linux_centos安装后无法进入图形界面
  2. python-django框架-电商项目-商品模块开发_20191124
  3. 为Nginx启用目录浏览功能
  4. Java中的Properties类
  5. LeetCode Day 1
  6. java实现银行管理系统
  7. java 字符串转日期格式
  8. 常见40个常用的js页面效果图
  9. &lt;USACO06FEB&gt;奶牛零食Treats for the Cowsの思路
  10. python返回值进行unpack