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


Java ConcurrentLinkedHashMap類代碼示例

本文整理匯總了Java中com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap的典型用法代碼示例。如果您正苦於以下問題:Java ConcurrentLinkedHashMap類的具體用法?Java ConcurrentLinkedHashMap怎麽用?Java ConcurrentLinkedHashMap使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: setMaxInMemory

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
public void setMaxInMemory(int newInMemory) {
    this.maxInMemory = newInMemory;
    Map<Object, CacheLine<V>> oldmap = this.memoryTable;

    if (newInMemory > 0) {
        if (this.memoryTable instanceof ConcurrentLinkedHashMap<?, ?>) {
            ((ConcurrentLinkedHashMap<?, ?>) this.memoryTable).setCapacity(newInMemory);
            return;
        } else {
            this.memoryTable =new Builder<Object, CacheLine<V>>()
                .maximumWeightedCapacity(newInMemory)
                .build();
        }
    } else {
        this.memoryTable = new ConcurrentHashMap<Object, CacheLine<V>>();
    }

    this.memoryTable.putAll(oldmap);
}
 
開發者ID:ilscipio,項目名稱:scipio-erp,代碼行數:20,代碼來源:UtilCache.java

示例2: SerializingCache

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
private SerializingCache(long capacity, Weigher<RefCountedMemory> weigher, ISerializer<V> serializer)
{
    this.serializer = serializer;

    EvictionListener<K,RefCountedMemory> listener = new EvictionListener<K, RefCountedMemory>()
    {
        public void onEviction(K k, RefCountedMemory mem)
        {
            mem.unreference();
        }
    };

    this.map = new ConcurrentLinkedHashMap.Builder<K, RefCountedMemory>()
               .weigher(weigher)
               .maximumWeightedCapacity(capacity)
               .concurrencyLevel(DEFAULT_CONCURENCY_LEVEL)
               .listener(listener)
               .build();
}
 
開發者ID:vcostet,項目名稱:cassandra-kmean,代碼行數:20,代碼來源:SerializingCache.java

示例3: SuperTagger

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
public SuperTagger(Map<String, Integer> freqStruct,
            Map<SuperTagElement, Integer> freqFringe, boolean estimateInterpol,
            Map<ElementaryStringTree, String> predTreeFringeMap,
            Map<ElementaryStringTree, String> predTreeStructMap,
            Map<ElementaryStringTree, String> predTreeMainLeafMap)
    {
        this.freqStruct = freqStruct;
        this.freqFringe = freqFringe;
        if (estimateInterpol)
        {
            estimateInterpolation();
        }
        else
        {
            //SuperTagElement.setInterpol(0.8150451950523311, 0.08875637920595104, 0.09619842574171784);//supertag all;
            SuperTagElement.setInterpol(0.9012691986830528, 0.08005882103417558, 0.01867198028277168);
            //SuperTagStructElement.setInterpol(1.0, 0.0);
        }
        this.predTreeFringeMap = predTreeFringeMap;
        this.predTreeStructMap = predTreeStructMap;
        this.predTreeMainLeafMap = predTreeMainLeafMap;
//        superTagStructCache = new LRUMap<SuperTagStructElement, Double>(100000);
        superTagStructCache = new ConcurrentLinkedHashMap.Builder<SuperTagElement, Double>().maximumWeightedCapacity(10000).build();
        superTagElementCache = new ConcurrentLinkedHashMap.Builder<SuperTagElement, Double>().maximumWeightedCapacity(10000).build();
    }
 
開發者ID:sinantie,項目名稱:PLTAG,代碼行數:26,代碼來源:SuperTagger.java

示例4: putImageInCache

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
private static void putImageInCache(final ConcurrentLinkedHashMap<String, ImageCacheWrapper> imageCache,
									final String imageKey,
									final Image image,
									final String originalImagePathName) {

	final ImageCacheWrapper imageCacheWrapper = new ImageCacheWrapper(image, originalImagePathName, imageKey);

	final ImageCacheWrapper oldWrapper = imageCache.put(imageKey, imageCacheWrapper);

	if (oldWrapper != null) {
		final Image oldImage = oldWrapper.image;
		if (oldImage != null) {
			oldImage.dispose();
		}
	}
}
 
開發者ID:wolfgang-ch,項目名稱:mytourbook,代碼行數:17,代碼來源:PhotoImageCache.java

