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


Java ConcurrentHashMap.get方法代碼示例

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


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

示例1: getQueryStats

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
protected QueryStats getQueryStats(String sql) {
    if (sql==null) sql = "";
    ConcurrentHashMap<String,QueryStats> queries = SlowQueryReport.this.queries;
    if (queries==null) {
        if (log.isWarnEnabled()) log.warn("Connection has already been closed or abandoned");
        return null;
    }
    QueryStats qs = queries.get(sql);
    if (qs == null) {
        qs = new QueryStats(sql);
        if (queries.putIfAbsent(sql,qs)!=null) {
            qs = queries.get(sql);
        } else {
            //we added a new element, see if we need to remove the oldest
            if (queries.size() > maxQueries) {
                removeOldest(queries);
            }
        }
    }
    return qs;
}
 
開發者ID:liaokailin,項目名稱:tomcat7,代碼行數:22,代碼來源:SlowQueryReport.java

示例2: FileTailer

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
public FileTailer(IFileTailerListener listener, ConcurrentHashMap<String, String> prop) {
	this.listener = listener;
	this.prop = prop;
	/**
	 * 對n個source實例,配置n個快照文件
	 */
	this.snapShotMarkDirPath = prop.get("backupFileDirPath");
	this.snapShotMarkPath = prop.get("backupFileDirPath")+File.separator+"mark.txt";
	this.backupDB = new MD5File(snapShotMarkDirPath);
	this.clearTimeInterval = Long.parseLong(prop.get("clearTimeInterval"));
	pattern = Pattern.compile(prop.get("regexFileName"));//必須能匹配上實時文件,也能匹配由實時文件產生的新文件
	this.tailFile = new File(prop.get("fileRootDir")+File.separator+prop.get("filePrefix")+prop.get("fileSuffix"));
	logger.info("開始執行:initMarkData()");
	try {
		this.initMarkData();
	} catch (IOException e) {
		logger.error("加載本地快照文件失敗!",e);
	}
	logger.info("結束執行:initMarkData()");
}
 
開發者ID:dimensoft,項目名稱:improved-journey,代碼行數:21,代碼來源:FileTailer.java

示例3: isLocked

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
private boolean isLocked(final String group, final MessageQueue mq, final String clientId) {
    ConcurrentHashMap<MessageQueue, LockEntry> groupValue = this.mqLockTable.get(group);
    if (groupValue != null) {
        LockEntry lockEntry = groupValue.get(mq);
        if (lockEntry != null) {
            boolean locked = lockEntry.isLocked(clientId);
            if (locked) {
                lockEntry.setLastUpdateTimestamp(System.currentTimeMillis());
            }

            return locked;
        }
    }

    return false;
}
 
開發者ID:lirenzuo,項目名稱:rocketmq-rocketmq-all-4.1.0-incubating,代碼行數:17,代碼來源:RebalanceLockManager.java

示例4: isLocked

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * LockEntry 為consumer端 clientId 的實體,該方法用來判斷group下的mq是否被
 * 指定的clientId鎖著,並且獲取鎖不過時
 * @param group
 * @param mq
 * @param clientId
 * @return
 */
private boolean isLocked(final String group, final MessageQueue mq, final String clientId) {
    ConcurrentHashMap<MessageQueue, LockEntry> groupValue = this.mqLockTable.get(group);
    if (groupValue != null) {
        LockEntry lockEntry = groupValue.get(mq);
        if (lockEntry != null) {
            boolean locked = lockEntry.isLocked(clientId);
            if (locked) {
                lockEntry.setLastUpdateTimestamp(System.currentTimeMillis());
            }

            return locked;
        }
    }

    return false;
}
 
開發者ID:lyy4j,項目名稱:rmq4note,代碼行數:25,代碼來源:RebalanceLockManager.java

