當前位置: 首頁>>代碼示例>>Java>>正文


Java AtomicReference.compareAndSet方法代碼示例

本文整理匯總了Java中java.util.concurrent.atomic.AtomicReference.compareAndSet方法的典型用法代碼示例。如果您正苦於以下問題:Java AtomicReference.compareAndSet方法的具體用法?Java AtomicReference.compareAndSet怎麽用?Java AtomicReference.compareAndSet使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.util.concurrent.atomic.AtomicReference的用法示例。


在下文中一共展示了AtomicReference.compareAndSet方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: compute

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
public final void compute() {
	final Fun<? super K, ? extends U> searchFunction;
	final AtomicReference<U> result;
	if ((searchFunction = this.searchFunction) != null && (result = this.result) != null) {
		for (int i = baseIndex, f, h; batch > 0 && (h = ((f = baseLimit) + i) >>> 1) > i;) {
			if (result.get() != null)
				return;
			addToPendingCount(1);
			new SearchKeysTask<K, V, U>(this, batch >>>= 1, baseLimit = h, f, tab, searchFunction, result)
					.fork();
		}
		while (result.get() == null) {
			U u;
			Node<K, V> p;
			if ((p = advance()) == null) {
				propagateCompletion();
				break;
			}
			if ((u = searchFunction.apply(p.key)) != null) {
				if (result.compareAndSet(null, u))
					quietlyCompleteRoot();
				break;
			}
		}
	}
}
 
開發者ID:zhangjunfang,項目名稱:util,代碼行數:27,代碼來源:ConcurrentHashMapV8.java