示例5: run_normal

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
public int run_normal( ConcurrentLinkedHashMap<String,String> hm ) {
  SimpleRandom R = new SimpleRandom();

  int get_ops = 0;
  int put_ops = 0;
  int del_ops = 0;
  while( !_stop ) {
    int x = R.nextInt()&((1<<20)-1);
    String key = KEYS[R.nextInt()&(KEYS.length-1)];
    if( x < _gr ) {
      get_ops++;
      String val = hm.get(key);
      if( val != null && !val.equals(key) ) {
        throw new IllegalArgumentException("Mismatched key="+key+" and val="+val);
      }
    } else if( x < _pr ) {
      put_ops++;
  hm.putIfAbsent( key, key );
    } else {
      del_ops++;
      hm.remove( key );
    }
  }
  // We stopped; report results into shared result structure
  return get_ops+put_ops+del_ops;
}
 
開發者ID:ben-manes,項目名稱:concurrentlinkedhashmap,代碼行數:27,代碼來源:PerfHashBenchmark.java

示例6: init

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
/**
 * 初始化
 * @param name
 * @param entityCacheSize
 * @param concurrencyLevel
 */
public void init(String name, int entityCacheSize, int concurrencyLevel) {

	this.name = name;
	this.evictions = new ConcurrentReferenceHashMap<Object, Object>(ReferenceType.STRONG, ReferenceType.WEAK);

	this.store = new ConcurrentLinkedHashMap.Builder<Object, ValueWrapper>()
			.maximumWeightedCapacity(entityCacheSize > 0 ? entityCacheSize : DEFAULT_MAX_CAPACITY_OF_ENTITY_CACHE)
			.concurrencyLevel(concurrencyLevel).listener(new EvictionListener<Object, ValueWrapper>() {

				@Override
				public void onEviction(Object key, ValueWrapper value) {
					if (value.get() != null) {
						evictions.put(key, value.get());
					}
				}

			}).build();
}
 
開發者ID:Jakegogo,項目名稱:concurrent,代碼行數:25,代碼來源:ConcurrentLinkedHashMapCache.java

示例7: DeepPagingCache

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
public DeepPagingCache(long maxEntriesForDeepPaging) {
  _hits = Metrics.newMeter(new MetricName(ORG_APACHE_BLUR, DEEP_PAGING_CACHE, HIT), HIT, TimeUnit.SECONDS);
  _misses = Metrics.newMeter(new MetricName(ORG_APACHE_BLUR, DEEP_PAGING_CACHE, MISS), MISS, TimeUnit.SECONDS);
  _evictions = Metrics.newMeter(new MetricName(ORG_APACHE_BLUR, DEEP_PAGING_CACHE, EVICTION), EVICTION,
      TimeUnit.SECONDS);
  _lruCache = new ConcurrentLinkedHashMap.Builder<DeepPageKeyPlusPosition, DeepPageContainer>()
      .maximumWeightedCapacity(maxEntriesForDeepPaging)
      .listener(new EvictionListener<DeepPageKeyPlusPosition, DeepPageContainer>() {
        @Override
        public void onEviction(DeepPageKeyPlusPosition key, DeepPageContainer value) {
          _positionCache.remove(key);
          _evictions.mark();
        }
      }).build();
  Metrics.newGauge(new MetricName(ORG_APACHE_BLUR, DEEP_PAGING_CACHE, SIZE), new Gauge<Long>() {
    @Override
    public Long value() {
      return _lruCache.weightedSize();
    }
  });
  _positionCache = new ConcurrentSkipListMap<DeepPageKeyPlusPosition, DeepPageContainer>();
}
 
開發者ID:apache,項目名稱:incubator-blur,代碼行數:23,代碼來源:DeepPagingCache.java

示例8: SerializingCache

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
public SerializingCache(int capacity, ICompactSerializer3<V> serializer, String tableName, String cfName)
{
    this.serializer = serializer;

    EvictionListener<K,FreeableMemory> listener = new EvictionListener<K, FreeableMemory>()
    {
        public void onEviction(K k, FreeableMemory mem)
        {
            mem.unreference();
        }
    };
    this.map = new ConcurrentLinkedHashMap.Builder<K, FreeableMemory>()
               .weigher(Weighers.<FreeableMemory>singleton())
               .initialCapacity(capacity)
               .maximumWeightedCapacity(capacity)
               .concurrencyLevel(DEFAULT_CONCURENCY_LEVEL)
               .listener(listener)
               .build();
}
 
開發者ID:devdattakulkarni,項目名稱:Cassandra-KVPM,代碼行數:20,代碼來源:SerializingCache.java

