归纳避免同步锁的几种方式

简介:

在并发编程中, 经常需要对共享数据(对象)添加同步锁, 但同步锁会导致程序性能下降。下面总结了一些避免同步锁的方法:

无状态

因为对象内部不维护状态,自然就没有并发修改问题。如果一个服务器程序不保存用户的状态,那么就可以很容易进行横向扩容。

使用不变对象

当对象状态发生改变时,重新生成对象。在javascript提供创建不可变对象的接口,但可以使用immutable.jsseamless-immutable创建不可变对象。

通过函数调用栈传递对象引用

对象都在堆空间分配,并可以被多个线程引用。如果对象引用只在函数调用栈之间传递,则只有当前线程能引用该对象

对集合进行分区

JDK的java.util.ConcurrentHashMap 就是使用这种思想来实现的。 详情见 . 此方法不能避免锁,但可以提高并发量

通过消息传递状态

对象之间通过消息交互,对象内部不保存状态。典型的例子:Actor模型。

使用单线程异步

单线程多任务:每个任务的执行不能被打断。 程序监听各种事件并提供相应的回调函数

典型例子:nodejs

相关文章
|
26天前
|
安全 Java 开发者
Lock锁和AQS之间的关系与区别:基于第一原理的深入分析
【11月更文挑战第26天】在Java并发编程中,锁(Lock)和队列同步器(AbstractQueuedSynchronizer,简称AQS)是两个核心概念。它们为多线程环境下的同步和互斥提供了强大的支持。本文将从第一原理出发,深入探讨Lock锁和AQS之间的关系与区别,同时分析它们的相关概念、业务场景、历史背景、功能点以及底层原理,并使用Java代码进行模拟实现。
22 1
|
5月前
|
安全 Java 数据处理
Java并发编程:线程同步与协作的深度解析
在探索Java并发编程的海洋中,线程同步与协作的灯塔指引着航向。本文将深入挖掘线程同步机制的核心原理,揭示锁、条件变量等工具如何确保数据的一致性和线程间有序的通信。通过案例分析,我们将解码高效并发模式背后的设计哲学,并探讨现代Java并发库如何简化复杂的同步任务。跟随文章的步伐,您将获得提升多线程应用性能与可靠性的关键技能。 【7月更文挑战第24天】
50 5
|
5月前
|
监控 Java API
Java并发编程之线程池深度解析
【7月更文挑战第14天】在Java并发编程领域,线程池是提升性能、管理资源的关键工具。本文将深入探讨线程池的核心概念、内部工作原理以及如何有效使用线程池来处理并发任务,旨在为读者提供一套完整的线程池使用和优化策略。
|
存储 安全 Java
Java并发编程学习4-线程封闭和安全发布
本篇介绍 对象的共享之线程封闭和安全发布
82 2
Java并发编程学习4-线程封闭和安全发布
|
6月前
|
Java API
详细探究Java多线程的线程状态变化
Java多线程的线程状态主要有六种:新建(NEW)、可运行(RUNNABLE)、阻塞(BLOCKED)、等待(WAITING)、超时等待(TIMED_WAITING)和终止(TERMINATED)。线程创建后处于NEW状态,调用start()后进入RUNNABLE状态,表示准备好运行。当线程获得CPU资源,开始执行run()方法时,它处于运行状态。线程可以因等待锁或调用sleep()等方法进入BLOCKED或等待状态。线程完成任务或发生异常后,会进入TERMINATED状态。
21251 5
|
6月前
|
Python
Python多线程中递归锁如何解决死锁问题的详细阐述
Python多线程中递归锁如何解决死锁问题的详细阐述
|
7月前
|
缓存 安全 Java
多线程--深入探究多线程的重点,难点以及常考点线程安全问题
多线程--深入探究多线程的重点,难点以及常考点线程安全问题
158 1
|
7月前
|
监控 安全 Java
Java并发编程学习5-对象的组合
本篇介绍一些线程安全的组合模式(包含实例封闭,Java监视器模式,线程安全性委托,客户端加锁机制)
77 1
Java并发编程学习5-对象的组合