Java: Take into account writes to the field done via AtomicFieldUpdater (IDEA-152262)

This commit is contained in:
Pavel Dolgov
2018-06-21 19:23:58 +03:00
parent 9789fa1b18
commit 6caa2e4236
18 changed files with 387 additions and 0 deletions

View File

@@ -0,0 +1,11 @@
import java.util.concurrent.atomic.AtomicIntegerFieldUpdater;
class Atomics {
private volatile int num;
private static final AtomicIntegerFieldUpdater<Atomics> updater =
AtomicIntegerFieldUpdater.newUpdater(Atomics.class, "num");
public void init(int n) {
(updater).compareAndSet(this, 0, n);
}
}

View File

@@ -0,0 +1,11 @@
import java.util.concurrent.atomic.AtomicIntegerFieldUpdater;
class Atomics {
private volatile int <warning descr="Private field 'num' is never assigned">num</warning>;
private static final AtomicIntegerFieldUpdater<Atomics> updater =
AtomicIntegerFieldUpdater.newUpdater(Atomics.class, "num");
public int getInt() {
return updater.get(this);
}
}

View File

@@ -0,0 +1,20 @@
import java.util.concurrent.atomic.AtomicIntegerFieldUpdater;
import java.util.function.BiFunction;
class Atomics {
private volatile int num;
private static final AtomicIntegerFieldUpdater<Atomics> updater =
AtomicIntegerFieldUpdater.newUpdater(Atomics.class, "num");
public int getInt() {
return updater.get(this);
}
public int getAndSet(int n) {
return update(updater::getAndSet, n);
}
private int update(BiFunction<Atomics, Integer, Integer> f, int n) {
return f.apply(this, n);
}
}

View File

@@ -0,0 +1,14 @@
import java.util.concurrent.atomic.AtomicIntegerFieldUpdater;
class Atomics {
private volatile int num;
private static final AtomicIntegerFieldUpdater<Atomics> updater;
static {
updater = (AtomicIntegerFieldUpdater.newUpdater(Atomics.class, "num"));
}
public int increment() {
return updater.incrementAndGet(this);
}
}

View File

@@ -0,0 +1,10 @@
import java.util.concurrent.atomic.AtomicIntegerFieldUpdater;
class Atomics {
private volatile int num;
public void set(int n) {
AtomicIntegerFieldUpdater<Atomics> updater = AtomicIntegerFieldUpdater.newUpdater(Atomics.class, "num");
updater.set(this, n);
}
}

View File

@@ -0,0 +1,11 @@
import java.util.concurrent.atomic.AtomicLongFieldUpdater;
class Atomics {
private volatile long num;
private static final AtomicLongFieldUpdater<Atomics> updater =
(AtomicLongFieldUpdater.newUpdater(Atomics.class, "num"));
public void init(long n) {
updater.compareAndSet(this, 0, n);
}
}

View File

@@ -0,0 +1,11 @@
import java.util.concurrent.atomic.AtomicLongFieldUpdater;
class Atomics {
private volatile long <warning descr="Private field 'num' is never assigned">num</warning>;
private static final AtomicLongFieldUpdater<Atomics> updater =
AtomicLongFieldUpdater.newUpdater(Atomics.class, "num");
public long getLong() {
return updater.get(this);
}
}

View File

@@ -0,0 +1,20 @@
import java.util.concurrent.atomic.AtomicLongFieldUpdater;
import java.util.function.BiFunction;
class Atomics {
private volatile long num;
private static final AtomicLongFieldUpdater<Atomics> updater =
AtomicLongFieldUpdater.newUpdater(Atomics.class, "num");
public long getLong() {
return updater.get(this);
}
public long getAndSet(long n) {
return update(updater::getAndSet, n);
}
private long update(BiFunction<Atomics, Long, Long> f, long n) {
return f.apply(this, n);
}
}

View File

@@ -0,0 +1,14 @@
import java.util.concurrent.atomic.AtomicLongFieldUpdater;
class Atomics {
private volatile long num;
private static final AtomicLongFieldUpdater<Atomics> updater;
static {
(updater) = AtomicLongFieldUpdater.newUpdater(Atomics.class, "num");
}
public long increment() {
return updater.incrementAndGet(this);
}
}

View File

@@ -0,0 +1,10 @@
import java.util.concurrent.atomic.AtomicLongFieldUpdater;
class Atomics {
private volatile long num;
public void set(long n) {
AtomicLongFieldUpdater<Atomics> updater = AtomicLongFieldUpdater.newUpdater(Atomics.class, "num");
updater.set(this, n);
}
}

View File

@@ -0,0 +1,11 @@
import java.util.concurrent.atomic.AtomicReferenceFieldUpdater;
class Atomics {
private String <warning descr="Private field 'str' is never assigned">str</warning>;
private static final AtomicReferenceFieldUpdater<Atomics, String> updater =
AtomicReferenceFieldUpdater.newUpdater(Atomics.class, String.class, "str");
public void init(String s) {
updater.compareAndSet(this, null, s);
}
}

View File

@@ -0,0 +1,11 @@
import java.util.concurrent.atomic.AtomicReferenceFieldUpdater;
class Atomics {
private volatile String str;
private static final AtomicReferenceFieldUpdater<Atomics, String> updater =
AtomicReferenceFieldUpdater.newUpdater(Atomics.class, String.class, "str");
public void init(String s) {
updater.compareAndSet(this, null, s);
}
}

View File

@@ -0,0 +1,11 @@
import java.util.concurrent.atomic.AtomicReferenceFieldUpdater;
class Atomics {
private volatile String <warning descr="Private field 'str' is never assigned">str</warning>;
private static final AtomicReferenceFieldUpdater<Atomics, String> updater =
AtomicReferenceFieldUpdater.newUpdater(Atomics.class, String.class, "str");
public String getStr() {
return updater.get(this);
}
}

View File

@@ -0,0 +1,16 @@
import java.util.concurrent.atomic.AtomicReferenceFieldUpdater;
import java.util.function.BiFunction;
class Atomics {
private volatile String str;
private static final AtomicReferenceFieldUpdater<Atomics, String> updater =
AtomicReferenceFieldUpdater.newUpdater(Atomics.class, String.class, "str");
public String getAndSet(String s) {
return update(updater::getAndSet, s);
}
private String update(BiFunction<Atomics, String, String> f, String s) {
return f.apply(this, s);
}
}

View File

@@ -0,0 +1,10 @@
import java.util.concurrent.atomic.AtomicReferenceFieldUpdater;
class Atomics {
private volatile String str;
public void set(String s) {
AtomicReferenceFieldUpdater<Atomics, String> updater = AtomicReferenceFieldUpdater.newUpdater(Atomics.class, String.class, "str");
updater.set(this, s);
}
}