示例9: DayBasedStorageLocationMapper

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
public DayBasedStorageLocationMapper(Configuration configuration,
                                     UTCCurrentDateFormatter dateFormatter) {
    String s = configuration.getStorageIndexNamePrefix();
    this.indexPrefixName = s.endsWith("-") ? s : s + "-";
    this.currentDayFormatter = dateFormatter;
    this.dateCachingEnabled = configuration.isIndexNameDateCachingEnabled();
    indexNameSize = indexPrefixName.length() + 10;

    if(this.dateCachingEnabled) {
        dayCache = new ConcurrentLinkedHashMap.Builder<String,String>().maximumWeightedCapacity(configuration.getNumberOfIndexNamesToCache()).build();
    } else {
        dayCache = null;
    }


}
 
開發者ID:tootedom,項目名稱:related,代碼行數:17,代碼來源:DayBasedStorageLocationMapper.java

示例10: TimedCache

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
/**
    * 
    * @param capacity the maximum number of entries in the cache before the 
    * oldest entry is evicted. 
    * @param timeToLive specified in milliseconds
    */
public TimedCache(int capacity, int timeToLive) {
       cache = new ConcurrentLinkedHashMap.Builder<K, Long>()
       	    .maximumWeightedCapacity(capacity)
           .build();
       this.timeoutInterval = timeToLive;
   }
 
開發者ID:xuraylei,項目名稱:fresco_floodlight,代碼行數:13,代碼來源:TimedCache.java

示例11: createCache

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
private void createCache() {
    if (chunks != null) {
        chunks.clear();
        chunks = null;
    }

    long cacheSize = SystemProfile.calculateMaxObjects(10265, 0.6);

    System.out.println("Chunk Cache Size: " + cacheSize);

    chunks = new ConcurrentLinkedHashMap.Builder<Long, Chunk>()
            .maximumWeightedCapacity(cacheSize)
            .build();

    if (nullChunks != null) {
        nullChunks.clear();
        nullChunks = null;
    }

    cacheSize = SystemProfile.calculateMaxObjects(40, 0.1);

    System.out.println("Null Chunk Cache Size: " + cacheSize);

    nullChunks = new ConcurrentLinkedHashMap.Builder<Long, Byte>()
            .maximumWeightedCapacity(cacheSize)
            .build();
}
 
開發者ID:jocopa3,項目名稱:blocktopograph-library,代碼行數:28,代碼來源:ChunkManager.java

示例12: init

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
private void init() {
    if (cache == null) {
        synchronized (this) {
            if (cache == null) {
                cache = new ConcurrentLinkedHashMap.Builder<InnerQueryKey, SQLParsedState>().maximumWeightedCapacity(capacity).weigher(Weighers.singleton()).build();
            }
        }
    }
}
 
開發者ID:hellojavaer,項目名稱:ddal,代碼行數:10,代碼來源:LRUSQLParserCache.java

示例13: PersistableCache

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
public PersistableCache(JdbcTemplate template, int size) {
    dataMap = new ConcurrentLinkedHashMap.Builder<Long, Persistable>().maximumWeightedCapacity(size).weigher(Weighers.singleton())
            .listener((id, data) -> {
                if (data.isDirty()) {
                    //如果發現數據是髒的,那麽重新put一次,保證及時入庫
                    LOGGER.error("髒數據從緩存中移除了:" + id);
                }
            }).build();
}
 
開發者ID:beimi,項目名稱:ServerCore,代碼行數:10,代碼來源:PersistableCache.java

示例14: TimedCache

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
/**
    *
    * @param capacity the maximum number of entries in the cache before the 
    * oldest entry is evicted. 
    * @param timeToLive specified in milliseconds
    */
public TimedCache(int capacity, int timeToLive) {
       cache = new ConcurrentLinkedHashMap.Builder<K, Long>()
       	    .maximumWeightedCapacity(capacity)
           .build();
       this.timeoutInterval = timeToLive;
   }
 
開發者ID:zhenshengcai,項目名稱:floodlight-hardware,代碼行數:13,代碼來源:TimedCache.java

示例15: createTileCache

import com.googlecode.concurrentlinkedhashmap.ConcurrentLinkedHashMap; //導入依賴的package包/類
private void createTileCache() {
    long cacheSize = SystemProfile.calculateMaxObjects(128*128*2, 0.3);
    System.out.println("Tile Cache Size: " + cacheSize);

    tileMap = new ConcurrentLinkedHashMap.Builder<String, MCTile>()
            .maximumWeightedCapacity(cacheSize)
            .build();
}
 
開發者ID:jocopa3,項目名稱:BlocktopographPC-GUI,代碼行數:9,代碼來源:MCTileProvider.java


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