ThreadLocalRandom通过为每个线程维护独立seed避免CAS竞争,性能远超共享Random;应调用current()获取实例,禁用构造方法、缓存或用于安全场景。

Java里用 ThreadLocalRandom 替代 Math.random() 或共享的 Random 实例,能彻底避开多线程下的竞争,提升随机数生成性能。
Random 内部用一个原子变量(seed)记录状态,每次生成随机数都要先 CAS 更新 seed。高并发下多个线程争抢同一个 seed,导致大量 CAS 失败和重试,吞吐量骤降。
而 ThreadLocalRandom 每个线程持有独立 seed,无共享状态,完全无锁,天生线程安全。
不要调用构造方法,也不要用 new ThreadLocalRandom() —— 它的构造函数是包私有的。正确方式是直接调用静态工厂方法:
立即学习“Java免费学习笔记(深入)”;
ThreadLocalRandom.current() 获取当前线程专属实例(首次调用会初始化 seed)ThreadLocalRandom.current().nextInt(100)
nextInt()、nextLong()、nextDouble()、nextBoolean(),以及带范围的重载(如 nextInt(1, 10) 表示 [1,10))以下写法不推荐:
var rnd = ThreadLocalRandom.current();)在 16 线程压测下连续生成 1000 万个 int 随机数:
Random 实例:约 800–1200ms(明显受竞争拖慢)ThreadLocalRandom.current().nextInt():稳定在 200–300ms(接近线性扩展)可见 ThreadLocalRandom 在性能和简洁性上做到了最佳平衡。
基本上就这些。用对地方,一行代码就能避开锁竞争,还不用额外管理生命周期。
以上就是Java里如何使用ThreadLocalRandom避免竞争_Java随机数生成性能优化解析的详细内容,更多请关注php中文网其它相关文章!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号