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


Java ConcurrentHashMap.remove方法代碼示例

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


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

示例1: testMapClean

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
@Test
public void testMapClean() throws InterruptedException{
	ConcurrentHashMap<String, String> cache = new ConcurrentHashMap<String, String>();
	long lastCleanTimestamp = new Date().getTime();
	int cleanInterval = 2;
	cache.put("key1", "foo-" + new Date().getTime());
	Thread.sleep(500);
	cache.put("key2", "foo-" + new Date().getTime());
	Assert.assertEquals(cache.size(), 2);
	Thread.sleep(1700);
	long now = new Date().getTime();
	if((now-lastCleanTimestamp)/1000>=cleanInterval){
		lastCleanTimestamp = now;
		Iterator<Entry<String, String>> iter = cache.entrySet().iterator();
		while(iter.hasNext()){
			Entry<String, String> entry = iter.next();
			String key = entry.getKey();
			String value = entry.getValue();
			long valueTimestamp = Long.parseLong(value.substring(value.length()-13));
			if(valueTimestamp < now-cleanInterval*1000){
				cache.remove(key);
			}
		}
	}
	Assert.assertEquals(cache.size(), 1);
}
 
開發者ID:jweixin,項目名稱:jwx,代碼行數:27,代碼來源:TimeTest.java

示例2: cmnClearRegion

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
public void cmnClearRegion(long drId,
    ConcurrentHashMap<DiskStoreID, RegionVersionHolder<DiskStoreID>> memberToVersion) {
  DiskRegionView drv = getDiskRegionById(drId);
  if (drv.getClearRVV() == null) {
    this.ifLiveRecordCount++;
  }
  // otherwise previous clear is cancelled so don't change liveRecordCount
  this.ifTotalRecordCount++;

  DiskStoreID ownerId = parent.getDiskStoreID();
  // Create a fake RVV for clear purposes. We only need to memberToVersion information
  RegionVersionHolder<DiskStoreID> ownerExceptions = memberToVersion.remove(ownerId);
  long ownerVersion = ownerExceptions == null ? 0 : ownerExceptions.getVersion();
  RegionVersionVector rvv = new DiskRegionVersionVector(ownerId, memberToVersion, ownerVersion,
      new ConcurrentHashMap(), 0L, false, ownerExceptions);
  drv.setClearRVV(rvv);
}
 
開發者ID:ampool,項目名稱:monarch,代碼行數:18,代碼來源:DiskInitFile.java

示例3: removeMethodFromMethodsMap

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * Remove method from methods map.
 *
 * @param mTargetMap      the target map.
 * @param targetObject    the target object.
 * @param targetChannelId the target channel ids.
 */
private void removeMethodFromMethodsMap(ConcurrentHashMap<Object,
        ConcurrentHashMap<String, SubscriberHolder>> mTargetMap,
                                        Object targetObject,
                                        List<String> targetChannelId) {
    ConcurrentHashMap<String, SubscriberHolder> mSubscribedMethodsMap =
            mTargetMap.get(targetObject);
    for (Map.Entry<String, SubscriberHolder> mSubscribedMethodsMapEntry :
            mSubscribedMethodsMap.entrySet()) {
        SubscriberHolder subscribedMethod = mSubscribedMethodsMapEntry.getValue();
        List<String> methodChannelId = subscribedMethod.subscribedChannelID;
        if (targetChannelId.containsAll(methodChannelId)) {
            mSubscribedMethodsMap.remove(mSubscribedMethodsMapEntry.getKey());
            removeTargetIfRequired(mSubscribedMethodsMap, mTargetMap, targetObject);
        }
    }
}
 
開發者ID:MindorksOpenSource,項目名稱:NYBus,代碼行數:24,代碼來源:NYBusDriver.java

示例4: testSetValueWriteThrough

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * SetValue of an EntrySet entry sets value in the map.
 */
