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


Java AtomicLong.incrementAndGet方法代碼示例

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


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

示例1: testProgress

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
@Test
public void testProgress() throws Exception {
    Path tempDir = Files.createTempDirectory("jaffree");
    Path outputPath = tempDir.resolve("test.mkv");

    final AtomicLong counter = new AtomicLong();

    ProgressListener listener = new ProgressListener() {
        @Override
        public void onProgress(FFmpegProgress progress) {
            counter.incrementAndGet();
        }
    };

    FFmpegResult result = FFmpeg.atPath(BIN)
            .addInput(UrlInput.fromPath(SMALL_FLV))
            .addOutput(UrlOutput.toPath(outputPath))
            .setProgressListener(listener)
            .execute();

    Assert.assertNotNull(result);
    Assert.assertTrue(counter.get() > 0);
}
 
開發者ID:kokorin,項目名稱:Jaffree,代碼行數:24,代碼來源:FFmpegTest.java

示例2: testProgress2

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
@Test
public void testProgress2() throws Exception {
    Path tempDir = Files.createTempDirectory("jaffree");
    Path outputPath = tempDir.resolve("test.flv");

    final AtomicLong counter = new AtomicLong();

    ProgressListener listener = new ProgressListener() {
        @Override
        public void onProgress(FFmpegProgress progress) {
            counter.incrementAndGet();
        }
    };

    FFmpegResult result = FFmpeg.atPath(BIN)
            .addInput(UrlInput.fromPath(SMALL_MP4))
            .addOutput(UrlOutput.toPath(outputPath))
            .setProgressListener(listener)
            .execute();

    Assert.assertNotNull(result);
    Assert.assertTrue(counter.get() > 0);
}
 
開發者ID:kokorin,項目名稱:Jaffree,代碼行數:24,代碼來源:FFmpegTest.java

示例3: addUsage

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
public synchronized void addUsage(Long acl) {
    if (acl == OPEN_UNSAFE_ACL_ID) {
        return;
    }

    if (!longKeyMap.containsKey(acl)) {
        LOG.info("Ignoring acl " + acl + " as it does not exist in the cache");
        return;
    }

    AtomicLong count = referenceCounter.get(acl);
    if (count == null) {
        referenceCounter.put(acl, new AtomicLongWithEquals(1));
    } else {
        count.incrementAndGet();
    }
}
 
開發者ID:maoling,項目名稱:fuck_zookeeper,代碼行數:18,代碼來源:ReferenceCountedACLCache.java

示例4: testSubscriptionOnlyHappensOnce

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
@SuppressWarnings("unchecked")
@Test
public void testSubscriptionOnlyHappensOnce() throws InterruptedException {
    final AtomicLong count = new AtomicLong();
    Consumer<Disposable> incrementer = new Consumer<Disposable>() {
        @Override
        public void accept(Disposable s) {
            count.incrementAndGet();
        }
    };

    //this aync stream should emit first
    Observable<Integer> o1 = Observable.just(1).doOnSubscribe(incrementer)
            .delay(100, TimeUnit.MILLISECONDS).subscribeOn(Schedulers.computation());
    //this stream emits second
    Observable<Integer> o2 = Observable.just(1).doOnSubscribe(incrementer)
            .delay(100, TimeUnit.MILLISECONDS).subscribeOn(Schedulers.computation());
    TestObserver<Integer> ts = new TestObserver<Integer>();
    Observable.ambArray(o1, o2).subscribe(ts);
    ts.awaitTerminalEvent(5, TimeUnit.SECONDS);
    ts.assertNoErrors();
    assertEquals(2, count.get());
}
 
開發者ID:akarnokd,項目名稱:RxJava3-preview,代碼行數:24,代碼來源:ObservableAmbTest.java

示例5: testGetByNullableKeyValueMapper

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
@Test
public void testGetByNullableKeyValueMapper(){
	List<String> strings = Arrays.asList("aaa", "b", "ca", "eeee", "ca");
	AtomicLong counterA = new AtomicLong(0);
	Function<String,String> valueMapper = str -> {
		if(str.contains("a")){
			return counterA.incrementAndGet() + "a";
		}
		if(str.contains("b")){
			return "b";
		}
		return null;
	};
	Map<Integer,String> containsByLength = MapTool.getByNullable(strings, String::length, valueMapper);
	Assert.assertEquals(containsByLength.keySet(), Arrays.asList(3, 1, 2, 4));
	Assert.assertEquals(containsByLength.values(), Arrays.asList("1a", "b", "3a", null));
}
 
