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


Java AtomicBoolean.compareAndSet方法代碼示例

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


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

示例1: addRoots

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
public @Override boolean addRoots(final URL[] urls, SourceGroup grp, String type) throws IOException {
    final AtomicBoolean added = new AtomicBoolean();
    final String scope = findScope(grp, type);
    ModelOperation<POMModel> operation = new ModelOperation<POMModel>() {
        public @Override void performOperation(POMModel model) {
            for (URL url : urls) {
                File jar = FileUtil.archiveOrDirForURL(url);
                if (jar != null && jar.isFile()) {
                    try {
                        added.compareAndSet(false, addRemoveJAR(jar, model, scope, true));
                    } catch (IOException ex) {
                        Exceptions.printStackTrace(ex);
                    }
                } else {
                    Logger.getLogger(CPExtender.class.getName()).log(Level.INFO, "Adding non-jar root to Maven projects makes no sense. ({0})", url); //NOI18N
                }
            }
        }
    };
    FileObject pom = project.getProjectDirectory().getFileObject(POM_XML);//NOI18N
    org.netbeans.modules.maven.model.Utilities.performPOMModelOperations(pom, Collections.singletonList(operation));
    if (added.get()) {
        project.getLookup().lookup(NbMavenProject.class).triggerDependencyDownload();
    }
    return added.get();
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:27,代碼來源:CPExtender.java

示例2: testPrimaryReference

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
public void testPrimaryReference() throws Exception {
    final IndexShard shard = mock(IndexShard.class);
    final long primaryTerm = 1 + randomInt(200);
    when(shard.getPrimaryTerm()).thenReturn(primaryTerm);

    AtomicBoolean closed = new AtomicBoolean();
    Releasable releasable = () -> {
        if (closed.compareAndSet(false, true) == false) {
            fail("releasable is closed twice");
        }
    };
    TestAction.PrimaryShardReference primary = action.new PrimaryShardReference(shard, releasable);
    final Request request = new Request();
    Request replicaRequest = (Request) primary.perform(request).replicaRequest;

    assertThat(replicaRequest.primaryTerm(), equalTo(primaryTerm));

    final ElasticsearchException exception = new ElasticsearchException("testing");
    primary.failShard("test", exception);

    verify(shard).failShard("test", exception);

    primary.close();

    assertTrue(closed.get());
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:27,代碼來源:TransportReplicationActionTests.java

示例3: tAtomicBoolean

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
public void tAtomicBoolean() {
    System.currentTimeMillis();
    AtomicBoolean atomic = new AtomicBoolean();

    long t1 = System.currentTimeMillis();
    for (int i = 0; i < 10000000; i++) {
        if (atomic.compareAndSet(false, true)) {
            try {
                // ...
            } finally {
                atomic.set(false);
            }
        }
    }
    long t2 = System.currentTimeMillis();

    System.out.println("take time:" + (t2 - t1) + " ms.");
}
 
開發者ID:huang-up,項目名稱:mycat-src-1.6.1-RELEASE,代碼行數:19,代碼來源:LockPerfMain.java

示例4: testCacheInvalidation

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
@Test
public void testCacheInvalidation()
    throws InterruptedException, TestFailure, TimeoutException {
  List<DatabaseReference> refs = IntegrationTestUtils.getRandomNode(masterApp, 2);
  DatabaseReference reader = refs.get(0);
  DatabaseReference writer = refs.get(1);

  final AtomicBoolean startChecking = new AtomicBoolean(false);
  final Semaphore ready = new Semaphore(0);
  final ReadFuture future = new ReadFuture(reader.limitToLast(2), 
      new ReadFuture.CompletionCondition() {
        @Override
        public boolean isComplete(List<EventRecord> events) {
          DataSnapshot snap = events.get(events.size() - 1).getSnapshot();
          Object result = snap.getValue();
          if (startChecking.compareAndSet(false, true) && result == null) {
            ready.release(1);
            return false;
          }
          // We already initialized the location, and now the remove has
          // happened
          // so that
          // we have no more data
          return startChecking.get() && result == null;
        }
      });

  TestHelpers.waitFor(ready);
  for (int i = 0; i < 4; ++i) {
    writer.child("k" + i).setValueAsync(i);
  }

  writer.removeValueAsync();
  future.timedGet();
}
 
開發者ID:firebase,項目名稱:firebase-admin-java,代碼行數:36,代碼來源:QueryTestIT.java

示例5: send

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
/**
 * Send back the result
 * @param ctx channel context
 * @param result rpc result
 */
private void send(ChannelHandlerContext ctx, Object result) {
  int seqId = 0;
  Channel ch = ctx.channel();

  try {
    seqId = ((ByteBuf) result).readInt();
    ((ByteBuf) result).resetReaderIndex();
    AtomicBoolean channelInUse = channelStates.get(ctx);
    if (channelInUse == null) {
      return;
    }
    long startTs = System.currentTimeMillis();
    while (true) {
      if (channelInUse.compareAndSet(false, true)) {
        ctx.writeAndFlush(result);
        channelInUse.set(false);
        LOG.debug(
          "send response buf=" + result + ",channel ctx=" + ctx.channel() + ", seqId=" + seqId
            + " use time=" + (System.currentTimeMillis() - startTs));
        return;
      }
      Thread.sleep(10);
    }
  } catch (Throwable ex) {
    LOG.error("send response of request failed, request seqId=" + seqId + ", channel=" + ch, ex);
  }
}
 
開發者ID:Tencent,項目名稱:angel,代碼行數:33,代碼來源:WorkerPool.java

示例6: updateCurrentlyServingReplica

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
private void updateCurrentlyServingReplica(ScannerCallable scanner, Result[] result,
    AtomicBoolean done, ExecutorService pool) {
  if (done.compareAndSet(false, true)) {
    if (currentScannerCallable != scanner) replicaSwitched.set(true);
    currentScannerCallable = scanner;
    // store where to start the replica scanner from if we need to.
    if (result != null && result.length != 0) this.lastResult = result[result.length - 1];
    if (LOG.isTraceEnabled()) {
      LOG.trace("Setting current scanner as id=" + currentScannerCallable.scannerId +
          " associated with replica=" + currentScannerCallable.getHRegionInfo().getReplicaId());
    }
    // close all outstanding replica scanners but the one we heard back from
    outstandingCallables.remove(scanner);
    for (ScannerCallable s : outstandingCallables) {
      if (LOG.isTraceEnabled()) {
        LOG.trace("Closing scanner id=" + s.scannerId +
          ", replica=" + s.getHRegionInfo().getRegionId() +
          " because slow and replica=" +
          this.currentScannerCallable.getHRegionInfo().getReplicaId() + " succeeded");
      }
      // Submit the "close" to the pool since this might take time, and we don't
      // want to wait for the "close" to happen yet. The "wait" will happen when
      // the table is closed (when the awaitTermination of the underlying pool is called)
      s.setClose();
      final RetryingRPC r = new RetryingRPC(s);
      pool.submit(new Callable<Void>(){
        @Override
        public Void call() throws Exception {
          r.call(scannerTimeout);
          return null;
        }
      });
    }
    // now clear outstandingCallables since we scheduled a close for all the contained scanners
    outstandingCallables.clear();
  }
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:38,代碼來源:ScannerCallableWithReplicas.java

示例7: cancellable

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
/**
 * Produces a token which may be passed to {@link AggregateProgressFactory#createHandle}
 * in order to permit progress to be canceled.
 * If an event is received after a cancel request has been made, {@link ThreadDeath} will
 * be thrown (which you probably also want to catch and handle gracefully).
 * Due to AETHER-95, {@link IllegalStateException} with a cause of {@link ThreadDeath} might also be thrown.
 * Must be called by the same thread as will call {@link #setAggregateHandle} and runs the process.
 * @return a cancellation token
 */
public static Cancellable cancellable() {
    final AtomicBoolean b = new AtomicBoolean();
    activeListener().cancel = b;
    return new Cancellable() {
        public @Override boolean cancel() {
            return b.compareAndSet(false, true);
        }
    };
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:19,代碼來源:ProgressTransferListener.java

示例8: downloadProducts

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
@Test
public void downloadProducts() throws Exception {
  doAnswer(invocation -> {
    PublishSubject<Product> publishSubject = (PublishSubject<Product>) invocation.getArguments()[1];
    publishSubject.onNext(Product.getDefaultInstance());
    publishSubject.onComplete();
    return null;
  }).when(productDao).downloadProducts(any(), any());

  List<Product> downloadedProducts = Lists.newArrayList();
  AtomicBoolean onCompletedCalled = new AtomicBoolean(false);
  StreamObserver<Product> downloadObserver = new StreamObserver<Product>() {
    @Override
    public void onNext(Product value) {
      downloadedProducts.add(value);
    }

    @Override
    public void onError(Throwable t) {
      fail("should not fail");
    }

    @Override
    public void onCompleted() {
      onCompletedCalled.compareAndSet(false, true);
    }
  };
  productReadService.downloadProducts(DownloadProductsRequest.getDefaultInstance(), downloadObserver);

  verify(productDao, times(1)).downloadProducts(any(), any());
  assertThat(downloadedProducts).containsOnly(Product.getDefaultInstance());
  assertThat(onCompletedCalled).isTrue();
}
 
開發者ID:email2liyang,項目名稱:grpc-mate,代碼行數:34,代碼來源:ProductReadServiceTest.java

示例9: tryAcquire

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
@Nullable private Releasable tryAcquire() throws InterruptedException {
    if (semaphore.tryAcquire(1, 0, TimeUnit.SECONDS)) { // the untimed tryAcquire methods do not honor the fairness setting
        AtomicBoolean closed = new AtomicBoolean();
        return () -> {
            if (closed.compareAndSet(false, true)) {
                semaphore.release(1);
            }
        };
    }
    return null;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:12,代碼來源:IndexShardOperationsLock.java

示例10: wasOpenedHandlerCalled

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
boolean wasOpenedHandlerCalled(HRegionInfo hri) {
  AtomicBoolean b = openedRegionHandlerCalled.get(hri);
  //compareAndSet to be sure that unit tests don't see stale values. Means,
  //we will return true exactly once unless the handler code resets to true
  //this value.
  return b == null ? false : b.compareAndSet(true, false);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:8,代碼來源:AssignmentManager.java

示例11: init

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
protected void init(BufferedSource bufferedSource, final LogBean record, long timeout) {
    this.timeout = timeout;
    isFirstPacket = true;
    replied = false;
    isFinish = new AtomicBoolean(false);
    runTimeOut = new Runnable() {
        @Override
        public void run() {
            while (replied) {
                replied = false;
                try {
                    Thread.sleep(ProbeBufferedSource.this.timeout);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
            if (isFinish.compareAndSet(false, true)) {
                if (!cancelSubmit) {
                    FileUtil.getInstance().addReportContent(record.toString());
                }
            }
        }
    };

    this.source = bufferedSource;
    this.record = record;
}
 
開發者ID:pre-dem,項目名稱:pre-dem-android,代碼行數:28,代碼來源:ProbeBufferedSource.java

示例12: checkBuffer

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
private final boolean checkBuffer(final ByteBuffer bb, final boolean expect, final boolean update) {
    synchronized (mapTrack) {
        final AtomicBoolean inUse = mapTrack.get(bb);
        if (inUse == null) {
            return false;
        }

        return inUse.compareAndSet(expect, update);
    }
}
 
開發者ID:fast-data-transfer,項目名稱:fdt,代碼行數:11,代碼來源:AbstractBPool.java

示例13: testCompareAndSetInMultipleThreads

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
/**
 * compareAndSet in one thread enables another waiting for value
 * to succeed
 */
public void testCompareAndSetInMultipleThreads() throws Exception {
    final AtomicBoolean ai = new AtomicBoolean(true);
    Thread t = new Thread(new CheckedRunnable() {
        public void realRun() {
            while (!ai.compareAndSet(false, true)) Thread.yield();
        }});

    t.start();
    assertTrue(ai.compareAndSet(true, false));
    t.join(LONG_DELAY_MS);
    assertFalse(t.isAlive());
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:17,代碼來源:AtomicBooleanTest.java

示例14: asyncReloadDictionary

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
/**
 * Reloads the dictionary. Access is controlled on a per dictionary file basis.
 */
private void asyncReloadDictionary() {
    final AtomicBoolean isReloading = mIsReloading;
    if (!isReloading.compareAndSet(false, true)) {
        return;
    }
    final File dictFile = mDictFile;
    asyncExecuteTaskWithWriteLock(new Runnable() {
        @Override
        public void run() {
            try {
                if (!dictFile.exists() || isNeededToRecreate()) {
                    // If the dictionary file does not exist or contents have been updated,
                    // generate a new one.
                    createNewDictionaryLocked();
                } else if (getBinaryDictionary() == null) {
                    // Otherwise, load the existing dictionary.
                    loadBinaryDictionaryLocked();
                    final BinaryDictionary binaryDictionary = getBinaryDictionary();
                    if (binaryDictionary != null && !(isValidDictionaryLocked()
                            // TODO: remove the check below
                            && matchesExpectedBinaryDictFormatVersionForThisType(
                                    binaryDictionary.getFormatVersion()))) {
                        // Binary dictionary or its format version is not valid. Regenerate
                        // the dictionary file. createNewDictionaryLocked will remove the
                        // existing files if appropriate.
                        createNewDictionaryLocked();
                    }
                }
                clearNeedsToRecreate();
            } finally {
                isReloading.set(false);
            }
        }
    });
}
 
開發者ID:sergeychilingaryan,項目名稱:AOSP-Kayboard-7.1.2,代碼行數:39,代碼來源:ExpandableBinaryDictionary.java

示例15: wasClosedHandlerCalled

import java.util.concurrent.atomic.AtomicBoolean; //導入方法依賴的package包/類
boolean wasClosedHandlerCalled(HRegionInfo hri) {
  AtomicBoolean b = closedRegionHandlerCalled.get(hri);
  //compareAndSet to be sure that unit tests don't see stale values. Means,
  //we will return true exactly once unless the handler code resets to true
  //this value.
  return b == null ? false : b.compareAndSet(true, false);
}
 
開發者ID:fengchen8086,項目名稱:ditb,代碼行數:8,代碼來源:AssignmentManager.java


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