- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
所以我只是saw someone try to use一个ThreadLocal<AtomicInteger>
在一些 Java 代码中。
现在,对于链接代码,这显然是无用的,还有导致请求被拒绝的其他问题。
而且它似乎总是没用:AtomicInteger
(来自 java.util.concurrent.atomic 包)专为多线程访问而设计,ThreadLocal
使每个线程都有自己的值(value),那么为什么还要使用它呢?
我的问题是:是否有任何情况下 ThreadLocal<AtomicInteger>
会有用吗?
最佳答案
是的,我们可能会想出一个合理的场景:
AtomicInteger
的线程本地实例;如果不评估出现这种情况的整体背景,我们就无法做出判断。
关于java - ThreadLocal<AtomicInteger> 可能有用吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16933691/
当返回值不感兴趣时,AtomicInteger.getAndIncrement() 之间是否有任何(甚至在实践中不相关)差异?和 AtomicInteger.incrementAndGet()方法
有没有AtomicInteger.accumulateAndGet()不能用AtomicInteger.updateAndGet()代替的场景,还是只是为了方便方法引用? 这是一个简单的示例,我没有看
我对java中的并发数据结构有疑问,特别是: 1) ConcurrentHashMap 2) HashMap 3) ConcurrentHashMap 如果我理解正确的话: 1) 读/写是线程安全的,
我怎样才能实现这里的 while 循环总是精确执行 100 次。当我执行代码时,在极少数情况下它会在控制台上打印 99 或 98 行而不总是 100,我不明白。 import java.util.Ar
我从原子学教程中获取这段代码,它说:- "By using AtomicInteger as a replacement for Integer we're able to increment the
我正在尝试为我的 Libgdx 游戏创建一个简单的十秒倒计时器。我创建了一个 timekeep 类,它实现了 runnable 并且可以很好地执行十秒倒计时。然而,我想打印这个 Timer 变量,因为
如果两个线程都使用 i++ 递增相同的 int i,我们可能会遇到问题,因为 i++ 不是原子操作。这就是为什么有 AtomicInteger.increment(),它使递增原子化。因此,如果我们有
我已经阅读了 java.util.concurrent 包的 API 文档,但显然误解了一些内容。概述说 A small toolkit of classes that support lock-fr
是否 AtomicInteger提供任何形式的公平保证?像先到先服务的线程执行顺序就可以了? Victor Grazi's concurrent animated 上的动画示例绝对没有表现出任何这样的
我有一个类,它在各自的线程上创建许多新对象,我想保持跨线程的运行计数。我想要一个 AtomicInteger 但它没有达到我的预期,而只是得到了一个较小的版本。我假设这是一个竞争条件错误 - 但我不完
为什么在AtomicInteger或另一个Atomic类中定义了这个set方法? 示例代码: /** * Sets to the given value. * * @param newValu
我怀疑下面是否是线程安全的, // is this thread safe, final int MAX_COUNT = 3 ? if (retryCount.get() < MAX_COUNT) {
我正在阅读一些关于 Java 中的原子变量的文档。正如到处都写的那样,AtomicInteger 应该是线程安全的。 根据我对原子整数的理解,它的工作原理是比较和交换算法。当两个线程试图在完全相同的时
import java.util.concurrent.atomic.AtomicInteger; public class Volatiletest extends Thread { pri
AtomicIntegers 被认为是同步原语,还是它只是 Java 提供的方法(wait()、notify() 等)。 我对基元的定义感到困惑,因为原子整数可以对 int 进行操作并提供无锁线程 s
public class SynchroExample { public final AtomicInteger integer = new AtomicInteger(0); priva
我有一个 android 客户端,它将与服务器建立 Http 连接。 服务器要求所有的Http请求在Http头中提供一个单调递增的计数器。例如 POST /foo/server X-count: 43
我读到过使用原子包类使我们能够进行线程安全、更少锁定的编码。但是我不太确定原子包类中的方法如何在不使用锁或任何同步关键字的情况下提供线程安全。任何帮助都将不胜感激。 最佳答案 他们使用非常低级的指令,
我想实现一个共享对象来计算操作执行的统计信息。对象状态将由 Map 表示(键是操作的名称,值是操作执行的次数)。我可以选择 HashMap 是否正确?由于 AtomicInteger 具有 volat
我想找出从 0 到 1000000 的所有质数。为此我写了这个愚蠢的方法: public static boolean isPrime(int n) { for(int i = 2; i <
我是一名优秀的程序员,十分优秀!