開發者ID:hotpads,項目名稱:datarouter,代碼行數:18,代碼來源:MapTool.java

示例6: writeOperation

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
/**
 * 
 * @param operation
 * @return
 * @throws IOException 
 */
public Tuple<Future<DLSN>, Tuple<BytesReference, Long>> writeOperation(Translog.Operation operation, AtomicLong txid) throws IOException {
    BytesStreamOutput out = new BytesStreamOutput();
    try (ReleasableLock lock = writeLock.acquire()) {
        Future<DLSN> writeResult = null;
        out.writeByte(operation.opType().id());
        operation.writeTo(out);
        BytesReference bytes = out.bytes();
        LogRecord logRecord = new LogRecord(txid.incrementAndGet(), bytes.toBytes());
        writeResult = logWriter.write(logRecord);
        sizeInBytes += (20 + logRecord.getPayload().length);
        ++ numOperations;
        return new Tuple<Future<DLSN>, Tuple<BytesReference, Long>>(writeResult, new Tuple<BytesReference, Long>(bytes, txid.get()));
    } catch (TransactionIdOutOfOrderException e) {
        throw e;
    } finally {
        out.close();
    }
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:25,代碼來源:DistributedTranslog.java

示例7: updateNumberOfWaits

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
private static void updateNumberOfWaits(AtomicLong start, AtomicLong maxTime) {
    Long now = System.currentTimeMillis();
    Long startValue = start.get();
    if (startValue != 0 && now - startValue > 1000) {
        maxTime.incrementAndGet();
    }
    start.set(now);
}
 
開發者ID:salesforce,項目名稱:reactive-grpc,代碼行數:9,代碼來源:BackpressureIntegrationTest.java

示例8: incrementAndGet

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
private long incrementAndGet(String path) {
    AtomicLong value = accessCounts.get(path);
    if (value == null) {
        value = accessCounts.putIfAbsent(path, new AtomicLong(1));
    }
    if (value != null) {
        return value.incrementAndGet();
    }
    return 1;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:11,代碼來源:MockRepository.java

示例9: main

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
public static void main(String[] args) {
    try {
        final AtomicLong count = new AtomicLong(0);
        ExecutorService fixed = Executors.newFixedThreadPool(5);
        class Inc implements Callable<Long> {
            public Long call() throws Exception {
                Thread.sleep(200); // Catch IE from possible cancel
                return count.incrementAndGet();
            }
        }
        List<Inc> tasks = Arrays.asList(new Inc(), new Inc(), new Inc());
        List<Future<Long>> futures = fixed.invokeAll(tasks);
        check(futures.size() == tasks.size());
        check(count.get() == tasks.size());

        long gauss = 0;
        for (Future<Long> future : futures) gauss += future.get();
        check(gauss == ((tasks.size()+1)*tasks.size())/2);

        ExecutorService single = Executors.newSingleThreadExecutor();
        long save = count.get();
        check(single.invokeAny(tasks) == save + 1);
        check(count.get() == save + 1);

        fixed.shutdown();
        single.shutdown();

    } catch (Throwable t) { unexpected(t); }

    System.out.printf("%nPassed = %d, failed = %d%n%n", passed, failed);
    if (failed > 0) throw new Error("Some tests failed");
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:33,代碼來源:Invoke.java

示例10: test_embeddedServer_withHandlerChain

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
@Test
public void test_embeddedServer_withHandlerChain() throws Exception {
    AtomicLong logCount = new AtomicLong(0);
    RequestLog requestLog = (request, response) -> logCount.incrementAndGet();
    RequestLogHandler requestLogHandler = new RequestLogHandler();
    requestLogHandler.setRequestLog(requestLog);
    StatisticsHandler handlerChain = new StatisticsHandler();
    handlerChain.setHandler(requestLogHandler);

    Javalin app = Javalin.create()
        .port(0)
        .embeddedServer(new EmbeddedJettyFactory(() -> {
            Server server = new Server();
            server.setHandler(handlerChain);
            return server;
        }))
        .get("/", ctx -> ctx.result("Hello World"))
        .start();

    String origin = "http://localhost:" + app.port();

    int requests = 10;
    for (int i = 0; i < requests; i++) {
        assertThat(Unirest.get(origin + "/").asString().getBody(), is("Hello World"));
        assertThat(Unirest.get(origin + "/not_there").asString().getStatus(), is(404));
    }

    assertThat(handlerChain.getDispatched(), is(requests * 2));
    assertThat(handlerChain.getResponses2xx(), is(requests));
    assertThat(handlerChain.getResponses4xx(), is(requests));

    assertThat(logCount.get(), is((long) (requests * 2)));

    app.stop();
}
 
開發者ID:tipsy,項目名稱:javalin,代碼行數:36,代碼來源:TestCustomJetty.java

示例11: testIterator

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
@Test
public void testIterator() {
    ArrayList theList = new ArrayList();
    theList.add("A");
    theList.add("B");
    AtomicLong theLong = new AtomicLong(0);
    for (Object a : theList) {
        theLong.incrementAndGet();
    }
    Assert.assertEquals(2, theLong.get(), 0);
}
 
開發者ID:mirkosertic,項目名稱:Bytecoder,代碼行數:12,代碼來源:TArrayListTest.java

示例12: dumpFrames

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
@Test
public void dumpFrames() throws Exception {
    final Path tempDir = Files.createTempDirectory("jaffree");
    System.out.println("Will write to " + tempDir);

    final AtomicLong trackCounter = new AtomicLong();
    final AtomicLong frameCounter = new AtomicLong();
    FrameConsumer consumer = new FrameConsumer() {

        @Override
        public void consumeStreams(List<Stream> tracks) {
            trackCounter.set(tracks.size());
        }

        @Override
        public void consume(Frame frame) {
            if (frame == null) {
                return;
            }

            long n = frameCounter.incrementAndGet();
            String filename = String.format("frame%05d.png", n);
            try {
                boolean written = ImageIO.write(frame.getImage(), "png", tempDir.resolve(filename).toFile());
                Assert.assertTrue(written);
                System.out.println(filename);
            } catch (IOException e) {
                throw new RuntimeException(e);
            }
        }
    };

    FFmpegResult result = FFmpeg.atPath(BIN)
            .addInput(
                    UrlInput.fromPath(VIDEO_MP4)
                            .setDuration(1, TimeUnit.SECONDS)
            )
            .addOutput(
                    FrameOutput.withConsumer(consumer)
                            .extractVideo(true)
                            .extractAudio(false)
            )
            .execute();

    Assert.assertNotNull(result);
    Assert.assertEquals(1, trackCounter.get());
    Assert.assertTrue(frameCounter.get() > 10);
}
 
開發者ID:kokorin,項目名稱:Jaffree,代碼行數:49,代碼來源:FrameIOTest.java

示例13: testBlockingTimeout

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
public void testBlockingTimeout() throws Exception {
    final String nodeName = "test_node";
    LongGCDisruption disruption = new LongGCDisruption(random(), nodeName) {
        @Override
        protected Pattern[] getUnsafeClasses() {
            return new Pattern[]{
                Pattern.compile(LockedExecutor.class.getSimpleName())
            };
        }

        @Override
        protected long getStoppingTimeoutInMillis() {
            return 100;
        }
    };
    final AtomicBoolean stop = new AtomicBoolean();
    final CountDownLatch underLock = new CountDownLatch(1);
    final CountDownLatch pauseUnderLock = new CountDownLatch(1);
    final LockedExecutor lockedExecutor = new LockedExecutor();
    final AtomicLong ops = new AtomicLong();
    try {
        Thread[] threads = new Thread[10];
        for (int i = 0; i < 10; i++) {
            // at least one locked and one none lock thread
            final boolean lockedExec = (i < 9 && randomBoolean()) || i == 0;
            threads[i] = new Thread(() -> {
                while (stop.get() == false) {
                    if (lockedExec) {
                        lockedExecutor.executeLocked(() -> {
                            try {
                                underLock.countDown();
                                ops.incrementAndGet();
                                pauseUnderLock.await();
                            } catch (InterruptedException e) {

                            }
                        });
                    } else {
                        ops.incrementAndGet();
                    }
                }
            });
            threads[i].setName("[" + nodeName + "][" + i + "]");
            threads[i].start();
        }
        // make sure some threads are under lock
        underLock.await();
        RuntimeException e = expectThrows(RuntimeException.class, disruption::startDisrupting);
        assertThat(e.getMessage(), containsString("stopping node threads took too long"));
    } finally {
        stop.set(true);
        pauseUnderLock.countDown();
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:55,代碼來源:LongGCDisruptionTest.java

示例14: testNotBlockingUnsafeStackTraces

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
/**
 * Checks that a GC disruption never blocks threads while they are doing something "unsafe"
 * but does keep retrying until all threads can be safely paused
 */
public void testNotBlockingUnsafeStackTraces() throws Exception {
    final String nodeName = "test_node";
    LongGCDisruption disruption = new LongGCDisruption(random(), nodeName) {
        @Override
        protected Pattern[] getUnsafeClasses() {
            return new Pattern[]{
                Pattern.compile(LockedExecutor.class.getSimpleName())
            };
        }
    };
    final AtomicBoolean stop = new AtomicBoolean();
    final LockedExecutor lockedExecutor = new LockedExecutor();
    final AtomicLong ops = new AtomicLong();
    try {
        Thread[] threads = new Thread[10];
        for (int i = 0; i < 10; i++) {
            threads[i] = new Thread(() -> {
                for (int iter = 0; stop.get() == false; iter++) {
                    if (iter % 2 == 0) {
                        lockedExecutor.executeLocked(() -> {
                            Thread.yield(); // give some chance to catch this stack trace
                            ops.incrementAndGet();
                        });
                    } else {
                        Thread.yield(); // give some chance to catch this stack trace
                        ops.incrementAndGet();
                    }
                }
            });
            threads[i].setName("[" + nodeName + "][" + i + "]");
            threads[i].start();
        }
        // make sure some threads are under lock
        disruption.startDisrupting();
        long first = ops.get();
        assertThat(lockedExecutor.lock.isLocked(), equalTo(false)); // no threads should own the lock
        Thread.sleep(100);
        assertThat(ops.get(), equalTo(first));
        disruption.stopDisrupting();
        assertBusy(() -> assertThat(ops.get(), greaterThan(first)));
    } finally {
        stop.set(true);
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:49,代碼來源:LongGCDisruptionTest.java

示例15: handleError

import java.util.concurrent.atomic.AtomicLong; //導入方法依賴的package包/類
@Override
public void handleError(final IncomingDataPoint dp, 
                        final Exception exception) {
  KafkaRequeueTopic type = KafkaRequeueTopic.DEFAULT;
  try {
    if (dp == null) {
      throw new IllegalArgumentException("Unable to reque a null data point.");
    }
    
    if (dp instanceof Metric) {
      type = KafkaRequeueTopic.RAW;
    } else if (dp instanceof Aggregate && 
        Strings.isNullOrEmpty(((Aggregate) dp).getInterval())) {
      type = KafkaRequeueTopic.PREAGGREGATE;
    } else if (dp instanceof Aggregate) {
      type = KafkaRequeueTopic.ROLLUP;
    } else if (dp instanceof Histogram) {
      type = KafkaRequeueTopic.HISTOGRAM;
    }
    
    String topic = topic_name_map.get(type);
    if (Strings.isNullOrEmpty(topic)) {
      type = KafkaRequeueTopic.DEFAULT;
      topic = topic_name_map.get(type);
    }
    
    if (LOG.isDebugEnabled()) {
      LOG.debug("Routing SEH message " + dp + " to topic: " + topic);
    }
    
    int hash = dp.getMetric().hashCode() + Objects.hashCode(dp.getTags());
    final KeyedMessage<String, byte[]> data = 
        new KeyedMessage<String, byte[]>(topic, 
            Integer.toString(Math.abs(hash)),
            JSON.serializeToBytes(dp));
    producer.send(data);
    
    final AtomicLong requeued = topic_requeued_counters.get(type);
    if (requeued != null) {
      requeued.incrementAndGet();
    }
  } catch (final Exception ex) {
    LOG.error("Unexpected exception publishing data", ex);
    final AtomicLong requeue_ex = topic_requeued_exception_counters
        .get(type);
    if (requeue_ex != null) {
      requeue_ex.incrementAndGet();
    }
  }
}
 
開發者ID:OpenTSDB,項目名稱:opentsdb-rpc-kafka,代碼行數:51,代碼來源:KafkaStorageExceptionHandler.java


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