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


Java ThreadLocalRandom.current方法代碼示例

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


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

示例1: createRandomStringBasedOnTimestamp

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
/**
 * 根據當前時間(hour)戳創建字符串,包括8位隨機字符串和時間戳
 * 
 * @return
 * @throws UnsupportedEncodingException 
 */
public static String createRandomStringBasedOnTimestamp(int type) throws UnsupportedEncodingException{

    String timestampStr = createTimestampStr(type);
    
    
    Random random = ThreadLocalRandom.current();
    int p = random.nextInt(8-1);
    int length = 8+timestampStr.length();
    StringBuffer strBuffer = new StringBuffer(length);
    
    
    for(int i=0;i<length;i++){
        strBuffer.append(base[random.nextInt(base.length)]);
        if(i==p){
            strBuffer.append(timestampStr);
        }
    }
    return strBuffer.toString();
    
}
 
開發者ID:sylinklee,項目名稱:netto_rpc,代碼行數:27,代碼來源:RandomStrGenerator.java

示例2: handleDiceRoll

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
private void handleDiceRoll(@NotNull MessageReceivedEvent event, @NotNull List<String> args) {
    int upper = Integer.parseUnsignedInt(args.get(0).substring(2));
    int iterations = 1;
    if (args.size() > 1 && INT_PATTERN.matcher(args.get(1)).find()) {
        iterations = Math.min(12, Integer.parseUnsignedInt(args.get(1)));
    }
    int sIterations = iterations;
    ThreadLocalRandom random = ThreadLocalRandom.current();
    EmbedBuilder builder = MessageUtils.getEmbedBuilder(event.getMessage().getAuthor());
    int sum = 0;
    while (iterations-- != 0) {
        int num = random.nextInt(1, upper + 1);
        sum += num;
        builder.appendField(":game_die: [1," + upper + "]", num + "", true);
    }
    builder.withTitle("Tossed " + sIterations + (sIterations == 1 ? " dice" : " dices"));
    builder.withDescription("Average result: " + (sum / sIterations));

    sendThenDelete(MessageUtils.getMessageBuilder(event.getMessage())
            .withEmbed(builder.build()));
    delete(event.getMessage());
}
 
開發者ID:ViniciusArnhold,項目名稱:ProjectAltaria,代碼行數:23,代碼來源:RandomNumberCommand.java

示例3: newBuilderInstance

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
private static Builder newBuilderInstance() {
    ThreadLocalRandom random = ThreadLocalRandom.current();
    return new Builder(UUID.randomUUID().toString(),
            random.nextInt(),
            UUID.randomUUID().toString(),
            Instant.ofEpochMilli(random.nextLong(0, Instant.now().toEpochMilli())));
}
 
開發者ID:richardstartin,項目名稱:simdbenchmarks,代碼行數:8,代碼來源:HashSetContainsBenchmark.java

示例4: testNextIntBadBounds

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
/**
 * nextInt(least >= bound) throws IllegalArgumentException
 */