示例2: decFloat

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
public void decFloat(String attributeName, Float oldVal) {
  if (oldVal == 0) {
    return;
  }
  AtomicReference<Number> ar = aggregateMap.get(attributeName);
  Number curVal;
  for (;;) {
    Number expectedVal = ar.get();
    if (expectedVal.floatValue() != 0) {
      curVal = expectedVal.floatValue() - oldVal;
    } else {
      return;
    }
    if (ar.compareAndSet(expectedVal, curVal)) {
      return;
    }
  }
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:19,代碼來源:StatsAggregator.java

示例3: decLong

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
public void decLong(String attributeName, Long oldVal) {
  if (oldVal == 0) {
    return;
  }
  AtomicReference<Number> ar = aggregateMap.get(attributeName);
  Number curVal;
  for (;;) {
    Number expectedVal = ar.get();
    if (expectedVal.longValue() != 0) {
      curVal = expectedVal.longValue() - oldVal;
    } else {
      return;
    }
    if (ar.compareAndSet(expectedVal, curVal)) {
      return;
    }
  }
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:19,代碼來源:StatsAggregator.java

示例4: create

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
public static <T> ConnectableObservable<T> create(Observable<? extends T> source) {
    final AtomicReference<PublishSubscriber<T>> curr = new AtomicReference();
    return new OperatorPublish(new Observable$OnSubscribe<T>() {
        public void call(Subscriber<? super T> child) {
            while (true) {
                PublishSubscriber<T> r = (PublishSubscriber) curr.get();
                if (r == null || r.isUnsubscribed()) {
                    PublishSubscriber<T> u = new PublishSubscriber(curr);
                    u.init();
                    if (curr.compareAndSet(r, u)) {
                        r = u;
                    } else {
                        continue;
                    }
                }
                InnerProducer<T> inner = new InnerProducer(r, child);
                if (r.add(inner)) {
                    child.add(inner);
                    child.setProducer(inner);
                    return;
                }
            }
        }
    }, source, curr);
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:26,代碼來源:OperatorPublish.java

示例5: addTask

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
private void addTask(final CraftTask task) {
    final AtomicReference<CraftTask> tail = this.tail;
    CraftTask tailTask = tail.get();
    while (!tail.compareAndSet(tailTask, task)) {
        tailTask = tail.get();
    }
    tailTask.setNext(task);
}
 
開發者ID:UraniumMC,項目名稱:Uranium,代碼行數:9,代碼來源:CraftScheduler.java

示例6: testConcurrentDynamicUpdates

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
public void testConcurrentDynamicUpdates() throws Throwable {
    createIndex("index");
    final Thread[] indexThreads = new Thread[32];
    final CountDownLatch startLatch = new CountDownLatch(1);
    final AtomicReference<Throwable> error = new AtomicReference<>();
    for (int i = 0; i < indexThreads.length; ++i) {
        final String id = Integer.toString(i);
        indexThreads[i] = new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    startLatch.await();
                    assertEquals(DocWriteResponse.Result.CREATED, client().prepareIndex("index", "type", id)
                        .setSource("field" + id, "bar").get().getResult());
                } catch (Exception e) {
                    error.compareAndSet(null, e);
                }
            }
        });
        indexThreads[i].start();
    }
    startLatch.countDown();
    for (Thread thread : indexThreads) {
        thread.join();
    }
    if (error.get() != null) {
        throw error.get();
    }
    Thread.sleep(2000);
    GetMappingsResponse mappings = client().admin().indices().prepareGetMappings("index").setTypes("type").get();
    for (int i = 0; i < indexThreads.length; ++i) {
        assertMappingsHaveField(mappings, "index", "type", "field" + i);
    }
    for (int i = 0; i < indexThreads.length; ++i) {
        assertTrue(client().prepareGet("index", "type", Integer.toString(i)).get().isExists());
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:38,代碼來源:DynamicMappingIT.java

示例7: abortWait

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
/**
 * Variant of releaseWaiters that additionally tries to remove any
 * nodes no longer waiting for advance due to timeout or
 * interrupt. Currently, nodes are removed only if they are at
 * head of queue, which suffices to reduce memory footprint in
 * most usages.
 *
 * @return current phase on exit
 */
private int abortWait(int phase) {
    AtomicReference<QNode> head = (phase & 1) == 0 ? evenQ : oddQ;
    for (;;) {
        Thread t;
        QNode q = head.get();
        int p = (int)(root.state >>> PHASE_SHIFT);
        if (q == null || ((t = q.thread) != null && q.phase == p))
            return p;
        if (head.compareAndSet(q, q.next) && t != null) {
            q.thread = null;
            LockSupport.unpark(t);
        }
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:24,代碼來源:Phaser.java

示例8: set

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
public void set(Subscription s) {
    if (s == null) {
        throw new IllegalArgumentException("Subscription can not be null");
    }
    State oldState;
    AtomicReference<State> localState = this.state;
    do {
        oldState = (State) localState.get();
        if (oldState.isUnsubscribed) {
            s.unsubscribe();
            return;
        }
    } while (!localState.compareAndSet(oldState, oldState.set(s)));
    oldState.subscription.unsubscribe();
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:16,代碼來源:SerialSubscription.java

示例9: compute

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
public final void compute() {
    final Function<? super V, ? extends U> searchFunction;
    final AtomicReference<U> result;
    if ((searchFunction = this.searchFunction) != null &&
        (result = this.result) != null) {
        for (int i = baseIndex, f, h; batch > 0 &&
                 (h = ((f = baseLimit) + i) >>> 1) > i;) {
            if (result.get() != null)
                return;
            addToPendingCount(1);
            new SearchValuesTask<K,V,U>
                (this, batch >>>= 1, baseLimit = h, f, tab,
                 searchFunction, result).fork();
        }
        while (result.get() == null) {
            U u;
            Node<K,V> p;
            if ((p = advance()) == null) {
                propagateCompletion();
                break;
            }
            if ((u = searchFunction.apply(p.val)) != null) {
                if (result.compareAndSet(null, u))
                    quietlyCompleteRoot();
                break;
            }
        }
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:30,代碼來源:ConcurrentHashMap.java

示例10: unsubscribe

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
public void unsubscribe() {
    State newState;
    AtomicReference<State> localState = this.state;
    State oldState;
    do {
        oldState = (State) localState.get();
        if (!oldState.isUnsubscribed) {
            newState = oldState.unsubscribe();
        } else {
            return;
        }
    } while (!localState.compareAndSet(oldState, newState));
    unsubscribeActualIfApplicable(newState);
}
 
開發者ID:JackChan1999,項目名稱:boohee_v5.6,代碼行數:15,代碼來源:RefCountSubscription.java

示例11: setOnce

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
/**
 * Atomically updates the target upstream AtomicReference from null to the non-null
 * next Disposable, otherwise disposes next and reports a ProtocolViolationException
 * if the AtomicReference doesn't contain the shared disposed indicator.
 * @param upstream the target AtomicReference to update
 * @param next the Disposable to set on it atomically
 * @param observer the class of the consumer to have a personalized
 * error message if the upstream already contains a non-cancelled Disposable.
 * @return true if successful, false if the content of the AtomicReference was non null
 */
public static boolean setOnce(AtomicReference<Disposable> upstream, Disposable next, Class<?> observer) {
    ObjectHelper.requireNonNull(next, "next is null");
    if (!upstream.compareAndSet(null, next)) {
        next.dispose();
        if (upstream.get() != DisposableHelper.DISPOSED) {
            reportDoubleSubscription(observer);
        }
        return false;
    }
    return true;
}
 
開發者ID:akarnokd,項目名稱:RxJava3-preview,代碼行數:22,代碼來源:EndObserverHelper.java

示例12: setOnce

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
/**
 * Atomically updates the target upstream AtomicReference from null to the non-null
 * next Subscription, otherwise cancels next and reports a ProtocolViolationException
 * if the AtomicReference doesn't contain the shared cancelled indicator.
 * @param upstream the target AtomicReference to update
 * @param next the Subscription to set on it atomically
 * @param subscriber the class of the consumer to have a personalized
 * error message if the upstream already contains a non-cancelled Subscription.
 * @return true if successful, false if the content of the AtomicReference was non null
 */
public static boolean setOnce(AtomicReference<Subscription> upstream, Subscription next, Class<?> subscriber) {
    ObjectHelper.requireNonNull(next, "next is null");
    if (!upstream.compareAndSet(null, next)) {
        next.cancel();
        if (upstream.get() != SubscriptionHelper.CANCELLED) {
            reportDoubleSubscription(subscriber);
        }
        return false;
    }
    return true;
}
 
開發者ID:akarnokd,項目名稱:RxJava3-preview,代碼行數:22,代碼來源:EndSubscriberHelper.java

示例13: incInt

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
public void incInt(String attributeName, Integer newVal, Integer oldVal) {
  if (newVal.equals(oldVal)) {
    return;
  }
  AtomicReference<Number> ar = aggregateMap.get(attributeName);
  for (;;) {
    Number expectedVal = ar.get();
    Number curVal = expectedVal.intValue() + (newVal - oldVal);
    if (ar.compareAndSet(expectedVal, curVal)) {
      return;
    }
  }
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:14,代碼來源:StatsAggregator.java

示例14: evaluate

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
@Override
public void evaluate() throws Throwable {
    long start = System.currentTimeMillis();
    if (parallel) {
        final CountDownLatch done = new CountDownLatch(times);
        final ExecutorService es = Executors.newCachedThreadPool();
        final AtomicReference<Throwable> anyError = new AtomicReference<>(null);
        try {
            for (int i = 1; i <= times; i++) {
                final int idx = i;
                es.submit(() -> {
                            try {
                                if (anyError.compareAndSet(null, null)) {
                                    if (printStep) {
                                        System.out.println("Repeat(Parallel) " + methodName + ": " + idx + "/" + times);
                                    }
                                    statement.evaluate();
                                }
                            } catch (Throwable throwable) {
                                anyError.compareAndSet(null, throwable);
                            } finally {
                                done.countDown();
                            }
                        }
                );
            }
            done.await();
            if (!anyError.compareAndSet(null, null)) {
                throw anyError.get();
            }
        } finally {
            es.shutdown();
        }
    } else {
        for (int i = 1; i <= times; i++) {
            long lapsed = System.currentTimeMillis() - start;
            long each = (i == 1 ? 0 : lapsed / (i - 1));
            if (printStep) {
                System.out.println("Repeat " + methodName + ": " + i + "/" + times + " elapsed(ms):" + lapsed + " each(ms):" + each);
            }
            statement.evaluate();
        }
    }
}
 
開發者ID:altiplanogao,項目名稱:io-comparison,代碼行數:45,代碼來源:MultiTestRule.java

示例15: testThreads

import java.util.concurrent.atomic.AtomicReference; //導入方法依賴的package包/類
public void testThreads() throws Exception {
    final ParentChildIndexFieldData indexFieldData = getForField(childType);
    final DirectoryReader reader = ElasticsearchDirectoryReader.wrap(
            DirectoryReader.open(writer), new ShardId(new Index("test", ""), 0));
    final IndexParentChildFieldData global = indexFieldData.loadGlobal(reader);
    final AtomicReference<Exception> error = new AtomicReference<>();
    final int numThreads = scaledRandomIntBetween(3, 8);
    final Thread[] threads = new Thread[numThreads];
    final CountDownLatch latch = new CountDownLatch(1);

    final Map<Object, BytesRef[]> expected = new HashMap<>();
    for (LeafReaderContext context : reader.leaves()) {
        AtomicParentChildFieldData leafData = global.load(context);
        SortedDocValues parentIds = leafData.getOrdinalsValues(parentType);
        final BytesRef[] ids = new BytesRef[parentIds.getValueCount()];
        for (int j = 0; j < parentIds.getValueCount(); ++j) {
            final BytesRef id = parentIds.lookupOrd(j);
            if (id != null) {
                ids[j] = BytesRef.deepCopyOf(id);
            }
        }
        expected.put(context.reader().getCoreCacheKey(), ids);
    }

    for (int i = 0; i < numThreads; ++i) {
        threads[i] = new Thread() {
            @Override
            public void run() {
                try {
                    latch.await();
                    for (int i = 0; i < 100000; ++i) {
                        for (LeafReaderContext context : reader.leaves()) {
                            AtomicParentChildFieldData leafData = global.load(context);
                            SortedDocValues parentIds = leafData.getOrdinalsValues(parentType);
                            final BytesRef[] expectedIds = expected.get(context.reader().getCoreCacheKey());
                            for (int j = 0; j < parentIds.getValueCount(); ++j) {
                                final BytesRef id = parentIds.lookupOrd(j);
                                assertEquals(expectedIds[j], id);
                            }
                        }
                    }
                } catch (Exception e) {
                    error.compareAndSet(null, e);
                }
            }
        };
        threads[i].start();
    }
    latch.countDown();
    for (Thread thread : threads) {
        thread.join();
    }
    if (error.get() != null) {
        throw error.get();
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:57,代碼來源:ParentChildFieldDataTests.java


注:本文中的java.util.concurrent.atomic.AtomicReference.compareAndSet方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。