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


Java ConcurrentHashMap.computeIfAbsent方法代碼示例

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


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

示例1: testcomputeIfAbsent_performance

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * Tests performance of computeIfAbsent when the element is present.
 * See JDK-8161372
 * ant -Djsr166.tckTestClass=ConcurrentHashMapTest -Djsr166.methodFilter=testcomputeIfAbsent_performance -Djsr166.expensiveTests=true tck
 */
public void testcomputeIfAbsent_performance() {
    final int mapSize = 20;
    final int iterations = expensiveTests ? (1 << 23) : mapSize * 2;
    final int threads = expensiveTests ? 10 : 2;
    final ConcurrentHashMap<Integer, Integer> map = new ConcurrentHashMap<>();
    for (int i = 0; i < mapSize; i++)
        map.put(i, i);
    final ExecutorService pool = Executors.newFixedThreadPool(2);
    try (PoolCleaner cleaner = cleaner(pool)) {
        Runnable r = new CheckedRunnable() {
            public void realRun() {
                int result = 0;
                for (int i = 0; i < iterations; i++)
                    result += map.computeIfAbsent(i % mapSize, k -> k + k);
                if (result == -42) throw new Error();
            }};
        for (int i = 0; i < threads; i++)
            pool.execute(r);
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:26,代碼來源:ConcurrentHashMap8Test.java

示例2: addBlankFile

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
public void addBlankFile(BlankFileMessage blankFileMessage) {
    int clientId = blankFileMessage.getClientId();
    int fileId = blankFileMessage.getFileId();

    Client client = clients.get(clientId);
    File clientFile = getOrCreateClientFile(fileId, client);

    ConcurrentHashMap<Long, Region> clientRegions = clientFile.getRegions();
    ConcurrentHashMap<Long, Region> serverRegions = files.get(fileId).getRegions();

    byte[] emptyByteArrayRegionSize = new byte[(int) REGION_SIZE];
    byte[] slowDigestForWholeEmptyRegion = Base64.getEncoder().encode(emptyByteArrayRegionSize);

    for (Region serverRegion : serverRegions.values()) {
        long offset = serverRegion.getOffset();
        long size = serverRegion.getSize();

        Region region = clientRegions.computeIfAbsent(offset, (aLong) ->
                new Region(offset, size));
        region.setQuickDigest(0);
        if(region.getSize() == REGION_SIZE) {
            region.setSlowDigest(slowDigestForWholeEmptyRegion);
        } else {
            byte[] emptyArraySmallerSize = new byte[(int) region.getSize()];
            region.setSlowDigest(
                    Base64.getEncoder()
                            .encode(emptyArraySmallerSize));
        }
    }
}
 
開發者ID:gaganis,項目名稱:odoxSync,代碼行數:31,代碼來源:DirectorySynchronizer.java

示例3: main

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
public static void main(String[] args) {
    ArrayList<String> list = new ArrayList<>(Arrays.asList("I", "love", "you", "too"));

    list.removeIf(new Predicate<String>() {
        @Override
        public boolean test(String s) {
            if (s.length() < 2) {

                return true;
            }
            return false;
        }
    });
    list.removeIf(l -> l.length() < 4);
    System.out.println(JSON.toJSONString(list));
    Date date = new Date();

    ConcurrentHashMap concurrentHashMap = new ConcurrentHashMap<>();
    concurrentHashMap.put("ds", 1);
    concurrentHashMap.computeIfAbsent("fdfd", k -> k.toString());
    System.out.println(JSON.toJSONString(concurrentHashMap));
    HashMap hashMap = new HashMap<>();
    hashMap.put("fd1", 1);
    hashMap.put("fd2", 1);
    hashMap.put("fd3", 1);
    hashMap.put("fd4", "fd");
    hashMap.put("fd5", 1);
    hashMap.entrySet().stream().forEach(hash -> {
        System.out.println(hash.toString());
    });
}
 
開發者ID:wxz1211,項目名稱:dooo,代碼行數:32,代碼來源:WashMap.java

示例4: testComputeIfAbsent

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * computeIfAbsent adds when the given key is not present
 */
public void testComputeIfAbsent() {
    ConcurrentHashMap map = map5();
    map.computeIfAbsent(six, x -> "Z");
    assertTrue(map.containsKey(six));
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:9,代碼來源:ConcurrentHashMap8Test.java

示例5: testComputeIfAbsent3

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * computeIfAbsent does not add if function returns null
 */
public void testComputeIfAbsent3() {
    ConcurrentHashMap map = map5();
    map.computeIfAbsent(six, x -> null);
    assertFalse(map.containsKey(six));
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:9,代碼來源:ConcurrentHashMap8Test.java

示例6: getClientRegion

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
private Region getClientRegion(int clientId, int fileId, long offset) {
    Client client = clients.get(clientId);

    File clientFile = getOrCreateClientFile(fileId, client);

    Region serverRegion = files.get(fileId).getRegions().get(offset);

    ConcurrentHashMap<Long, Region> clientRegions = clientFile.getRegions();
    return clientRegions.computeIfAbsent(offset, (aLong) -> new Region(serverRegion.getOffset(), serverRegion.getSize()));
}
 
開發者ID:gaganis,項目名稱:odoxSync,代碼行數:11,代碼來源:DirectorySynchronizer.java

示例7: addOperationToHash

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
private void addOperationToHash(ConcurrentHashMap<String, ConcurrentLinkedDeque<Operation>> userHash,
		Operation operation) {

	ConcurrentLinkedDeque<Operation> opList = userHash.computeIfAbsent(operation.getUser(), user -> new ConcurrentLinkedDeque<>());

	opList.add(operation);

}
 
開發者ID:PacktPublishing,項目名稱:Java-9-Concurrency-Cookbook-Second-Edition,代碼行數:9,代碼來源:HashFiller.java


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