草庐IT

non-volatile

全部标签

java - GWT Maven 插件 : Generating non-String parameters in the Messages class

我的“Messages.properties”文件中有一个属性,它有一个使用数字格式的参数:my.message=Fileexceeds{0,number,0.0}MB.当我运行gwt:i18nMaven目标时,它会根据我的“Messages.properties”文件中的属性生成一个Messages接口(interface)(与正常情况一样):publicinterfaceMessagesextendscom.google.gwt.i18n.client.Messages{//...@DefaultMessage("Fileexceeds{0,number,0.0}MB.")@Key

java - 用锁保护非 volatile 字段的初始化?

出于教育目的,我正在编写一个简单版本的AtomicLong,其中一个内部变量由ReentrantReadWriteLock保护。这是一个简化的示例:publicclassPlainSimpleAtomicLong{privatelongvalue;privatefinalReentrantReadWriteLockrwLock=newReentrantReadWriteLock();publicPlainSimpleAtomicLong(longinitialValue){this.value=initialValue;}publiclongget(){longresult;rwLoc

java - volatile 为什么以及如何暗示原子读/写?

首先,我知道volatile不会使多个操作(如i++)成为原子操作。这个问题是关于单个读取或写入操作。我最初的理解是volatile只强制执行内存屏障(即其他线程将能够看到更新的值)。现在我注意到JLSsection17.7说volatile还使单个读取或写入成为原子。例如,给定两个线程,都将不同的值写入volatilelongx,那么x最终将恰好代表其中一个值。我很好奇这怎么可能。在32位系统上,如果两个线程并行写入64位位置并且没有“适当的”同步(即某种锁),结果可能会混淆。为清楚起见,我们使用一个示例,其中线程1写入0L而线程2将-1L写入相同的64位内存位置。T1writesl

java - 在什么情况下其他线程看不到对非 volatile 变量的写入?我可以出于实验目的强制这样的条件吗?

我最近在SO和其他地方阅读了很多关于线程内存管理的内容,特别是volatile关键字的使用。我开始对这个概念有相当的信心,但是,为了充分理解它的效果,我想尝试运行一些实验来说明它。这是我的设置:我有一个生产者线程(它从麦克风读取音频数据,与我的previousquestion相关,但实际数据并不重要),它以byte[]到一个单独的消费者线程。线程之间共享数据的方式是我实验中的主要变量:我尝试了一个ArrayBlockingQueue;我尝试了一个共享的volatilebyte[]引用(使用array=array自引用,如thisblogpost中所推荐);我还尝试了一个没有自引用的普通

java - 是否有 Checkstyle/PMD 规则 "Non-abstract classes should not be named AbstractXXX"?

我正在处理的Java项目结合使用了代码分析工具:PMD、Checkstyle和FindBugs。这些发现了大量错误、样式问题等,但经常有一个漏网之鱼:publicclassAbstractBadlyNamedClass{//Notabstract!//...}注意相反的方式被检查,即publicabstractBadlyNamedClass给出PMD警告“抽象类应命名为AbstractXXX”。任何人都可以建议是否有一种方法可以检查这一点,可以使用上述工具之一(可能是某种自定义规则?)或其他可以完成这项工作的自动化工具? 最佳答案

java - 如果从 2 个线程写入 volatile 变量会怎样?

考虑Java并发实践中的片段-@ThreadSafepublicclassSynchronizedInteger{@GuardedBy("this")privateintvalue;publicsynchronizedintgetValue(){returnvalue;}publicsynchronizedvoidsetValue(intvalue){this.value=value;}}同一本书的摘录-AgoodwaytothinkaboutvolatilevariablesistoimaginethattheybehaveroughlyliketheSynchronizedInte

java - java 中的 volatile 与 threadLocal

让我们以SimpleDateFormat为例,因为它不是线程安全的。我可以像这样使用threadLocal允许每个线程拥有自己的SimpleDateFormat副本:privatestaticfinalThreadLocalformatter=newThreadLocal(){@OverrideprotectedSimpleDateFormatinitialValue(){returnnewSimpleDateFormat("yyyyMMddHHmm");}};但是volatile关键字保证线程将拥有变量的最新副本。所以我可以不这样做吗:volatileSimpleDateFormat

java - 在仅同步访问的情况下是否需要 volatile

这个问题在这里已经有了答案:Java-isvolatilerequiredwithsynchronized?(2个答案)关闭7年前。emitting变量应该是可变的吗?emit()方法从不同的线程调用,并且emit必须是可见的。但它只能在synchronizedblock中访问。//...是完成工作的地方,但是这里没有引用emitting。那么,如果synchronized的结构是固定的,我还需要一个volatile来emitting吗?(为什么?)staticfinalclassC{booleanemitting=false;//shallbevolatile?publicvoide

java - Jackson ObjectMapper 即使使用 NON_NULL 也会抛出 NullPointerException

当使用以下JSON并且“phones”或“emailAddresses”为空时,我将收到NullPointerException。JSON:{"item":{"messages":{"user.phone.missing":{"type":"warning","key":"user.phone.missing","message":"Userprofiledoesnothaveaphonenumber","code":null},"user.email.missing":{"type":"warning","key":"user.email.missing","message":"Us

java - 如何确定我的 JDK11 版本是 "free"还是 "non-free"?

众所周知,Oracle在Java11中更改了Java许可证,要求JDK的商业用途需要付费许可证。然而,使用OpenJDK仍然是免费的。我的PC上有一个JDK11文件夹,如下所示:在这些文件夹中有什么方法可以判断我拥有的是免费的OpenJDK版本还是需要付费许可的OracleJDK版本? 最佳答案 您会在JDK的根目录中看到一个名为release的文件。用文本编辑器打开它并检查它是否包含该行BUILD_TYPE="commercial"如果是这样,那么它就是一个商业构建。这是我安装11.0.1OpenJDK时的样子:IMPLEMENT