public void testSetValueWriteThrough() {
    // Adapted from a bug report by Eric Zoerner
    ConcurrentHashMap map = new ConcurrentHashMap(2, 5.0f, 1);
    assertTrue(map.isEmpty());
    for (int i = 0; i < 20; i++)
        map.put(new Integer(i), new Integer(i));
    assertFalse(map.isEmpty());
    Map.Entry entry1 = (Map.Entry)map.entrySet().iterator().next();
    // Unless it happens to be first (in which case remainder of
    // test is skipped), remove a possibly-colliding key from map
    // which, under some implementations, may cause entry1 to be
    // cloned in map
    if (!entry1.getKey().equals(new Integer(16))) {
        map.remove(new Integer(16));
        entry1.setValue("XYZ");
        assertTrue(map.containsValue("XYZ")); // fails if write-through broken
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:22,代碼來源:ConcurrentHashMapTest.java

示例5: remove

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

示例6: execute

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
@SuppressWarnings("unchecked")
@Override
public void execute(JobExecutionContext job) throws JobExecutionException {
	TriggerScheduleServiceCenterToProviderServiceCenterMessage msg = new TriggerScheduleServiceCenterToProviderServiceCenterMessage();
	String jobName = job.getJobDetail().getKey().getName();
	JobDataMap jobDataMap = job.getJobDetail().getJobDataMap();
	ConcurrentHashMap<Integer, ServiceXServerSession> rpcServers = (ConcurrentHashMap<Integer, ServiceXServerSession>) jobDataMap
			.get(RPCSERVERS);
	ConcurrentHashMap<String, ConcurrentHashSet<Integer>> schedules = (ConcurrentHashMap<String, ConcurrentHashSet<Integer>>) jobDataMap
			.get(SCHEDULES);
	ConcurrentHashSet<Integer> providerList = schedules.get(jobName);
	if (providerList == null) {
		log.error("Job:" + jobName + "找不到Provider");
		return;
	}
	msg.setJobName(jobName);
	// 查看是否是最有一次執行,並且移除此job
	if (!job.getTrigger().mayFireAgain()) {
		msg.setEnd(true);
		schedules.remove(jobName);
		log.info("任務生命終結,執行刪除:" + jobName);
	}
	// 選舉式觸發
	ArrayList<Integer> arrayList = new ArrayList<>(providerList);
	int providerId = arrayList.get(RandomUtil.randomInt(0, arrayList.size() - 1));
	ServiceXServerSession serviceXServerSession = rpcServers.get(providerId);
	if (serviceXServerSession != null) {
		serviceXServerSession.getSession().writeAndFlush(msg);
		log.info(jobName + "觸發!分配的ProviderId為:" + providerId + ",下次觸發時間:"
				+ TimeUtil.date2Str(job.getTrigger().getNextFireTime().getTime()));
	}
}
 
開發者ID:HankXV,項目名稱:Limitart,代碼行數:33,代碼來源:ScheduleTask.java

示例7: 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:liaokailin,項目名稱:tomcat7,代碼行數:16,代碼來源:SlowQueryReport.java

示例8: removeTargetIfRequired

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * Remove the target.
 *
 * @param subscribedMethods the subscribed methods.
 * @param mTargetMap        the target map.
 * @param targetObject      the target object.
 */
private void removeTargetIfRequired(ConcurrentHashMap<String, SubscriberHolder> subscribedMethods,
                                    ConcurrentHashMap<Object,
                                            ConcurrentHashMap<String, SubscriberHolder>> mTargetMap,
                                    Object targetObject) {
    if (subscribedMethods.size() == 0) {
        mTargetMap.remove(targetObject);
    }
}
 
開發者ID:MindorksOpenSource,項目名稱:NYBus,代碼行數:16,代碼來源:NYBusDriver.java

示例9: processQueue

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * Removes weak keys from the map that have been enqueued
 * on the reference queue and are no longer in use.
 */
private static void processQueue(ReferenceQueue<Key> queue,
                                 ConcurrentHashMap<? extends
                                 WeakReference<Key>, ?> pdMap) {
    Reference<? extends Key> ref;
    while ((ref = queue.poll()) != null) {
        pdMap.remove(ref);
    }
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:13,代碼來源:ProtectionDomain.java

示例10: WeakKey

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
public WeakKey(K key, Cleaner c, ConcurrentHashMap<WeakKey<K>, ?> map) {
    super(key);
    this.hash = key.hashCode();
    this.map = map;
    cleanable = new WeakCleanable<Object>(key, c) {
        protected void performCleanup() {
            map.remove(WeakKey.this);
        }
    };
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:11,代碼來源:CleanerTest.java

示例11: testRemove

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * remove removes the correct key-value pair from the map
 */
public void testRemove() {
    ConcurrentHashMap map = map5();
    map.remove(five);
    assertEquals(4, map.size());
    assertFalse(map.containsKey(five));
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:10,代碼來源:ConcurrentHashMapTest.java

示例12: testRemove2

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * remove(key,value) removes only if pair present
 */
public void testRemove2() {
    ConcurrentHashMap map = map5();
    map.remove(five, "E");
    assertEquals(4, map.size());
    assertFalse(map.containsKey(five));
    map.remove(four, "A");
    assertEquals(4, map.size());
    assertTrue(map.containsKey(four));
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:13,代碼來源:ConcurrentHashMapTest.java

示例13: testRemove1_NullPointerException

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * remove(null) throws NPE
 */
public void testRemove1_NullPointerException() {
    ConcurrentHashMap c = new ConcurrentHashMap(5);
    c.put("sadsdf", "asdads");
    try {
        c.remove(null);
        shouldThrow();
    } catch (NullPointerException success) {}
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:12,代碼來源:ConcurrentHashMapTest.java

示例14: testRemove2_NullPointerException

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
/**
 * remove(null, x) throws NPE
 */
public void testRemove2_NullPointerException() {
    ConcurrentHashMap c = new ConcurrentHashMap(5);
    c.put("sadsdf", "asdads");
    try {
        c.remove(null, "whatever");
        shouldThrow();
    } catch (NullPointerException success) {}
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:12,代碼來源:ConcurrentHashMapTest.java

示例15: unlockBatch

import java.util.concurrent.ConcurrentHashMap; //導入方法依賴的package包/類
public void unlockBatch(final String group, final Set<MessageQueue> mqs, final String clientId) {
    try {
        this.lock.lockInterruptibly();
        try {
            ConcurrentHashMap<MessageQueue, LockEntry> groupValue = this.mqLockTable.get(group);
            if (null != groupValue) {
                for (MessageQueue mq : mqs) {
                    LockEntry lockEntry = groupValue.get(mq);
                    if (null != lockEntry) {
                        if (lockEntry.getClientId().equals(clientId)) {
                            groupValue.remove(mq);
                            log.info("unlockBatch, Group: {} {} {}",
                                group,
                                mq,
                                clientId);
                        } else {
                            log.warn("unlockBatch, but mq locked by other client: {}, Group: {} {} {}",
                                lockEntry.getClientId(),
                                group,
                                mq,
                                clientId);
                        }
                    } else {
                        log.warn("unlockBatch, but mq not locked, Group: {} {} {}",
                            group,
                            mq,
                            clientId);
                    }
                }
            } else {
                log.warn("unlockBatch, group not exist, Group: {} {}",
                    group,
                    clientId);
            }
        } finally {
            this.lock.unlock();
        }
    } catch (InterruptedException e) {
        log.error("putMessage exception", e);
    }
}
 
開發者ID:lirenzuo,項目名稱:rocketmq-rocketmq-all-4.1.0-incubating,代碼行數:42,代碼來源:RebalanceLockManager.java


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