2016-01-29 11:44:19 -08:00
|
|
|
/*
|
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
|
|
*
|
|
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
|
|
* accompanied this code).
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License version
|
|
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*
|
|
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
|
|
* questions.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This file is available under and governed by the GNU General Public
|
|
|
|
* License version 2 only, as published by the Free Software Foundation.
|
|
|
|
* However, the following notice accompanied the original version of this
|
|
|
|
* file:
|
|
|
|
*
|
|
|
|
* Written by Doug Lea and Martin Buchholz with assistance from
|
|
|
|
* members of JCP JSR-166 Expert Group and released to the public
|
|
|
|
* domain, as explained at
|
|
|
|
* http://creativecommons.org/publicdomain/zero/1.0/
|
|
|
|
*/
|
|
|
|
|
|
|
|
import java.util.concurrent.atomic.AtomicInteger;
|
|
|
|
import java.util.concurrent.atomic.AtomicIntegerArray;
|
|
|
|
import java.util.concurrent.atomic.AtomicIntegerFieldUpdater;
|
|
|
|
import java.util.concurrent.atomic.AtomicLong;
|
|
|
|
import java.util.concurrent.atomic.AtomicLongArray;
|
|
|
|
import java.util.concurrent.atomic.AtomicLongFieldUpdater;
|
|
|
|
import java.util.concurrent.atomic.AtomicReference;
|
|
|
|
import java.util.concurrent.atomic.AtomicReferenceArray;
|
|
|
|
import java.util.concurrent.atomic.AtomicReferenceFieldUpdater;
|
|
|
|
|
|
|
|
import junit.framework.Test;
|
|
|
|
import junit.framework.TestSuite;
|
|
|
|
|
2016-11-28 23:47:23 -08:00
|
|
|
/**
|
|
|
|
* Tests of atomic class methods accepting lambdas introduced in JDK8.
|
|
|
|
*/
|
2016-01-29 11:44:19 -08:00
|
|
|
public class Atomic8Test extends JSR166TestCase {
|
|
|
|
|
|
|
|
public static void main(String[] args) {
|
|
|
|
main(suite(), args);
|
|
|
|
}
|
|
|
|
public static Test suite() {
|
|
|
|
return new TestSuite(Atomic8Test.class);
|
|
|
|
}
|
|
|
|
|
|
|
|
static long addLong17(long x) { return x + 17; }
|
|
|
|
static int addInt17(int x) { return x + 17; }
|
2021-01-28 18:06:55 +00:00
|
|
|
static Item addItem17(Item x) {
|
|
|
|
return new Item(x.intValue() + 17);
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
2021-01-28 18:06:55 +00:00
|
|
|
static Item sumItem(Item x, Item y) {
|
|
|
|
return new Item(x.intValue() + y.intValue());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
volatile long aLongField;
|
|
|
|
volatile int anIntField;
|
2021-01-28 18:06:55 +00:00
|
|
|
volatile Item anItemField;
|
2016-01-29 11:44:19 -08:00
|
|
|
|
2016-11-28 23:47:23 -08:00
|
|
|
AtomicLongFieldUpdater<Atomic8Test> aLongFieldUpdater() {
|
2016-01-29 11:44:19 -08:00
|
|
|
return AtomicLongFieldUpdater.newUpdater
|
|
|
|
(Atomic8Test.class, "aLongField");
|
|
|
|
}
|
|
|
|
|
2016-11-28 23:47:23 -08:00
|
|
|
AtomicIntegerFieldUpdater<Atomic8Test> anIntFieldUpdater() {
|
2016-01-29 11:44:19 -08:00
|
|
|
return AtomicIntegerFieldUpdater.newUpdater
|
|
|
|
(Atomic8Test.class, "anIntField");
|
|
|
|
}
|
|
|
|
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicReferenceFieldUpdater<Atomic8Test,Item> anItemFieldUpdater() {
|
2016-01-29 11:44:19 -08:00
|
|
|
return AtomicReferenceFieldUpdater.newUpdater
|
2021-01-28 18:06:55 +00:00
|
|
|
(Atomic8Test.class, Item.class, "anItemField");
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicLong getAndUpdate returns previous value and updates
|
|
|
|
* result of supplied function
|
|
|
|
*/
|
|
|
|
public void testLongGetAndUpdate() {
|
|
|
|
AtomicLong a = new AtomicLong(1L);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(1L, a.getAndUpdate(Atomic8Test::addLong17));
|
|
|
|
mustEqual(18L, a.getAndUpdate(Atomic8Test::addLong17));
|
|
|
|
mustEqual(35L, a.get());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicLong updateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testLongUpdateAndGet() {
|
|
|
|
AtomicLong a = new AtomicLong(1L);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(18L, a.updateAndGet(Atomic8Test::addLong17));
|
|
|
|
mustEqual(35L, a.updateAndGet(Atomic8Test::addLong17));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicLong getAndAccumulate returns previous value and updates
|
|
|
|
* with supplied function.
|
|
|
|
*/
|
|
|
|
public void testLongGetAndAccumulate() {
|
|
|
|
AtomicLong a = new AtomicLong(1L);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(1L, a.getAndAccumulate(2L, Long::sum));
|
|
|
|
mustEqual(3L, a.getAndAccumulate(3L, Long::sum));
|
|
|
|
mustEqual(6L, a.get());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicLong accumulateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testLongAccumulateAndGet() {
|
|
|
|
AtomicLong a = new AtomicLong(1L);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(7L, a.accumulateAndGet(6L, Long::sum));
|
|
|
|
mustEqual(10L, a.accumulateAndGet(3L, Long::sum));
|
|
|
|
mustEqual(10L, a.get());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicInteger getAndUpdate returns previous value and updates
|
|
|
|
* result of supplied function
|
|
|
|
*/
|
|
|
|
public void testIntGetAndUpdate() {
|
|
|
|
AtomicInteger a = new AtomicInteger(1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(1, a.getAndUpdate(Atomic8Test::addInt17));
|
|
|
|
mustEqual(18, a.getAndUpdate(Atomic8Test::addInt17));
|
|
|
|
mustEqual(35, a.get());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicInteger updateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testIntUpdateAndGet() {
|
|
|
|
AtomicInteger a = new AtomicInteger(1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(18, a.updateAndGet(Atomic8Test::addInt17));
|
|
|
|
mustEqual(35, a.updateAndGet(Atomic8Test::addInt17));
|
|
|
|
mustEqual(35, a.get());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicInteger getAndAccumulate returns previous value and updates
|
|
|
|
* with supplied function.
|
|
|
|
*/
|
|
|
|
public void testIntGetAndAccumulate() {
|
|
|
|
AtomicInteger a = new AtomicInteger(1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(1, a.getAndAccumulate(2, Integer::sum));
|
|
|
|
mustEqual(3, a.getAndAccumulate(3, Integer::sum));
|
|
|
|
mustEqual(6, a.get());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicInteger accumulateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testIntAccumulateAndGet() {
|
|
|
|
AtomicInteger a = new AtomicInteger(1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(7, a.accumulateAndGet(6, Integer::sum));
|
|
|
|
mustEqual(10, a.accumulateAndGet(3, Integer::sum));
|
|
|
|
mustEqual(10, a.get());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicReference getAndUpdate returns previous value and updates
|
|
|
|
* result of supplied function
|
|
|
|
*/
|
|
|
|
public void testReferenceGetAndUpdate() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicReference<Item> a = new AtomicReference<>(one);
|
|
|
|
mustEqual(1, a.getAndUpdate(Atomic8Test::addItem17));
|
|
|
|
mustEqual(18, a.getAndUpdate(Atomic8Test::addItem17));
|
|
|
|
mustEqual(35, a.get());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicReference updateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testReferenceUpdateAndGet() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicReference<Item> a = new AtomicReference<>(one);
|
|
|
|
mustEqual(18, a.updateAndGet(Atomic8Test::addItem17));
|
|
|
|
mustEqual(35, a.updateAndGet(Atomic8Test::addItem17));
|
|
|
|
mustEqual(35, a.get());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicReference getAndAccumulate returns previous value and updates
|
|
|
|
* with supplied function.
|
|
|
|
*/
|
|
|
|
public void testReferenceGetAndAccumulate() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicReference<Item> a = new AtomicReference<>(one);
|
|
|
|
mustEqual( 1, a.getAndAccumulate(two, Atomic8Test::sumItem));
|
|
|
|
mustEqual( 3, a.getAndAccumulate(three, Atomic8Test::sumItem));
|
|
|
|
mustEqual( 6, a.get());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicReference accumulateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testReferenceAccumulateAndGet() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicReference<Item> a = new AtomicReference<>(one);
|
|
|
|
mustEqual( 7, a.accumulateAndGet(six, Atomic8Test::sumItem));
|
|
|
|
mustEqual( 10, a.accumulateAndGet(three, Atomic8Test::sumItem));
|
|
|
|
mustEqual( 10, a.get());
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicLongArray getAndUpdate returns previous value and updates
|
|
|
|
* result of supplied function
|
|
|
|
*/
|
|
|
|
public void testLongArrayGetAndUpdate() {
|
|
|
|
AtomicLongArray a = new AtomicLongArray(1);
|
|
|
|
a.set(0, 1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(1L, a.getAndUpdate(0, Atomic8Test::addLong17));
|
|
|
|
mustEqual(18L, a.getAndUpdate(0, Atomic8Test::addLong17));
|
|
|
|
mustEqual(35L, a.get(0));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicLongArray updateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testLongArrayUpdateAndGet() {
|
|
|
|
AtomicLongArray a = new AtomicLongArray(1);
|
|
|
|
a.set(0, 1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(18L, a.updateAndGet(0, Atomic8Test::addLong17));
|
|
|
|
mustEqual(35L, a.updateAndGet(0, Atomic8Test::addLong17));
|
|
|
|
mustEqual(35L, a.get(0));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicLongArray getAndAccumulate returns previous value and updates
|
|
|
|
* with supplied function.
|
|
|
|
*/
|
|
|
|
public void testLongArrayGetAndAccumulate() {
|
|
|
|
AtomicLongArray a = new AtomicLongArray(1);
|
|
|
|
a.set(0, 1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(1L, a.getAndAccumulate(0, 2L, Long::sum));
|
|
|
|
mustEqual(3L, a.getAndAccumulate(0, 3L, Long::sum));
|
|
|
|
mustEqual(6L, a.get(0));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicLongArray accumulateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testLongArrayAccumulateAndGet() {
|
|
|
|
AtomicLongArray a = new AtomicLongArray(1);
|
|
|
|
a.set(0, 1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(7L, a.accumulateAndGet(0, 6L, Long::sum));
|
|
|
|
mustEqual(10L, a.accumulateAndGet(0, 3L, Long::sum));
|
|
|
|
mustEqual(10L, a.get(0));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicIntegerArray getAndUpdate returns previous value and updates
|
|
|
|
* result of supplied function
|
|
|
|
*/
|
|
|
|
public void testIntArrayGetAndUpdate() {
|
|
|
|
AtomicIntegerArray a = new AtomicIntegerArray(1);
|
|
|
|
a.set(0, 1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(1, a.getAndUpdate(0, Atomic8Test::addInt17));
|
|
|
|
mustEqual(18, a.getAndUpdate(0, Atomic8Test::addInt17));
|
|
|
|
mustEqual(35, a.get(0));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicIntegerArray updateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testIntArrayUpdateAndGet() {
|
|
|
|
AtomicIntegerArray a = new AtomicIntegerArray(1);
|
|
|
|
a.set(0, 1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(18, a.updateAndGet(0, Atomic8Test::addInt17));
|
|
|
|
mustEqual(35, a.updateAndGet(0, Atomic8Test::addInt17));
|
|
|
|
mustEqual(35, a.get(0));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicIntegerArray getAndAccumulate returns previous value and updates
|
|
|
|
* with supplied function.
|
|
|
|
*/
|
|
|
|
public void testIntArrayGetAndAccumulate() {
|
|
|
|
AtomicIntegerArray a = new AtomicIntegerArray(1);
|
|
|
|
a.set(0, 1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(1, a.getAndAccumulate(0, 2, Integer::sum));
|
|
|
|
mustEqual(3, a.getAndAccumulate(0, 3, Integer::sum));
|
|
|
|
mustEqual(6, a.get(0));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicIntegerArray accumulateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testIntArrayAccumulateAndGet() {
|
|
|
|
AtomicIntegerArray a = new AtomicIntegerArray(1);
|
|
|
|
a.set(0, 1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(7, a.accumulateAndGet(0, 6, Integer::sum));
|
|
|
|
mustEqual(10, a.accumulateAndGet(0, 3, Integer::sum));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicReferenceArray getAndUpdate returns previous value and updates
|
|
|
|
* result of supplied function
|
|
|
|
*/
|
|
|
|
public void testReferenceArrayGetAndUpdate() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicReferenceArray<Item> a = new AtomicReferenceArray<>(1);
|
2016-01-29 11:44:19 -08:00
|
|
|
a.set(0, one);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual( 1, a.getAndUpdate(0, Atomic8Test::addItem17));
|
|
|
|
mustEqual( 18, a.getAndUpdate(0, Atomic8Test::addItem17));
|
|
|
|
mustEqual( 35, a.get(0));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicReferenceArray updateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testReferenceArrayUpdateAndGet() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicReferenceArray<Item> a = new AtomicReferenceArray<>(1);
|
2016-01-29 11:44:19 -08:00
|
|
|
a.set(0, one);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual( 18, a.updateAndGet(0, Atomic8Test::addItem17));
|
|
|
|
mustEqual( 35, a.updateAndGet(0, Atomic8Test::addItem17));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicReferenceArray getAndAccumulate returns previous value and updates
|
|
|
|
* with supplied function.
|
|
|
|
*/
|
|
|
|
public void testReferenceArrayGetAndAccumulate() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicReferenceArray<Item> a = new AtomicReferenceArray<>(1);
|
2016-01-29 11:44:19 -08:00
|
|
|
a.set(0, one);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual( 1, a.getAndAccumulate(0, two, Atomic8Test::sumItem));
|
|
|
|
mustEqual( 3, a.getAndAccumulate(0, three, Atomic8Test::sumItem));
|
|
|
|
mustEqual( 6, a.get(0));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicReferenceArray accumulateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testReferenceArrayAccumulateAndGet() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicReferenceArray<Item> a = new AtomicReferenceArray<>(1);
|
2016-01-29 11:44:19 -08:00
|
|
|
a.set(0, one);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual( 7, a.accumulateAndGet(0, six, Atomic8Test::sumItem));
|
|
|
|
mustEqual( 10, a.accumulateAndGet(0, three, Atomic8Test::sumItem));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicLongFieldUpdater getAndUpdate returns previous value and updates
|
|
|
|
* result of supplied function
|
|
|
|
*/
|
|
|
|
public void testLongFieldUpdaterGetAndUpdate() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicLongFieldUpdater<Atomic8Test> a = aLongFieldUpdater();
|
|
|
|
a.set(this, 1L);
|
|
|
|
mustEqual(1L, a.getAndUpdate(this, Atomic8Test::addLong17));
|
|
|
|
mustEqual(18L, a.getAndUpdate(this, Atomic8Test::addLong17));
|
|
|
|
mustEqual(35L, a.get(this));
|
|
|
|
mustEqual(35L, aLongField);
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicLongFieldUpdater updateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testLongFieldUpdaterUpdateAndGet() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicLongFieldUpdater<Atomic8Test> a = aLongFieldUpdater();
|
|
|
|
a.set(this, 1L);
|
|
|
|
mustEqual(18L, a.updateAndGet(this, Atomic8Test::addLong17));
|
|
|
|
mustEqual(35L, a.updateAndGet(this, Atomic8Test::addLong17));
|
|
|
|
mustEqual(35L, a.get(this));
|
|
|
|
mustEqual(35L, aLongField);
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicLongFieldUpdater getAndAccumulate returns previous value
|
|
|
|
* and updates with supplied function.
|
|
|
|
*/
|
|
|
|
public void testLongFieldUpdaterGetAndAccumulate() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicLongFieldUpdater<Atomic8Test> a = aLongFieldUpdater();
|
|
|
|
a.set(this, 1L);
|
|
|
|
mustEqual(1L, a.getAndAccumulate(this, 2L, Long::sum));
|
|
|
|
mustEqual(3L, a.getAndAccumulate(this, 3L, Long::sum));
|
|
|
|
mustEqual(6L, a.get(this));
|
|
|
|
mustEqual(6L, aLongField);
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicLongFieldUpdater accumulateAndGet updates with supplied
|
|
|
|
* function and returns result.
|
|
|
|
*/
|
|
|
|
public void testLongFieldUpdaterAccumulateAndGet() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicLongFieldUpdater<Atomic8Test> a = aLongFieldUpdater();
|
|
|
|
a.set(this, 1L);
|
|
|
|
mustEqual(7L, a.accumulateAndGet(this, 6L, Long::sum));
|
|
|
|
mustEqual(10L, a.accumulateAndGet(this, 3L, Long::sum));
|
|
|
|
mustEqual(10L, a.get(this));
|
|
|
|
mustEqual(10L, aLongField);
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicIntegerFieldUpdater getAndUpdate returns previous value and updates
|
|
|
|
* result of supplied function
|
|
|
|
*/
|
|
|
|
public void testIntegerFieldUpdaterGetAndUpdate() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicIntegerFieldUpdater<Atomic8Test> a = anIntFieldUpdater();
|
2016-01-29 11:44:19 -08:00
|
|
|
a.set(this, 1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(1, a.getAndUpdate(this, Atomic8Test::addInt17));
|
|
|
|
mustEqual(18, a.getAndUpdate(this, Atomic8Test::addInt17));
|
|
|
|
mustEqual(35, a.get(this));
|
|
|
|
mustEqual(35, anIntField);
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicIntegerFieldUpdater updateAndGet updates with supplied function and
|
|
|
|
* returns result.
|
|
|
|
*/
|
|
|
|
public void testIntegerFieldUpdaterUpdateAndGet() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicIntegerFieldUpdater<Atomic8Test> a = anIntFieldUpdater();
|
2016-01-29 11:44:19 -08:00
|
|
|
a.set(this, 1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(18, a.updateAndGet(this, Atomic8Test::addInt17));
|
|
|
|
mustEqual(35, a.updateAndGet(this, Atomic8Test::addInt17));
|
|
|
|
mustEqual(35, a.get(this));
|
|
|
|
mustEqual(35, anIntField);
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicIntegerFieldUpdater getAndAccumulate returns previous value
|
|
|
|
* and updates with supplied function.
|
|
|
|
*/
|
|
|
|
public void testIntegerFieldUpdaterGetAndAccumulate() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicIntegerFieldUpdater<Atomic8Test> a = anIntFieldUpdater();
|
2016-01-29 11:44:19 -08:00
|
|
|
a.set(this, 1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(1, a.getAndAccumulate(this, 2, Integer::sum));
|
|
|
|
mustEqual(3, a.getAndAccumulate(this, 3, Integer::sum));
|
|
|
|
mustEqual(6, a.get(this));
|
|
|
|
mustEqual(6, anIntField);
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicIntegerFieldUpdater accumulateAndGet updates with supplied
|
|
|
|
* function and returns result.
|
|
|
|
*/
|
|
|
|
public void testIntegerFieldUpdaterAccumulateAndGet() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicIntegerFieldUpdater<Atomic8Test> a = anIntFieldUpdater();
|
2016-01-29 11:44:19 -08:00
|
|
|
a.set(this, 1);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual(7, a.accumulateAndGet(this, 6, Integer::sum));
|
|
|
|
mustEqual(10, a.accumulateAndGet(this, 3, Integer::sum));
|
|
|
|
mustEqual(10, a.get(this));
|
|
|
|
mustEqual(10, anIntField);
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicReferenceFieldUpdater getAndUpdate returns previous value
|
|
|
|
* and updates result of supplied function
|
|
|
|
*/
|
|
|
|
public void testReferenceFieldUpdaterGetAndUpdate() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicReferenceFieldUpdater<Atomic8Test,Item> a = anItemFieldUpdater();
|
2016-01-29 11:44:19 -08:00
|
|
|
a.set(this, one);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual( 1, a.getAndUpdate(this, Atomic8Test::addItem17));
|
|
|
|
mustEqual( 18, a.getAndUpdate(this, Atomic8Test::addItem17));
|
|
|
|
mustEqual( 35, a.get(this));
|
|
|
|
mustEqual( 35, anItemField);
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicReferenceFieldUpdater updateAndGet updates with supplied
|
|
|
|
* function and returns result.
|
|
|
|
*/
|
|
|
|
public void testReferenceFieldUpdaterUpdateAndGet() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicReferenceFieldUpdater<Atomic8Test,Item> a = anItemFieldUpdater();
|
2016-01-29 11:44:19 -08:00
|
|
|
a.set(this, one);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual( 18, a.updateAndGet(this, Atomic8Test::addItem17));
|
|
|
|
mustEqual( 35, a.updateAndGet(this, Atomic8Test::addItem17));
|
|
|
|
mustEqual( 35, a.get(this));
|
|
|
|
mustEqual( 35, anItemField);
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicReferenceFieldUpdater returns previous value and updates
|
|
|
|
* with supplied function.
|
|
|
|
*/
|
|
|
|
public void testReferenceFieldUpdaterGetAndAccumulate() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicReferenceFieldUpdater<Atomic8Test,Item> a = anItemFieldUpdater();
|
2016-01-29 11:44:19 -08:00
|
|
|
a.set(this, one);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual( 1, a.getAndAccumulate(this, two, Atomic8Test::sumItem));
|
|
|
|
mustEqual( 3, a.getAndAccumulate(this, three, Atomic8Test::sumItem));
|
|
|
|
mustEqual( 6, a.get(this));
|
|
|
|
mustEqual( 6, anItemField);
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* AtomicReferenceFieldUpdater accumulateAndGet updates with
|
|
|
|
* supplied function and returns result.
|
|
|
|
*/
|
|
|
|
public void testReferenceFieldUpdaterAccumulateAndGet() {
|
2021-01-28 18:06:55 +00:00
|
|
|
AtomicReferenceFieldUpdater<Atomic8Test,Item> a = anItemFieldUpdater();
|
2016-01-29 11:44:19 -08:00
|
|
|
a.set(this, one);
|
2021-01-28 18:06:55 +00:00
|
|
|
mustEqual( 7, a.accumulateAndGet(this, six, Atomic8Test::sumItem));
|
|
|
|
mustEqual( 10, a.accumulateAndGet(this, three, Atomic8Test::sumItem));
|
|
|
|
mustEqual( 10, a.get(this));
|
|
|
|
mustEqual( 10, anItemField);
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* All Atomic getAndUpdate methods throw NullPointerException on
|
|
|
|
* null function argument
|
|
|
|
*/
|
2021-01-28 18:06:55 +00:00
|
|
|
@SuppressWarnings("unchecked")
|
2016-01-29 11:44:19 -08:00
|
|
|
public void testGetAndUpdateNPE() {
|
2019-05-02 06:33:28 -07:00
|
|
|
assertThrows(
|
|
|
|
NullPointerException.class,
|
2016-01-29 11:44:19 -08:00
|
|
|
() -> new AtomicLong().getAndUpdate(null),
|
|
|
|
() -> new AtomicInteger().getAndUpdate(null),
|
|
|
|
() -> new AtomicReference().getAndUpdate(null),
|
|
|
|
() -> new AtomicLongArray(1).getAndUpdate(0, null),
|
|
|
|
() -> new AtomicIntegerArray(1).getAndUpdate(0, null),
|
|
|
|
() -> new AtomicReferenceArray(1).getAndUpdate(0, null),
|
|
|
|
() -> aLongFieldUpdater().getAndUpdate(this, null),
|
|
|
|
() -> anIntFieldUpdater().getAndUpdate(this, null),
|
2021-01-28 18:06:55 +00:00
|
|
|
() -> anItemFieldUpdater().getAndUpdate(this, null));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* All Atomic updateAndGet methods throw NullPointerException on null function argument
|
|
|
|
*/
|
2021-01-28 18:06:55 +00:00
|
|
|
@SuppressWarnings("unchecked")
|
2016-01-29 11:44:19 -08:00
|
|
|
public void testUpdateAndGetNPE() {
|
2019-05-02 06:33:28 -07:00
|
|
|
assertThrows(
|
|
|
|
NullPointerException.class,
|
2016-01-29 11:44:19 -08:00
|
|
|
() -> new AtomicLong().updateAndGet(null),
|
|
|
|
() -> new AtomicInteger().updateAndGet(null),
|
|
|
|
() -> new AtomicReference().updateAndGet(null),
|
|
|
|
() -> new AtomicLongArray(1).updateAndGet(0, null),
|
|
|
|
() -> new AtomicIntegerArray(1).updateAndGet(0, null),
|
|
|
|
() -> new AtomicReferenceArray(1).updateAndGet(0, null),
|
|
|
|
() -> aLongFieldUpdater().updateAndGet(this, null),
|
|
|
|
() -> anIntFieldUpdater().updateAndGet(this, null),
|
2021-01-28 18:06:55 +00:00
|
|
|
() -> anItemFieldUpdater().updateAndGet(this, null));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* All Atomic getAndAccumulate methods throw NullPointerException
|
|
|
|
* on null function argument
|
|
|
|
*/
|
2021-01-28 18:06:55 +00:00
|
|
|
@SuppressWarnings("unchecked")
|
2016-01-29 11:44:19 -08:00
|
|
|
public void testGetAndAccumulateNPE() {
|
2019-05-02 06:33:28 -07:00
|
|
|
assertThrows(
|
|
|
|
NullPointerException.class,
|
2016-01-29 11:44:19 -08:00
|
|
|
() -> new AtomicLong().getAndAccumulate(1L, null),
|
|
|
|
() -> new AtomicInteger().getAndAccumulate(1, null),
|
|
|
|
() -> new AtomicReference().getAndAccumulate(one, null),
|
|
|
|
() -> new AtomicLongArray(1).getAndAccumulate(0, 1L, null),
|
|
|
|
() -> new AtomicIntegerArray(1).getAndAccumulate(0, 1, null),
|
|
|
|
() -> new AtomicReferenceArray(1).getAndAccumulate(0, one, null),
|
|
|
|
() -> aLongFieldUpdater().getAndAccumulate(this, 1L, null),
|
|
|
|
() -> anIntFieldUpdater().getAndAccumulate(this, 1, null),
|
2021-01-28 18:06:55 +00:00
|
|
|
() -> anItemFieldUpdater().getAndAccumulate(this, one, null));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* All Atomic accumulateAndGet methods throw NullPointerException
|
|
|
|
* on null function argument
|
|
|
|
*/
|
2021-01-28 18:06:55 +00:00
|
|
|
@SuppressWarnings("unchecked")
|
2016-01-29 11:44:19 -08:00
|
|
|
public void testAccumulateAndGetNPE() {
|
2019-05-02 06:33:28 -07:00
|
|
|
assertThrows(
|
|
|
|
NullPointerException.class,
|
2016-01-29 11:44:19 -08:00
|
|
|
() -> new AtomicLong().accumulateAndGet(1L, null),
|
|
|
|
() -> new AtomicInteger().accumulateAndGet(1, null),
|
|
|
|
() -> new AtomicReference().accumulateAndGet(one, null),
|
|
|
|
() -> new AtomicLongArray(1).accumulateAndGet(0, 1L, null),
|
|
|
|
() -> new AtomicIntegerArray(1).accumulateAndGet(0, 1, null),
|
|
|
|
() -> new AtomicReferenceArray(1).accumulateAndGet(0, one, null),
|
|
|
|
() -> aLongFieldUpdater().accumulateAndGet(this, 1L, null),
|
|
|
|
() -> anIntFieldUpdater().accumulateAndGet(this, 1, null),
|
2021-01-28 18:06:55 +00:00
|
|
|
() -> anItemFieldUpdater().accumulateAndGet(this, one, null));
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|
|
|
|
|
2016-11-28 23:47:23 -08:00
|
|
|
/**
|
|
|
|
* Object arguments for parameters of type T that are not
|
|
|
|
* instances of the class passed to the newUpdater call will
|
|
|
|
* result in a ClassCastException being thrown.
|
|
|
|
*/
|
2021-01-28 18:06:55 +00:00
|
|
|
@SuppressWarnings("unchecked")
|
2016-11-28 23:47:23 -08:00
|
|
|
public void testFieldUpdaters_ClassCastException() {
|
|
|
|
// Use raw types to allow passing wrong object type, provoking CCE
|
|
|
|
final AtomicLongFieldUpdater longUpdater = aLongFieldUpdater();
|
|
|
|
final AtomicIntegerFieldUpdater intUpdater = anIntFieldUpdater();
|
2021-01-28 18:06:55 +00:00
|
|
|
final AtomicReferenceFieldUpdater refUpdater = anItemFieldUpdater();
|
2016-11-28 23:47:23 -08:00
|
|
|
for (Object x : new Object[]{ new Object(), null }) {
|
2019-05-02 06:33:28 -07:00
|
|
|
assertThrows(
|
|
|
|
ClassCastException.class,
|
2016-11-28 23:47:23 -08:00
|
|
|
() -> longUpdater.get(x),
|
|
|
|
() -> intUpdater.get(x),
|
|
|
|
() -> refUpdater.get(x),
|
|
|
|
|
|
|
|
() -> longUpdater.set(x, 17L),
|
|
|
|
() -> intUpdater.set(x, 17),
|
2021-01-28 18:06:55 +00:00
|
|
|
() -> refUpdater.set(x, new Item(17)),
|
2016-11-28 23:47:23 -08:00
|
|
|
|
|
|
|
() -> longUpdater.addAndGet(x, 17L),
|
|
|
|
() -> intUpdater.addAndGet(x, 17),
|
|
|
|
|
|
|
|
() -> longUpdater.getAndUpdate(x, y -> y),
|
|
|
|
() -> intUpdater.getAndUpdate(x, y -> y),
|
|
|
|
() -> refUpdater.getAndUpdate(x, y -> y),
|
|
|
|
|
|
|
|
() -> longUpdater.compareAndSet(x, 17L, 42L),
|
|
|
|
() -> intUpdater.compareAndSet(x, 17, 42),
|
2021-01-28 18:06:55 +00:00
|
|
|
() -> refUpdater.compareAndSet(x, 17, fortytwo));
|
2016-11-28 23:47:23 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-29 11:44:19 -08:00
|
|
|
}
|