示例5: registerCompositeFont

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
protected static void registerCompositeFont(String compositeName,
                                            String[] componentFileNames,
                                            String[] componentNames,
                                            int numMetricsSlots,
                                            int[] exclusionRanges,
                                            int[] exclusionMaxIndex,
                                            boolean defer,
                                            ConcurrentHashMap<String, Font2D>
                                            altNameCache) {

    CompositeFont cf = new CompositeFont(compositeName,
                                         componentFileNames,
                                         componentNames,
                                         numMetricsSlots,
                                         exclusionRanges,
                                         exclusionMaxIndex, defer,
                                         SunFontManager.getInstance());

    /* if the cache has an existing composite for this case, make
     * its handle point to this new font.
     * This ensures that when the altNameCache that is passed in
     * is the global mapNameCache - ie we are running as an application -
     * that any statically created java.awt.Font instances which already
     * have a Font2D instance will have that re-directed to the new Font
     * on subsequent uses. This is particularly important for "the"
     * default font instance, or similar cases where a UI toolkit (eg
     * Swing) has cached a java.awt.Font. Note that if Swing is using
     * a custom composite APIs which update the standard composites have
     * no effect - this is typically the case only when using the Windows
     * L&F where these APIs would conflict with that L&F anyway.
     */
    Font2D oldFont =altNameCache.get(compositeName.toLowerCase(Locale.ENGLISH));
    if (oldFont instanceof CompositeFont) {
        oldFont.handle.font2D = cf;
    }
    altNameCache.put(compositeName.toLowerCase(Locale.ENGLISH), cf);
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:38,代碼來源:SunFontManager.java

示例6: 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

示例7: updateMethodInSet

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * Update methods in set.
 *
 * @param targetObject    the target object.
 * @param subscribeMethod the subscribe method.
 * @param mTargetMap      the target map.
 */
private void updateMethodInSet(Object targetObject,
                               SubscriberHolder subscribeMethod,
                               ConcurrentHashMap<Object, ConcurrentHashMap<String,
                                       SubscriberHolder>> mTargetMap) {
    ConcurrentHashMap<String, SubscriberHolder> methodSet = mTargetMap.get(targetObject);
    methodSet.put(subscribeMethod.getKeyForSubscribeHolderMap(), subscribeMethod);
}
 
開發者ID:MindorksOpenSource,項目名稱:NYBus,代碼行數:15,代碼來源:NYBusDriver.java

示例8: registerCompositeFont

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
protected static void registerCompositeFont(String compositeName,
                                            String[] componentFileNames,
                                            String[] componentNames,
                                            int numMetricsSlots,
                                            int[] exclusionRanges,
                                            int[] exclusionMaxIndex,
                                            boolean defer,
                                            ConcurrentHashMap<String, Font2D>
                                            altNameCache) {

    CompositeFont cf = new CompositeFont(compositeName,
                                         componentFileNames,
                                         componentNames,
                                         numMetricsSlots,
                                         exclusionRanges,
                                         exclusionMaxIndex, defer,
                                         SunFontManager.getInstance());

    /* if the cache has an existing composite for this case, make
     * its handle point to this new font.
     * This ensures that when the altNameCache that is passed in
     * is the global mapNameCache - ie we are running as an application -
     * that any statically created java.awt.Font instances which already
     * have a Font2D instance will have that re-directed to the new Font
     * on subsequent uses. This is particularly important for "the"
     * default font instance, or similar cases where a UI toolkit (eg
     * Swing) has cached a java.awt.Font. Note that if Swing is using
     * a custom composite APIs which update the standard composites have
     * no effect - this is typically the case only when using the Windows
     * L&F where these APIs would conflict with that L&F anyway.
     */
    Font2D oldFont = (Font2D)
        altNameCache.get(compositeName.toLowerCase(Locale.ENGLISH));
    if (oldFont instanceof CompositeFont) {
        oldFont.handle.font2D = cf;
    }
    altNameCache.put(compositeName.toLowerCase(Locale.ENGLISH), cf);
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:39,代碼來源:SunFontManager.java

示例9: queryOffset

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
public long queryOffset(final String group, final String topic, final int queueId) {
    // [email protected]
    String key = topic + TOPIC_GROUP_SEPARATOR + group;
    ConcurrentHashMap<Integer, Long> map = this.offsetTable.get(key);
    if (null != map) {
        Long offset = map.get(queueId);
        if (offset != null)
            return offset;
    }

    return -1;
}
 
開發者ID:lyy4j,項目名稱:rmq4note,代碼行數:13,代碼來源:ConsumerOffsetManager.java

示例10: doSubscribe

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
@Override
protected void doSubscribe(final URL url, final NotifyListener listener) {
    try {
        clientLock.lock();

        ConcurrentHashMap<NotifyListener, IZkChildListener> childChangeListeners = serviceListeners.get(url);
        if (childChangeListeners == null) {
            serviceListeners.putIfAbsent(url, new ConcurrentHashMap<NotifyListener, IZkChildListener>());
            childChangeListeners = serviceListeners.get(url);
        }
        IZkChildListener zkChildListener = childChangeListeners.get(listener);
        if (zkChildListener == null) {
            childChangeListeners.putIfAbsent(listener, new IZkChildListener() {
                @Override
                public void handleChildChange(String parentPath, List<String> currentChilds) {

                    listener.notify(getUrl(), childrenNodeToUrls(parentPath, currentChilds));
                    logger.info(String.format("[ZookeeperRegistry] service list change: path=%s, currentChilds=%s", parentPath, currentChilds.toString()));
                }
            });
            zkChildListener = childChangeListeners.get(listener);
        }

        // 防止舊節點未正常注銷
        removeNode(url, ZkNodeType.CLIENT);
        createNode(url, ZkNodeType.CLIENT);

        String serverTypePath = ZkUtils.toNodeTypePath(url, ZkNodeType.SERVER);
        zkClient.subscribeChildChanges(serverTypePath, zkChildListener);
        logger.info(String.format("[ZookeeperRegistry] subscribe service: path=%s, info=%s", ZkUtils.toNodePath(url, ZkNodeType.SERVER), url.toFullUri()));
    } catch (Throwable e) {
        throw new RpcFrameworkException(String.format("Failed to subscribe %s to zookeeper(%s), cause: %s", url, getUrl(), e.getMessage()), e);
    } finally {
        clientLock.unlock();
    }
}
 
開發者ID:TFdream,項目名稱:mango,代碼行數:37,代碼來源:ZookeeperRegistry.java

示例11: tryLock

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
public boolean tryLock(final String group, final MessageQueue mq, final String clientId) {

        if (!this.isLocked(group, mq, clientId)) {
            try {
                this.lock.lockInterruptibly();
                try {
                    ConcurrentHashMap<MessageQueue, LockEntry> groupValue = this.mqLockTable.get(group);
                    if (null == groupValue) {
                        groupValue = new ConcurrentHashMap<>(32);
                        this.mqLockTable.put(group, groupValue);
                    }

                    LockEntry lockEntry = groupValue.get(mq);
                    if (null == lockEntry) {
                        lockEntry = new LockEntry();
                        lockEntry.setClientId(clientId);
                        groupValue.put(mq, lockEntry);
                        log.info("tryLock, message queue not locked, I got it. Group: {} NewClientId: {} {}", //
                            group, //
                            clientId, //
                            mq);
                    }

                    if (lockEntry.isLocked(clientId)) {
                        lockEntry.setLastUpdateTimestamp(System.currentTimeMillis());
                        return true;
                    }

                    String oldClientId = lockEntry.getClientId();

                    if (lockEntry.isExpired()) {
                        lockEntry.setClientId(clientId);
                        lockEntry.setLastUpdateTimestamp(System.currentTimeMillis());
                        log.warn(
                            "tryLock, message queue lock expired, I got it. Group: {} OldClientId: {} NewClientId: {} {}", //
                            group, //
                            oldClientId, //
                            clientId, //
                            mq);
                        return true;
                    }

                    log.warn(
                        "tryLock, message queue locked by other client. Group: {} OtherClientId: {} NewClientId: {} {}", //
                        group, //
                        oldClientId, //
                        clientId, //
                        mq);
                    return false;
                } finally {
                    this.lock.unlock();
                }
            } catch (InterruptedException e) {
                log.error("putMessage exception", e);
            }
        } else {

        }

        return true;
    }
 
開發者ID:lyy4j,項目名稱:rmq4note,代碼行數:62,代碼來源:RebalanceLockManager.java

示例12: get

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
public V get(K1 key1, K2 key2) {
    ConcurrentHashMap<K2, V> k2_v = k1_k2V_map.get(key1);
    return k2_v == null ? null : k2_v.get(key2);
}
 
開發者ID:weiwenqiang,項目名稱:GitHub,代碼行數:5,代碼來源:DoubleKeyValueMap.java

示例13: updateTmpFm

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * Update the tmp Fm by using the keyword
 * @param keyword 
 */
private void updateTmpFm(String keyword) {
    tmpFm.emptyAll();
    ConcurrentHashMap<String, ConcurrentSkipListSet<Market>> data = fm.getFinancialMarketData();
    String marketCode = selectedMarketProperty.getValue().toUpperCase();
    String marketType = selectedMarketTypeProperty.getValue();
    if (marketCode == null || marketCode.isEmpty()) {
        //do nothing
        return;
    }
    else {
        if (data.get(marketType) != null) {
            Market market = fm.getMarket(selectedMarketTypeProperty.getValue(), marketCode);
            
            if (market == null) {
                //do nothing
                return;
            } else {
                Iterator<String> iterator = market.getData().keySet().iterator();
                while (iterator.hasNext()) {
                    String OHLCCode = iterator.next();
                    if (OHLCCode.startsWith(keyword)){
                        if (tmpFm.getMarket(selectedMarketTypeProperty.getValue(), marketCode) == null){
                            Market tmpMarket = new Market(marketCode, market.getChartType(), market.getCountryName());
                            tmpFm.addMarket(selectedMarketTypeProperty.getValue(), tmpMarket);
                        }
                        Iterator<OHLC> ohlcIterator = market.getOHLC(OHLCCode).iterator();
                        while(ohlcIterator.hasNext()) {
                            if (tmpFm.getMarket(marketType, marketCode) != null) {
                                tmpFm.getMarket(marketType, marketCode).addOHLC(OHLCCode, ohlcIterator.next());
                            }else {
                                tmpFm.initMarket(marketType, marketCode, market.getCountryName(), market.getChartType());
                                tmpFm.getMarket(marketType, marketCode).addOHLC(OHLCCode, ohlcIterator.next());
                            }
                        }
                    }
                }
            }
        }
        else {
            //do nothing
            return;
        }
    }
}
 
開發者ID:ztan5,項目名稱:TechnicalAnalysisTool,代碼行數:49,代碼來源:MarketDataTreeViewNode.java

示例14: processUpdateEncryption

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
protected void processUpdateEncryption(TLRPC.TL_updateEncryption update, ConcurrentHashMap<Integer, TLRPC.User> usersDict) {
    final TLRPC.EncryptedChat newChat = update.chat;
    long dialog_id = ((long) newChat.id) << 32;
    TLRPC.EncryptedChat existingChat = MessagesController.getInstance().getEncryptedChatDB(newChat.id);

    if (newChat instanceof TLRPC.TL_encryptedChatRequested && existingChat == null) {
        int user_id = newChat.participant_id;
        if (user_id == UserConfig.getClientUserId()) {
            user_id = newChat.admin_id;
        }
        TLRPC.User user = MessagesController.getInstance().getUser(user_id);
        if (user == null) {
            user = usersDict.get(user_id);
        }
        newChat.user_id = user_id;
        final TLRPC.TL_dialog dialog = new TLRPC.TL_dialog();
        dialog.id = dialog_id;
        dialog.unread_count = 0;
        dialog.top_message = 0;
        dialog.last_message_date = update.date;

        AndroidUtilities.runOnUIThread(new Runnable() {
            @Override
            public void run() {
                MessagesController.getInstance().dialogs_dict.put(dialog.id, dialog);
                MessagesController.getInstance().dialogs.add(dialog);
                MessagesController.getInstance().putEncryptedChat(newChat, false);
                MessagesController.getInstance().sortDialogs(null);
                NotificationCenter.getInstance().postNotificationName(NotificationCenter.dialogsNeedReload);
            }
        });
        MessagesStorage.getInstance().putEncryptedChat(newChat, user, dialog);
        SecretChatHelper.getInstance().acceptSecretChat(newChat);
    } else if (newChat instanceof TLRPC.TL_encryptedChat) {
        if (existingChat != null && existingChat instanceof TLRPC.TL_encryptedChatWaiting && (existingChat.auth_key == null || existingChat.auth_key.length == 1)) {
            newChat.a_or_b = existingChat.a_or_b;
            newChat.user_id = existingChat.user_id;
            SecretChatHelper.getInstance().processAcceptedSecretChat(newChat);
        } else if (existingChat == null && startingSecretChat) {
            delayedEncryptedChatUpdates.add(update);
        }
    } else {
        final TLRPC.EncryptedChat exist = existingChat;
        if (exist != null) {
            newChat.user_id = exist.user_id;
            newChat.auth_key = exist.auth_key;
            newChat.key_create_date = exist.key_create_date;
            newChat.key_use_count_in = exist.key_use_count_in;
            newChat.key_use_count_out = exist.key_use_count_out;
            newChat.ttl = exist.ttl;
            newChat.seq_in = exist.seq_in;
            newChat.seq_out = exist.seq_out;
        }
        AndroidUtilities.runOnUIThread(new Runnable() {
            @Override
            public void run() {
                if (exist != null) {
                    MessagesController.getInstance().putEncryptedChat(newChat, false);
                }
                MessagesStorage.getInstance().updateEncryptedChat(newChat);
                NotificationCenter.getInstance().postNotificationName(NotificationCenter.encryptedChatUpdated, newChat);
            }
        });
    }
}
 
開發者ID:MLNO,項目名稱:airgram,代碼行數:66,代碼來源:SecretChatHelper.java

示例15: manageCache

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
private <T> T manageCache(ConcurrentHashMap<Integer, WithUseCount<T>> cache, Accessor<T> accessor, int n, FieldSelector fieldSelector, int limit) throws IOException
{
    Integer key = Integer.valueOf(n);
    WithUseCount<T> value = cache.get(key);
    if (value == null)
    {
        T made = accessor.get(n, fieldSelector);
        value = new WithUseCount<T>(made, n);
        cache.put(key, value);

        // resize

        if (limit >= 0)
        {
            if (cache.size() >= limit)
            {
                HashMap<Integer, WithUseCount<T>> keep = new HashMap<Integer, WithUseCount<T>>();
                WithUseCount<T>[] existing = new WithUseCount[0];
                synchronized (cache)
                {
                    existing = cache.values().toArray(existing);
                    cache.clear();
                }
                Arrays.sort(existing);

                for (WithUseCount<T> current : existing)
                {
                    keep.put(Integer.valueOf(current.doc), current);
                    if ((current.count.get() == 0) || (keep.size() > (limit / 4)))
                    {
                        break;
                    }
                }
                keep.put(key, value);
                cache.putAll(keep);
            }
        }
    }
    else
    {
        value.count.getAndIncrement();
    }
    return value.object;
}
 
開發者ID:Alfresco,項目名稱:alfresco-repository,代碼行數:45,代碼來源:ReferenceCountingReadOnlyIndexReaderFactory.java


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