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


Java ConcurrentHashMap.values方法代碼示例

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


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

示例1: printUsage

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * Prints the applications help for available commands.
 *  @param out
 * @param commandList
 */
private void printUsage(final PrintStream out, final ConcurrentHashMap<String, Command> commandList) {
    out.println("Description:");
    out.println("  cljbuild is a clojure/jvm build too.");
    out.println("");
    out.println("Usage:");
    out.println("  cljbuild <command> [<command-options>]");
    out.println("");
    out.println("Available commands:");

    for (final Command c : commandList.values()) {
        final String target = c.getTarget();
        final int padLen = 14 - target.length();
        final char[] padding = new char[padLen];
        Arrays.fill(padding, ' ');

        out.print("  ");
        out.print(target);
        out.print(padding);
        out.print(" ");
        out.println(c.getDescription());
    }

    out.println("");
}
 
開發者ID:nfisher,項目名稱:cljbuck,代碼行數:30,代碼來源:Main.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: getIt

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * Method handling HTTP GET requests. The returned object will be sent
 * to the client as "text/plain" media type.
 *
 * @return String that will be returned as a text/plain response.
 */
@GET
@Produces(MediaType.APPLICATION_JSON)
public Map<Integer, List<FileProgress>> getIt() {
    ConcurrentHashMap<Integer, Client> clients = DirectorySynchronizer.INSTANCE.clients;
    ConcurrentHashMap<Integer, File> serverFiles = DirectorySynchronizer.INSTANCE.files;

    Map<Integer, List<FileProgress>> result = new HashMap<>();

    for (Client client : clients.values()) {

        List<FileProgress> fileProgresses = getFileProgresses(serverFiles, client);
        result.put(client.getId(), fileProgresses);
    }
    return result;
}
 
開發者ID:gaganis,項目名稱:odoxSync,代碼行數:22,代碼來源:Progress.java

示例4: getNeighborChildrenCount

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * we do it in a hack way.
 * travel the dom tree, to get how many children does this slider-neighbor have.
 *
 * @return
 */
private int getNeighborChildrenCount() {

    try {
        WXDomManager domManager = WXSDKManager.getInstance().getWXDomManager();
        Field domRegistriesField = domManager.getClass().getDeclaredField("mDomRegistries");
        domRegistriesField.setAccessible(true);
        ConcurrentHashMap<String, Object> domRegistriesMap = (ConcurrentHashMap<String, Object>) domRegistriesField.get(domManager);
        Object domStatement = domRegistriesMap.get(getInstanceId()); // WXDomStatement
        Field mRegistryField = domStatement.getClass().getDeclaredField("mRegistry");
        mRegistryField.setAccessible(true);
        ConcurrentHashMap<String, WXDomObject> mRegistryMap = (ConcurrentHashMap<String, WXDomObject>) mRegistryField.get(domStatement);
        for(WXDomObject domObject : mRegistryMap.values()) {
            if(domObject.getType().equalsIgnoreCase(WXBasicComponentType.SLIDER_NEIGHBOR)) {
                int sum = 0;
                for (int i = 0,count = domObject.getChildCount(); i < count; i++) {
                    if(domObject.getChild(i) instanceof WXIndicator.IndicatorDomNode) {
                        continue;
                    }
                    sum++;
                }
                return sum;
            }
        }
    } catch (Exception e) {
        // ignore
    }

    return -1;

}
 
開發者ID:erguotou520,項目名稱:weex-uikit,代碼行數:37,代碼來源:WXSliderNeighbor.java

示例5: cleanUnusedTopic

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
@Override
public int cleanUnusedTopic(Set<String> topics) {
    Iterator<Entry<String, ConcurrentHashMap<Integer, ConsumeQueue>>> it = this.consumeQueueTable.entrySet().iterator();
    while (it.hasNext()) {
        Entry<String, ConcurrentHashMap<Integer, ConsumeQueue>> next = it.next();
        String topic = next.getKey();
        if (!topics.contains(topic) && !topic.equals(ScheduleMessageService.SCHEDULE_TOPIC)) {
            ConcurrentHashMap<Integer, ConsumeQueue> queueTable = next.getValue();
            for (ConsumeQueue cq : queueTable.values()) {
                cq.destroy();
                log.info("cleanUnusedTopic: {} {} ConsumeQueue cleaned",//
                    cq.getTopic(), //
                    cq.getQueueId() //
                );

                this.commitLog.removeQueurFromTopicQueueTable(cq.getTopic(), cq.getQueueId());
            }
            it.remove();

            log.info("cleanUnusedTopic: {},topic destroyed", topic);
        }
    }

    return 0;
}
 
