锁优化的思路和方法

  • 减少锁持有时间
	public synchronized void syncMethod() {
		othercode1();
		mutextMethod();
		othercode2();
	}
	public void syncMethod() {
		othercode1();
              synchronized mutextMethod();
othercode2();}


  • 减小锁粒度

    将大对象,拆成小对象,大大增加并行度,降低锁竞争偏向锁,轻量级锁成功率提高
 ConcurrentHashMap

 HashMap的同步实现
Collections.synchronizedMap(Map<K,V> m)返回SynchronizedMap对象

public V get(Object key) {
		synchronized (mutex) {
			return m.get(key);
		}
	}

	public V put(K key, V value) {
		synchronized (mutex) {
			return m.put(key, value);
		}
	}

ConcurrentHashMap

若干个Segment :Segment<K,V>[] segments

Segment中维护HashEntry<K,V>

put操作时
先定位到Segment,锁定一个Segment,执行put

在减小锁粒度后, ConcurrentHashMap允许若干个线程同时进入



  • 锁分离

根据功能进行锁分离

ReadWriteLock
读多写少的情况,可以提高性能


读锁

写锁

读锁

可访问

不可访问

写锁

不可访问

不可访问


读写分离思想可以延伸,只要操作互不影响,锁就可以分离

LinkedBlockingQueue

队列

链表


A

  • 锁粗化


  • 锁消除

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值