0

0

Java多线程下如何保证数据安全_常用解决方案汇总

P粉602998670

P粉602998670

发布时间:2026-01-23 13:04:03

|

282人浏览过

|

来源于php中文网

原创

i++不是原子操作,因其被拆分为读取、计算、写回三步,多线程下易发生竞态导致结果错误;volatile仅保可见性不保原子性;synchronized、AtomicInteger、ThreadLocal等是常用线程安全方案。

java多线程下如何保证数据安全_常用解决方案汇总

多线程读写共享变量时,i++ 为什么不是原子操作?

因为 i++ 实际拆成三步:读取 i 的值 → 计算 i + 1 → 写回新值。多个线程可能同时读到相同旧值,各自加 1 后写回,导致最终只加了一次。

常见现象是:10 个线程各执行 1000 次 i++,结果远小于 10000;或者日志中出现重复 ID、计数跳变、ConcurrentModificationException 等。

  • 不要依赖“看起来没出错”来判断线程安全——竞态条件(race condition)具有随机性和不可复现性
  • volatile 能保证可见性,但不能解决复合操作的原子性问题(如 i++list.add()
  • 局部变量天然线程安全;对象实例字段/静态字段才是风险点

synchronized 锁住临界区是最直接的控制方式

它通过 JVM 的 monitor 机制确保同一时刻只有一个线程能进入被保护的代码块或方法,适合逻辑清晰、争用不激烈的场景。

public class Counter {
    private int count = 0;
    public synchronized void increment() {
        count++; // 这里是原子的
    }
    public synchronized int getCount() {
        return count;
    }
}
  • 锁对象必须一致:方法级 synchronized 锁的是当前实例(this),静态方法锁的是类对象(Counter.class
  • 避免锁整个方法体——只包裹真正需要同步的语句,否则会严重拖慢吞吐量
  • 不要用 String 或常量池对象(如 "lock")作锁,容易被外部误用导致锁失效或死锁

java.util.concurrent 包里的工具类更适合高并发场景

当需要频繁读写、或对性能敏感时,ReentrantLockAtomicIntegerConcurrentHashMap 等比 synchronized 更灵活高效。

Magic AI Avatars
Magic AI Avatars

神奇的AI头像,获得200多个由AI制作的自定义头像。

下载

立即学习Java免费学习笔记(深入)”;

  • AtomicInteger 用 CAS(Compare-And-Swap)实现无锁原子更新,适用于简单计数:counter.incrementAndGet()
  • ReentrantLock 支持可中断、超时、公平锁等特性,但需手动 lock()/unlock(),忘记 unlock() 会导致死锁
  • ConcurrentHashMap 不是“线程安全的 HashMap”,而是分段锁 + CAS 的高性能实现,get() 完全无锁,put() 只锁对应桶
  • 避免把 ArrayListHashMap 包裹在 synchronized 块里使用——它们本身不提供迭代器一致性保障,仍可能抛 ConcurrentModificationException

ThreadLocal 是隔离数据而非共享数据的思路

它为每个线程提供独立副本,彻底规避竞争。典型用途是保存用户上下文、数据库连接、格式化器(如 SimpleDateFormat)等非线程安全对象。

private static final ThreadLocal<SimpleDateFormat> DATE_FORMAT =
    ThreadLocal.withInitial(() -> new SimpleDateFormat("yyyy-MM-dd"));
  • 每次调用 get() 都返回当前线程专属实例,无需同步
  • 务必在业务结束时调用 remove(),尤其在线程池场景下,否则会造成内存泄漏(ThreadLocalMap 中的 key 是弱引用,value 不是)
  • 不能用于传递参数或跨线程通信——子线程不会自动继承父线程的 ThreadLocal 值,需显式使用 InheritableThreadLocal
真正难处理的从来不是单个变量的增减,而是跨多个对象、多步骤事务的一致性。比如“扣库存 + 记日志 + 发消息”这三步,即使每步都加了锁,整体仍可能因异常或顺序问题出错。这时候得靠分布式锁、消息队列幂等、本地事务表这些更高层机制,而不是盯着 synchronized 补丁。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
什么是分布式
什么是分布式

分布式是一种计算和数据处理的方式,将计算任务或数据分散到多个计算机或节点中进行处理。本专题为大家提供分布式相关的文章、下载、课程内容,供大家免费下载体验。

407

2023.08.11

分布式和微服务的区别
分布式和微服务的区别

分布式和微服务的区别在定义和概念、设计思想、粒度和复杂性、服务边界和自治性、技术栈和部署方式等。本专题为大家提供分布式和微服务相关的文章、下载、课程内容,供大家免费下载体验。

251

2023.10.07

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1030

2023.08.02

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1567

2023.10.24

c++中volatile关键字的作用
c++中volatile关键字的作用

本专题整合了c++中volatile关键字的相关内容,阅读专题下面的文章了解更多详细内容。

75

2025.10.23

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

871

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

30

2025.12.06

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

765

2023.08.10

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.4万人学习

C# 教程
C# 教程

共94课时 | 11.2万人学习

Java 教程
Java 教程

共578课时 | 81.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号