開發者ID:y123456yz,項目名稱:reading-and-annotate-rocketmq-3.4.6,代碼行數:26,代碼來源:DefaultMessageStore.java

示例6: removeOldest

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * Sort QueryStats by last invocation time
 * @param queries
 */
protected void removeOldest(ConcurrentHashMap<String,QueryStats> queries) {
    ArrayList<QueryStats> list = new ArrayList<QueryStats>(queries.values());
    Collections.sort(list, queryStatsComparator);
    int removeIndex = 0;
    while (queries.size() > maxQueries) {
        String sql = list.get(removeIndex).getQuery();
        queries.remove(sql);
        if (log.isDebugEnabled()) log.debug("Removing slow query, capacity reached:"+sql);
        removeIndex++;
    }
}
 
開發者ID:sunmingshuai,項目名稱:apache-tomcat-7.0.73-with-comment,代碼行數:16,代碼來源:SlowQueryReport.java

示例7: cleanUnusedTopic

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
@Override
public int cleanUnusedTopic(Set<String> topics) {
    Iterator<Entry<String, ConcurrentHashMap<Integer, ConsumeQueue>>> it = this.consumeQueueTable.entrySet().iterator();
    while (it.hasNext()) {
        Entry<String, ConcurrentHashMap<Integer, ConsumeQueue>> next = it.next();
        String topic = next.getKey();

        if (!topics.contains(topic) && !topic.equals(ScheduleMessageService.SCHEDULE_TOPIC)) {
            ConcurrentHashMap<Integer, ConsumeQueue> queueTable = next.getValue();
            for (ConsumeQueue cq : queueTable.values()) {
                cq.destroy();
                log.info("cleanUnusedTopic: {} {} ConsumeQueue cleaned", //
                    cq.getTopic(), //
                    cq.getQueueId() //
                );

                this.commitLog.removeQueueFromTopicQueueTable(cq.getTopic(), cq.getQueueId());
            }
            it.remove();

            log.info("cleanUnusedTopic: {},topic destroyed", topic);
        }
    }

    return 0;
}
 
開發者ID:lyy4j,項目名稱:rmq4note,代碼行數:27,代碼來源:DefaultMessageStore.java

示例8: recoverConsumeQueue

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
private void recoverConsumeQueue() {
    for (ConcurrentHashMap<Integer, ConsumeQueue> maps : this.consumeQueueTable.values()) {
        for (ConsumeQueue logic : maps.values()) {
            logic.recover();
        }
    }
}
 
開發者ID:lyy4j,項目名稱:rmq4note,代碼行數:8,代碼來源:DefaultMessageStore.java

示例9: recoverMessageQueue

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * recover topic message queue
 */
public void recoverMessageQueue() {
    for (ConcurrentHashMap<Integer, MessageQueueValue> mqs : mqMap.values()) {
        for (MessageQueueValue v : mqs.values()) {
            if (v.getMessageQueue() != null) {
                v.getMessageQueue().recover();
            }
        }
    }
}
 
開發者ID:taobaorun,項目名稱:LiQ,代碼行數:13,代碼來源:MessageQueueHolder.java

示例10: doFlush

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
private void doFlush(int retryTimes) {
    //獲取默認刷屏緩存頁大小   2
    int flushConsumeQueueLeastPages = DefaultMessageStore.this.getMessageStoreConfig().getFlushConsumeQueueLeastPages();

    if (retryTimes == RETRY_TIMES_OVER) {
        flushConsumeQueueLeastPages = 0;
    }

    long logicsMsgTimestamp = 0;

    //徹底刷屏間隔  1000 * 60
    int flushConsumeQueueThoroughInterval = DefaultMessageStore.this.getMessageStoreConfig().getFlushConsumeQueueThoroughInterval();
    long currentTimeMillis = System.currentTimeMillis();
    if (currentTimeMillis >= (this.lastFlushTimestamp + flushConsumeQueueThoroughInterval)) {
        this.lastFlushTimestamp = currentTimeMillis;
        flushConsumeQueueLeastPages = 0;
        //獲取存儲檢查點的物理消息時間戳
        logicsMsgTimestamp = DefaultMessageStore.this.getStoreCheckpoint().getLogicsMsgTimestamp();
    }

    ConcurrentHashMap<String, ConcurrentHashMap<Integer, ConsumeQueue>> tables = DefaultMessageStore.this.consumeQueueTable;

    for (ConcurrentHashMap<Integer, ConsumeQueue> maps : tables.values()) {
        //ConsumeQueue 自己維護物理存儲抽象類
        for (ConsumeQueue cq : maps.values()) {
            boolean result = false;
            for (int i = 0; i < retryTimes && !result; i++) {
                result = cq.flush(flushConsumeQueueLeastPages);
            }
        }
    }

    if (0 == flushConsumeQueueLeastPages) {
        if (logicsMsgTimestamp > 0) {
            DefaultMessageStore.this.getStoreCheckpoint().setLogicsMsgTimestamp(logicsMsgTimestamp);
        }
        DefaultMessageStore.this.getStoreCheckpoint().flush();
    }
}
 
