关于同步的几个问题
来源:互联网 发布:怎么登录ebsco数据库 编辑:程序博客网 时间:2024/06/08 09:04
一、方步同步与同步块,如果方法与同步块的逻辑一样,效率是否一样?
public synchronized void sum(long j){ System.out.println(j); long sum=0; for(long i=0;i<100000000;i++){ sum=sum+i; } System.out.println(j+"===="+sum); } public void sum2(long j){ synchronized(this){ System.out.println(j); long sum=0; for(long i=0;i<100000000;i++){ sum=sum+i; } System.out.println(j+"===="+sum); } }使用的都是同一对象锁,效率不一样,测试发现方法同步要快,也就是同步块处理锁机制跟复杂些,同步块的优势在于精确控制锁的作用域,如能缩小锁范围,同步块具有优势,而且同步块扩展性更好,可以用锁分解,锁分段(ConcurrentHashMap实现机制)。
二、同步锁机制对每次new一个对象实例有效吗?
同步锁只对同一个对象锁有效,对不同的对象是不同的对象锁。
三、对象上不同方法上的同步,是否是同一锁?
是的,是同一对象锁,正因为是同一对象锁,也就保证对象属性的更新,修改,查询是原子操作,是串行的。
四、静态类的父类同步方法,静态子类间调用父类同步方法,是否是不同锁?
不是,都是使用的父类对象锁,也就是说静态类虽然不一样,但是如果都是调用父类方法,还是会存在竞争锁,导致线程等待。
如果是调用静态子类本身的同步方法,则使用的是各自静态子类的对象锁,不存在互相竞争锁。
父类:
public abstract class AbstractTest4 {public static synchronized void sum(String j){ System.out.println(j); long sum=0; for(long i=0;i<1000000000;i++){ sum=sum+i; } System.out.println(j+"===="+sum); } public static void sum2(Class j){ synchronized(j){ System.out.println(j); long sum=0; for(long i=0;i<1000000000;i++){ sum=sum+i; } System.out.println(j+"===="+sum); } } public static void main(String[] args) throws InterruptedException{ ExecutorService service1 = Executors.newFixedThreadPool(2*3); for(int j=0;j<100;j++){ service1.execute(new Runnable(){@Overridepublic void run() {//Test5.sum2(Test5.class);Test5.sum3(Thread.currentThread().getId());//Test5.sum("test5");} }); } ExecutorService service2 = Executors.newFixedThreadPool(2*3); for(int j=0;j<100;j++){ service2.execute(new Runnable(){@Overridepublic void run() {//Test6.sum2(Test6.class);Test6.sum3(Thread.currentThread().getId());//Test6.sum("test6");} }); } }}子类:
public class Test5 extends AbstractTest4{public static synchronized void sum3(long j){ System.out.println(j); long sum=0; for(long i=0;i<1000000000;i++){ sum=sum+i; } System.out.println(j+"test5===="+sum); }}
public class Test6 extends AbstractTest4{public static synchronized void sum3(long j){ System.out.println(j); long sum=0; for(long i=0;i<1000000000;i++){ sum=sum+i; } System.out.println(j+"test6===="+sum); }}
0 0
- 关于同步的几个问题
- java同步块的几个问题
- 关于《仙剑》的几个问题
- 关于CCheckListBox的几个问题!
- 关于网络的几个问题
- 关于分区的几个问题
- 关于人生目标的几个问题
- 关于进程的几个问题
- 关于Timer的几个问题
- 关于servlet的几个问题
- 关于Java的几个问题
- 关于OO的几个问题
- 关于VS的几个问题
- 关于jsp的几个问题
- 关于联合的几个问题
- 关于68013的几个问题
- 关于delphi7的几个问题
- 关于sizeof的几个问题
- android 返回值 实现 home键的效果
- 9.4 触摸和手势:事件的传递的机制
- 28 大数阶乘
- elasticsearch的基本用法
- CSU-ACM暑假集训基础组训练赛(1) B - Problem B
- 关于同步的几个问题
- ios中数字的格式化(金额千分位格式化显示)
- MFC学习笔记(2)—— 消息(1)
- 随记
- Difference between proxy server and reverse proxy server
- USACO maze1 BFS
- 使用UrlRewriteFilter如何在Tomcat crossContext的情况下上传文件
- inline hook内联汇编dll之屏蔽记事本粘贴功能
- iOS UIButton 設置