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


Java LongSupplier類代碼示例

本文整理匯總了Java中java.util.function.LongSupplier的典型用法代碼示例。如果您正苦於以下問題:Java LongSupplier類的具體用法?Java LongSupplier怎麽用?Java LongSupplier使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: parseLong

import java.util.function.LongSupplier; //導入依賴的package包/類
@Override
public long parseLong(String value, boolean roundUp, LongSupplier now) {
    Number n;
    try {
        n = format.parse(value);
    } catch (ParseException e) {
        throw new RuntimeException(e);
    }
    if (format.isParseIntegerOnly()) {
        return n.longValue();
    } else {
        double d = n.doubleValue();
        if (roundUp) {
            d = Math.ceil(d);
        } else {
            d = Math.floor(d);
        }
        return Math.round(d);
    }
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:21,代碼來源:DocValueFormat.java

示例2: TranslogWriter

import java.util.function.LongSupplier; //導入依賴的package包/類
private TranslogWriter(
    final ChannelFactory channelFactory,
    final ShardId shardId,
    final Checkpoint initialCheckpoint,
    final FileChannel channel,
    final Path path,
    final ByteSizeValue bufferSize,
    final LongSupplier globalCheckpointSupplier) throws IOException {
    super(initialCheckpoint.generation, channel, path, channel.position());
    this.shardId = shardId;
    this.channelFactory = channelFactory;
    this.outputStream = new BufferedChannelOutputStream(java.nio.channels.Channels.newOutputStream(channel), bufferSize.bytesAsInt());
    this.lastSyncedCheckpoint = initialCheckpoint;
    this.totalOffset = initialCheckpoint.offset;
    assert initialCheckpoint.minSeqNo == SequenceNumbersService.NO_OPS_PERFORMED : initialCheckpoint.minSeqNo;
    this.minSeqNo = initialCheckpoint.minSeqNo;
    assert initialCheckpoint.maxSeqNo == SequenceNumbersService.NO_OPS_PERFORMED : initialCheckpoint.maxSeqNo;
    this.maxSeqNo = initialCheckpoint.maxSeqNo;
    this.globalCheckpointSupplier = globalCheckpointSupplier;
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:21,代碼來源:TranslogWriter.java

示例3: parse

import java.util.function.LongSupplier; //導入依賴的package包/類
public long parse(String text, LongSupplier now, boolean roundUp, DateTimeZone timeZone) {
    long time;
    String mathString;
    if (text.startsWith("now")) {
        try {
            time = now.getAsLong();
        } catch (Exception e) {
            throw new ElasticsearchParseException("could not read the current timestamp", e);
        }
        mathString = text.substring("now".length());
    } else {
        int index = text.indexOf("||");
        if (index == -1) {
            return parseDateTime(text, timeZone, roundUp);
        }
        time = parseDateTime(text.substring(0, index), timeZone, false);
        mathString = text.substring(index + 2);
    }

    return parseMath(mathString, time, roundUp, timeZone);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:22,代碼來源:DateMathParser.java

示例4: TransportBulkAction

import java.util.function.LongSupplier; //導入依賴的package包/類
public TransportBulkAction(Settings settings, ThreadPool threadPool, TransportService transportService,
                           ClusterService clusterService, IngestService ingestService,
                           TransportShardBulkAction shardBulkAction, TransportCreateIndexAction createIndexAction,
                           ActionFilters actionFilters, IndexNameExpressionResolver indexNameExpressionResolver,
                           AutoCreateIndex autoCreateIndex, LongSupplier relativeTimeProvider) {
    super(settings, BulkAction.NAME, threadPool, transportService, actionFilters, indexNameExpressionResolver, BulkRequest::new);
    Objects.requireNonNull(relativeTimeProvider);
    this.clusterService = clusterService;
    this.ingestService = ingestService;
    this.shardBulkAction = shardBulkAction;
    this.createIndexAction = createIndexAction;
    this.autoCreateIndex = autoCreateIndex;
    this.relativeTimeProvider = relativeTimeProvider;
    this.ingestForwarder = new IngestActionForwarder(transportService);
    clusterService.addStateApplier(this.ingestForwarder);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:17,代碼來源:TransportBulkAction.java

示例5: TestTransportBulkAction

import java.util.function.LongSupplier; //導入依賴的package包/類
TestTransportBulkAction(
        Settings settings,
        ThreadPool threadPool,
        TransportService transportService,
        ClusterService clusterService,
        TransportShardBulkAction shardBulkAction,
        TransportCreateIndexAction createIndexAction,
        ActionFilters actionFilters,
        IndexNameExpressionResolver indexNameExpressionResolver,
        AutoCreateIndex autoCreateIndex,
        LongSupplier relativeTimeProvider) {
    super(
            settings,
            threadPool,
            transportService,
            clusterService,
            null,
            shardBulkAction,
            createIndexAction,
            actionFilters,
            indexNameExpressionResolver,
            autoCreateIndex,
            relativeTimeProvider);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:25,代碼來源:TransportBulkActionTookTests.java

示例6: of

import java.util.function.LongSupplier; //導入依賴的package包/類
/**
 * Create a new {@code Random64} instance, where the random numbers are
 * generated by the given long {@code supplier}.
 *
 * @param supplier the random number supplier
 * @return a new {@code Random64} instance
 * @throws java.lang.NullPointerException if the given {@code supplier} is
 *         {@code null}.
 */
public static Random64 of(final LongSupplier supplier) {
	Objects.requireNonNull(supplier);

	return new Random64() {
		private static final long serialVersionUID = 1L;

		private final Boolean _sentry = Boolean.TRUE;

		@Override
		public long nextLong() {
			return supplier.getAsLong();
		}

		@Override
		public void setSeed(final long seed) {
			if (_sentry != null) {
				throw new UnsupportedOperationException(
					"The 'setSeed(long)' method is not supported."
				);
			}
		}
	};
}
 
開發者ID:jenetics,項目名稱:prngine,代碼行數:33,代碼來源:Random64.java

示例7: shouldRequireNonNullCache

import java.util.function.LongSupplier; //導入依賴的package包/類
/**
 *
 */
@Test
@SuppressWarnings(CompilerWarnings.UNUSED)
public void shouldRequireNonNullCache() {
    // given
    final ConcurrentMap<String, Long> cache = null;
    final Supplier<String> keySupplier = () -> "key";
    final LongSupplier supplier = () -> 123L;

    // when
    thrown.expect(NullPointerException.class);
    thrown.expectMessage("Provide an empty map instead of NULL.");

    // then
    new ConcurrentMapBasedLongSupplierMemoizer<>(cache, keySupplier, supplier);
}
 
開發者ID:sebhoss,項目名稱:memoization.java,代碼行數:19,代碼來源:ConcurrentMapBasedLongSupplierMemoizerTest.java

示例8: shouldRequireNonNullKeySupplier

import java.util.function.LongSupplier; //導入依賴的package包/類
/**
 *
 */
@Test
@SuppressWarnings(CompilerWarnings.UNUSED)
public void shouldRequireNonNullKeySupplier() {
    // given
    final ConcurrentMap<String, Long> cache = new ConcurrentHashMap<>();
    final Supplier<String> keySupplier = null;
    final LongSupplier supplier = () -> 123L;

    // when
    thrown.expect(NullPointerException.class);
    thrown.expectMessage("Provide a key function, might just be 'MemoizationDefaults.defaultKeySupplier()'.");

    // then
    new ConcurrentMapBasedLongSupplierMemoizer<>(cache, keySupplier, supplier);
}
 
開發者ID:sebhoss,項目名稱:memoization.java,代碼行數:19,代碼來源:ConcurrentMapBasedLongSupplierMemoizerTest.java

示例9: shouldRequireNonNullValueSupplier

import java.util.function.LongSupplier; //導入依賴的package包/類
/**
 *
 */
@Test
@SuppressWarnings(CompilerWarnings.UNUSED)
public void shouldRequireNonNullValueSupplier() {
    // given
    final ConcurrentMap<String, Long> cache = new ConcurrentHashMap<>();
    final Supplier<String> keySupplier = () -> "key";
    final LongSupplier supplier = null;

    // when
    thrown.expect(NullPointerException.class);
    thrown.expectMessage("Cannot memoize a NULL Supplier - provide an actual Supplier to fix this.");

    // then
    new ConcurrentMapBasedLongSupplierMemoizer<>(cache, keySupplier, supplier);
}
 
開發者ID:sebhoss,項目名稱:memoization.java,代碼行數:19,代碼來源:ConcurrentMapBasedLongSupplierMemoizerTest.java

示例10: shouldUseSuppliedKey

import java.util.function.LongSupplier; //導入依賴的package包/類
/**
 *
 */
@Test
public void shouldUseSuppliedKey() {
    // given
    final ConcurrentMap<String, Long> cache = new ConcurrentHashMap<>();
    final Supplier<String> keySupplier = () -> "key";
    final LongSupplier supplier = () -> 123L;

    // when
    final ConcurrentMapBasedLongSupplierMemoizer<String> memoizer = new ConcurrentMapBasedLongSupplierMemoizer<>(
            cache, keySupplier, supplier);

    // then
    Assert.assertTrue("Cache is not empty before memoization", memoizer.viewCacheForTest().isEmpty());
    Assert.assertEquals("Memoized value does not match expectations", 123L, memoizer.getAsLong());
    Assert.assertFalse("Cache is still empty after memoization", memoizer.viewCacheForTest().isEmpty());
    Assert.assertEquals("Memoization key does not match expectations", "key",
            memoizer.viewCacheForTest().keySet().iterator().next());
}
 
開發者ID:sebhoss,項目名稱:memoization.java,代碼行數:22,代碼來源:ConcurrentMapBasedLongSupplierMemoizerTest.java

示例11: shouldTriggerOnce

import java.util.function.LongSupplier; //導入依賴的package包/類
/**
 *
 */
@Test
@SuppressWarnings(CompilerWarnings.BOXING)
public void shouldTriggerOnce() {
    // given
    final ConcurrentMap<String, Long> cache = new ConcurrentHashMap<>();
    final Supplier<String> keySupplier = () -> "key";
    final LongSupplier supplier = mock(LongSupplier.class);
    given(supplier.getAsLong()).willReturn(123L);

    // when
    final ConcurrentMapBasedLongSupplierMemoizer<String> memoizer = new ConcurrentMapBasedLongSupplierMemoizer<>(
            cache, keySupplier, supplier);

    // then
    Assert.assertEquals("Memoized value does not match expectations", 123L, memoizer.getAsLong()); // triggers
    Assert.assertEquals("Memoized value does not match expectations", 123L, memoizer.getAsLong()); // memoized
    Assert.assertEquals("Memoized value does not match expectations", 123L, memoizer.getAsLong()); // memoized
    Assert.assertEquals("Memoized value does not match expectations", 123L, memoizer.getAsLong()); // memoized
    verify(supplier, times(1)).getAsLong(); // real supplier triggered once, all other calls were memoized
}
 
開發者ID:sebhoss,項目名稱:memoization.java,代碼行數:24,代碼來源:ConcurrentMapBasedLongSupplierMemoizerTest.java

示例12: shouldReplyToOnNotLeaderWith

import java.util.function.LongSupplier; //導入依賴的package包/類
private void shouldReplyToOnNotLeaderWith(
    final IntSupplier libraryId,
    final LongSupplier connectCorrelationId,
    final String... channels)
{
    whenPolled()
        .then(
            (inv) ->
            {
                library.onNotLeader(libraryId.getAsInt(), connectCorrelationId.getAsLong(), LEADER_CHANNEL);
                return 1;
            })
        .then(replyWithApplicationHeartbeat())
        .then(noReply());

    newLibraryPoller(CLUSTER_CHANNELS);

    library.startConnecting();

    pollTwice();

    poll();

    attemptToConnectTo(channels);
    verify(connectHandler).onConnect(fixLibrary);
}
 
開發者ID:real-logic,項目名稱:artio,代碼行數:27,代碼來源:LibraryPollerTest.java

示例13: from

import java.util.function.LongSupplier; //導入依賴的package包/類
/** Creates a `Box.Long` from a `LongSupplier` and a `LongConsumer`. */
public static Lng from(LongSupplier getter, LongConsumer setter) {
	return new Lng() {
		@Override
		public long getAsLong() {
			return getter.getAsLong();
		}

		@Override
		public void set(long value) {
			setter.accept(value);
		}

		@Override
		public String toString() {
			return "Box.Long.from[" + get() + "]";
		}
	};
}
 
開發者ID:diffplug,項目名稱:durian,代碼行數:20,代碼來源:Box.java

示例14: createCustomMetric

import java.util.function.LongSupplier; //導入依賴的package包/類
@Override
public synchronized void createCustomMetric(String name, String description, String kind, LongSupplier value) {
    
    LongSupplier supplier = requireNonNull(value);
    Metric cm = context.getMetrics().createCustomMetric(
            requireNonNull(name),
            requireNonNull(description),
            Metric.Kind.valueOf(kind.toUpperCase(Locale.US)));
    cm.setValue(supplier.getAsLong());
    
    if (metrics == null) {
        metrics = new ArrayList<>();
        
        metricsGetter = getScheduledExecutorService().scheduleWithFixedDelay(this::updateMetrics,
                1, 1, TimeUnit.SECONDS);
    }
    
    metrics.add(() -> cm.setValue(supplier.getAsLong()));
}
 
開發者ID:IBMStreams,項目名稱:streamsx.topology,代碼行數:20,代碼來源:FunctionOperatorContext.java

示例15: awaitOnLatch

import java.util.function.LongSupplier; //導入依賴的package包/類
private void awaitOnLatch(CountDownLatch countDownLatch, LongSupplier nanosRemaining) throws TimeoutException {
  boolean interrupted = Thread.interrupted();
  try {
    while (true) {
      try {
        if (countDownLatch.await(nanosRemaining.getAsLong(), TimeUnit.NANOSECONDS)) {
          if (!entity.isConnected()) {
            throw new IllegalStateException("Cluster tier manager disconnected");
          } else {
            return;
          }
        } else {
          throw new TimeoutException();
        }
      } catch (InterruptedException e) {
        interrupted = true;
      }
    }
  } finally {
    if (interrupted) {
      Thread.currentThread().interrupt();
    }
  }
}
 
開發者ID:ehcache,項目名稱:ehcache3,代碼行數:25,代碼來源:StrongServerStoreProxy.java


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