開發者ID:lyy4j,項目名稱:rmq4note,代碼行數:40,代碼來源:DefaultMessageStore.java

示例11: execute

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
public static void execute(ManagerConnection c) {
    ByteBuffer buffer = c.allocate();

    // write header
    buffer = header.write(buffer, c,true);

    // write fields
    for (FieldPacket field : fields) {
        buffer = field.write(buffer, c,true);
    }

    // write eof
    buffer = eof.write(buffer, c,true);

    // write rows
    byte packetId = eof.packetId;     
    int i=0;
    Map<String, UserStat> statMap = UserStatAnalyzer.getInstance().getUserStatMap();
	for (UserStat userStat : statMap.values()) {
    	String user = userStat.getUser();        
    	ConcurrentHashMap<String, SqlResultSet> map=userStat.getSqlResultSizeRecorder().getSqlResultSet();
         if ( map != null ) { 
 	        for (SqlResultSet sqlResultSet:map.values()) {
 	        	RowDataPacket row = getRow(++i, user,sqlResultSet.getSql(), sqlResultSet.getCount(), sqlResultSet.getResultSetSize(),c.getCharset());
 	            row.packetId = ++packetId;
 	            buffer = row.write(buffer, c,true);
 	        }
         }
	}    
    // write last eof
    EOFPacket lastEof = new EOFPacket();
    lastEof.packetId = ++packetId;
    buffer = lastEof.write(buffer, c,true);

    // write buffer
    c.write(buffer);
}
 
開發者ID:huang-up,項目名稱:mycat-src-1.6.1-RELEASE,代碼行數:38,代碼來源:ShowSqlResultSet.java

示例12: addEdges

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
private void addEdges(final Tracer tracer, final MutableGraph<BuildRule> graph, final ConcurrentHashMap<String, BuildRule> nodeMap) {
    tracer.info(started(hashCode).toString());
    for (final BuildRule buildRuleV : nodeMap.values()) {
        for (final String predecessor : buildRuleV.getDeps()) {
            final BuildRule buildRuleU = nodeMap.get(predecessor);
            if (null == buildRuleU) {
                System.err.println("Unable to find " + predecessor);
                continue;
            }
            graph.putEdge(buildRuleU, buildRuleV);
        }
    }
    tracer.info(finished(hashCode).toString());
}
 
開發者ID:nfisher,項目名稱:cljbuck,代碼行數:15,代碼來源:Rules.java

示例13: truncateDirtyLogicFiles

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
public void truncateDirtyLogicFiles(long phyOffset) {
    ConcurrentHashMap<String, ConcurrentHashMap<Integer, ConsumeQueue>> tables = DefaultMessageStore.this.consumeQueueTable;

    for (ConcurrentHashMap<Integer, ConsumeQueue> maps : tables.values()) {
        for (ConsumeQueue logic : maps.values()) {
            logic.truncateDirtyLogicFiles(phyOffset);
        }
    }
}
 
開發者ID:lyy4j,項目名稱:rmq4note,代碼行數:10,代碼來源:DefaultMessageStore.java

示例14: destroyLogics

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
public void destroyLogics() {
    for (ConcurrentHashMap<Integer, ConsumeQueue> maps : this.consumeQueueTable.values()) {
        for (ConsumeQueue logic : maps.values()) {
            logic.destroy();
        }
    }
}
 
開發者ID:y123456yz,項目名稱:reading-and-annotate-rocketmq-3.4.6,代碼行數:8,代碼來源:DefaultMessageStore.java

示例15: recoverTopicQueueTable

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
private void recoverTopicQueueTable() {
    HashMap<String/* topic-queueid */, Long/* offset */> table = new HashMap<String, Long>(1024);
    long minPhyOffset = this.commitLog.getMinOffset();
    for (ConcurrentHashMap<Integer, ConsumeQueue> maps : this.consumeQueueTable.values()) {
        for (ConsumeQueue logic : maps.values()) {
            String key = logic.getTopic() + "-" + logic.getQueueId();
            table.put(key, logic.getMaxOffsetInQuque());
            logic.correctMinOffset(minPhyOffset);
        }
    }

    this.commitLog.setTopicQueueTable(table);
}
 
開發者ID:y123456yz,項目名稱:reading-and-annotate-rocketmq-3.4.6,代碼行數:14,代碼來源:DefaultMessageStore.java


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