设计模式之避免共享的设计模式Copy-on-Write模式

系列文章目录

设计模式之避免共享的设计模式Immutability(不变性)模式
设计模式之并发特定场景下的设计模式 Two-phase Termination(两阶段终止)模式


文章目录


一、Copy-on-Write是什么?

  • Java 里 String 在实现 replace() 方法的时候,并没有更改原字符串里面 value[] 数组的内容,而是创建了一个新字符串,这种方法在解决不可变对象的修改问题时经常到。它本质上是一种 Copy-on-Write方法。所谓 Copy-on-Write,经常被缩写为 COW 或者 CoW,顾名思义就是写时复制。
  • 不可变对象的写操作往往都是使用 Copy-on-Write 方法解决的,当然 Copy-on-Write 的应用领域并不局限于 Immutability 模式。
  • Copy-on-Write 才是最简单的并发解决方案,很多人都在无意中把它忽视了。它是如此简单,以至于 Java 中的基本数据类型String、Integer、Long 等都是基于 Copy-on-Write 方案实现的。
  • Copy-on-Write 缺点就是消耗内存,每次修改都需要复制一个新的对象出来,好在随着自动垃圾回收(GC)算法的成熟以及硬件的发展,这种内存消耗已经渐渐可以接受了。所以在实际工作中,如果写操作非常少(读多写少的场景),可以尝试使用 Copy-on-Write。

二、应用

  1. 配置信息:在配置信息读取频繁,而修改操作较少时,可以使用COW来管理配置信息。当需要修改配置时,创建配置的副本进行修改,然后替换原始配置,确保读取配置信息的线程不会受到修改操作的干扰。

  2. 缓存:在缓存对象上应用COW可以确保读操作始终访问到数据的一致性版本,而不受到写操作的影响。修改操作会在副本上进行,然后替换原始缓存对象。

  3. 数据快照:当需要对数据进行快照备份时,可以使用COW技术。在数据变化时,先复制原始数据,然后对副本进行写操作,以确保数据备份的一致性。

  4. 不变性对象:在并发编程中,不变性对象是一种常见的编程模式。不变性对象在创建后就不再修改,而是返回新的对象来代表修改后的状态。在这种场景下,COW可以用于处理返回新对象时的内部数据复制,确保并发访问的安全性。

相关推荐
邵伯几秒前
Java源码中的排序算法(一)--Arrays.sort()
java·排序算法
阿里巴巴P8高级架构师7 分钟前
从0到1:用 Spring Boot 4 + Java 21 打造一个智能AI面试官平台
java·后端
stevenzqzq9 分钟前
trace和Get thread dump的区别
java·android studio·断点
桦说编程10 分钟前
并发编程踩坑实录:这些原则,帮你少走80%的弯路
java·后端·性能优化
程序猿零零漆10 分钟前
Spring之旅 - 记录学习 Spring 框架的过程和经验(十三)SpringMVC快速入门、请求处理
java·学习·spring
BHXDML10 分钟前
JVM 深度理解 —— 程序的底层运行逻辑
java·开发语言·jvm
tkevinjd12 分钟前
net1(Java中的网络编程、TCP的三次握手与四次挥手)
java
码头整点薯条12 分钟前
基于Java实现的简易规则引擎(日常开发难点记录)
java·后端
Wang's Blog13 分钟前
Nodejs-HardCore: 深入解析DBF文件之二进制文件处理指南
开发语言·nodejs
hoiii18714 分钟前
基于LSB匹配的隐写术MATLAB实现程序
开发语言·matlab