0

0

Java里的原子类型在海量计费系统中的应用_性能基准测试

P粉602998670

P粉602998670

发布时间:2026-03-05 11:22:03

|

474人浏览过

|

来源于php中文网

原创

atomiclong 在高并发计数场景下比 synchronized 更稳,因其基于 cas 无锁机制,避免阻塞与上下文切换,响应达微秒级;但须正确使用 incrementandget(),且注意硬件极限与 volatile 内存语义。

java里的原子类型在海量计费系统中的应用_性能基准测试

AtomicLong 在高并发计数场景下为什么比 synchronized 更稳

因为 AtomicLong 底层用的是 CAS(Compare-and-Swap),没有锁竞争,避免了线程阻塞和上下文切换开销。在每秒几十万次计费更新的场景里,synchronized 块容易成为瓶颈,而 AtomicLong.incrementAndGet() 能保持微秒级响应。

  • 典型误用:把 AtomicLong 当普通变量反复读写(比如先 get()set(x+1)),这会丢原子性,必须用 incrementAndGet()addAndGet(delta)
  • 注意硬件限制:CAS 在多核高争用下可能自旋多次,极端情况下(如 64 核全压测)吞吐反而略低于分段锁,但绝大多数计费系统不会到这个量级
  • AtomicLong 的内存语义是 volatile 级别,能保证计数变更对其他线程可见,不用额外加 volatile

AtomicIntegerFieldUpdater 用于对象内计数字段的必要条件

想给已有业务对象(比如 BillingRecord)里的 int counter 字段做原子更新,又不想改字段类型?那得用 AtomicIntegerFieldUpdater,但它有硬性约束:

  • 目标字段必须是 volatile int,且不能是 private(至少是 protected 或包级可见)
  • Updater 实例必须用 newUpdater() 静态方法创建,且泛型类型、字段名必须**字面量匹配**——写错一个字母就抛 RuntimeException
  • 不支持继承:子类重写父类字段名不算“同一个字段”,Updater 会失效
  • 性能上和 AtomicInteger 几乎一致,但节省了每个对象多持有一个原子对象的内存(对亿级计费记录很重要)

AtomicReference + 自定义计数结构的适用边界

当计费逻辑不止是加减,还要附带时间戳、来源渠道、失败原因等状态时,AtomicReference 配合不可变类才是正解,而不是硬塞多个 Atomic* 字段。

试客源码试客系统试用程序
试客源码试客系统试用程序

2018年国内领先最专业的试客系统基于微软ASP.NET(C# NET4.0)+MSSQL架构开发,性能与安全性先天就比PHP语言好很多,系统主要活动类型:免费试用、折扣试用、红包试用、拍A发B等众多模式(支持淘宝、天猫、阿里、京东、拼多多、蘑姑街等,支持定制满足你的一切需求),另附带收藏/流量优化,推广联盟(可支持N级提成)、安全认证体系、微信公众号集成、交流论坛、帮助中心、招商等子模块,系统默

下载
  • 常见错误:用 AtomicReference 包裹可变对象(比如 HashMap),然后在外部修改它——原子性只保证引用替换,不保证内部状态安全
  • 正确做法:每次更新都构造新对象,例如 new CounterState(old.count + 1, System.nanoTime(), "wechat"),再用 compareAndSet()
  • 代价是 GC 压力略增,但在 JDK 8+ G1 下,短生命周期小对象基本无感;若 QPS 超 50 万/秒,建议预分配对象池或用 VarHandle 替代(JDK 9+)

基准测试时最容易被忽略的三个干扰项

用 JMH 测 AtomicLongsynchronized 性能差距,结果不准?大概率栽在这三处:

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

  • JVM 预热不足:@Fork(jvmArgs = {"-Xmx2g", "-XX:+UseG1GC"}) 至少跑 5 轮预热,否则 JIT 还没优化到位
  • 伪共享(False Sharing):多个 AtomicLong 实例在同一个 CPU 缓存行(64 字节)里,互相 invalidate——给字段加 @sun.misc.Contended 或手动填充 7 个 long 字段
  • 测试数据污染:用单个 AtomicLong 被所有线程狂刷,这不是真实场景;应模拟“每个用户/订单一个计数器”,用 ThreadLocalRandom 做索引打散

真实计费系统里,原子类型不是银弹——它解决的是单点高频更新,一旦涉及跨账户扣减、余额校验、事务一致性,就得退回到数据库或分布式锁。别为了“用原子类”而强行绕过业务约束。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

404

2023.08.11

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

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

249

2023.10.07

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

string转int
string转int

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

930

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

603

2024.08.29

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

4

2026.03.05

热门下载

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

精品课程

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

共23课时 | 4.1万人学习

C# 教程
C# 教程

共94课时 | 10.7万人学习

Java 教程
Java 教程

共578课时 | 77.3万人学习

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

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