public void testNextIntBadBounds() {
    int[][] badBoundss = {
        { 17, 2 },
        { -42, -42 },
        { Integer.MAX_VALUE, Integer.MIN_VALUE },
    };
    ThreadLocalRandom rnd = ThreadLocalRandom.current();
    for (int[] badBounds : badBoundss) {
        try {
            rnd.nextInt(badBounds[0], badBounds[1]);
            shouldThrow();
        } catch (IllegalArgumentException success) {}
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:18,代碼來源:ThreadLocalRandomTest.java

示例5: testSortTaskDemo

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
/**
 * SortTask demo works as advertised
 */
public void testSortTaskDemo() {
    ThreadLocalRandom rnd = ThreadLocalRandom.current();
    long[] array = new long[1007];
    for (int i = 0; i < array.length; i++)
        array[i] = rnd.nextLong();
    long[] arrayClone = array.clone();
    testInvokeOnPool(mainPool(), new SortTask(array));
    Arrays.sort(arrayClone);
    assertTrue(Arrays.equals(array, arrayClone));
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:14,代碼來源:RecursiveActionTest.java

示例6: correctnessTesting

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
@Test
void correctnessTesting() throws Exception {
    ThreadLocalRandom random = ThreadLocalRandom.current();
    for(int i = 0; i < 20; i++) {
        ZipfDistribution zipf = new ZipfDistribution(random.nextDouble(), 1000);

        long[] original = zipf.stream().limit(2000).asLongStream().toArray();
        verifyCompression(original, -1);
    }
}
 
開發者ID:burmanm,項目名稱:compression-int,代碼行數:11,代碼來源:Simple8EncodeTest.java

示例7: spread

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
private void spread() {
    World world = GameState.getGameWorld();
    ThreadLocalRandom random = ThreadLocalRandom.current();
    int spreadSize = UHC.getInstance().getMainConfig().getWorldBorderInitialSize();
    Stream<? extends Player> players = Bukkit.getServer().getOnlinePlayers().stream().filter(player -> player.getGameMode() != GameMode.SPECTATOR);

    players.forEach(player -> player.teleport(generateSafe(spreadSize, world, random)));
}
 
開發者ID:Project-Coalesce,項目名稱:UHC,代碼行數:9,代碼來源:GameInitializeHandler.java

示例8: testUnsizedDoublesCountSeq

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
/**
 * A sequential unsized stream of doubles generates at least 100 values
 */
public void testUnsizedDoublesCountSeq() {
    LongAdder counter = new LongAdder();
    ThreadLocalRandom r = ThreadLocalRandom.current();
    long size = 100;
    r.doubles().limit(size).forEach(x -> {
        counter.increment();
    });
    assertEquals(counter.sum(), size);
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:13,代碼來源:ThreadLocalRandomTest.java

示例9: randomMetric

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
public static Metric randomMetric(int numMetrics, int numDimensions, int numLabels) {
  ThreadLocalRandom r = ThreadLocalRandom.current();
  int i = r.nextInt(0, numMetrics);
  int[] labs = new int[numDimensions];
  for (int j = 0; j < numDimensions; j++) {
    labs[j] = r.nextInt(0, numLabels);
  }
  return metric(i, labs);
}
 
開發者ID:pinterest,項目名稱:yuvi,代碼行數:10,代碼來源:InvertedIndexTagStoreBenchmark.java

示例10: nextString

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
/**
 * Generates a random string of a length with a range, inclusive on either end.
 * @param min   min length
 * @param max   max length
 * @return a random string whose length is with the provided boundaries (inclusive)
 */
public static String nextString(Integer min, Integer max) {
    int length = stringLength(adjustStringLength(min), adjustStringLength(max));

    StringBuilder sb = new StringBuilder(length);
    Random random = ThreadLocalRandom.current();
    for (int i = 0; i < length; i++) {
        sb.append(RAND_CHARS.charAt(random.nextInt(RAND_CHARS.length())));
    }
    return sb.toString();
}
 
開發者ID:zezutom,項目名稱:schematic,代碼行數:17,代碼來源:RandomUtil.java

示例11: testLongsCount

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
/**
 * A parallel sized stream of longs generates the given number of values
 */
public void testLongsCount() {
    LongAdder counter = new LongAdder();
    ThreadLocalRandom r = ThreadLocalRandom.current();
    long size = 0;
    for (int reps = 0; reps < REPS; ++reps) {
        counter.reset();
        r.longs(size).parallel().forEach(x -> counter.increment());
        assertEquals(size, counter.sum());
        size += 524959;
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:15,代碼來源:ThreadLocalRandom8Test.java

示例12: setup

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
public void setup() {
    input = new GeoCoordTuple[size];
    ThreadLocalRandom random = ThreadLocalRandom.current();
    for (int i = 0; i < size; i++) {
        input[i] = new GeoCoordTuple(
                getLat(random),
                getLong(random),
                getLat(random),
                getLong(random)
        );
    }
}
 
開發者ID:RWTH-i5-IDSG,項目名稱:xsharing-services-router,代碼行數:13,代碼來源:DistanceCalcBenchmark.java

示例13: testUnsizedDoublesCountSeq

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
/**
 * A sequential unsized stream of doubles generates at least 100 values
 */
public void testUnsizedDoublesCountSeq() {
    LongAdder counter = new LongAdder();
    ThreadLocalRandom r = ThreadLocalRandom.current();
    long size = 100;
    r.doubles().limit(size).forEach(x -> counter.increment());
    assertEquals(size, counter.sum());
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:11,代碼來源:ThreadLocalRandom8Test.java

示例14: testUnsizedLongsCountSeq

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
/**
 * A sequential unsized stream of longs generates at least 100 values
 */
public void testUnsizedLongsCountSeq() {
    LongAdder counter = new LongAdder();
    ThreadLocalRandom r = ThreadLocalRandom.current();
    long size = 100;
    r.longs().limit(size).forEach(x -> counter.increment());
    assertEquals(size, counter.sum());
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:11,代碼來源:ThreadLocalRandom8Test.java

示例15: generator

import java.util.concurrent.ThreadLocalRandom; //導入方法依賴的package包/類
public static String generator(String dbName, String tblName, long beginTime, long endTime)
{
    ConsumerConfig config = ConsumerConfig.INSTANCE();
    String hdfsWarehouse = config.getHDFSWarehouse();
    ThreadLocalRandom tlr = ThreadLocalRandom.current();
    long random = tlr.nextLong();
    return String.format("%s/%s/%s/%s-%s-%d%d%d", hdfsWarehouse, dbName, tblName, dbName, tblName, beginTime, endTime, random);
}
 
開發者ID:dbiir,項目名稱:paraflow,代碼行數:9,代碼來源:FileNameGenerator.java


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