org.frameworkset.cache.EdenConcurrentCache Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bboss-util Show documentation
Show all versions of bboss-util Show documentation
bboss is a j2ee framework include aop/ioc,mvc,persistent,taglib,rpc,event ,bean-xml serializable and so on.http://www.bbossgroups.com
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.frameworkset.cache;
import java.util.Map;
import java.util.WeakHashMap;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.atomic.AtomicLong;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
public final class EdenConcurrentCache {
private final int size;
public final int DEFAULT_SIZE = 1000;
private final Map eden;
private final AtomicLong missing;
private final Lock cacheLock = new ReentrantLock();
private final Map longterm;
public EdenConcurrentCache() {
this.size = DEFAULT_SIZE;
this.eden = new ConcurrentHashMap();
this.longterm = new WeakHashMap();
missing = new AtomicLong();
}
public EdenConcurrentCache(int size) {
this.size = size;
this.eden = new ConcurrentHashMap();
this.longterm = new WeakHashMap();
missing = new AtomicLong();
}
public V get(K k) {
V v = this.eden.get(k);
if (v == null) {
cacheLock.lock();
try{
v = this.longterm.get(k);
}
finally {
cacheLock.unlock();
}
if (v != null) {
this.eden.put(k, v);
}
}
return v;
}
public int getMaxSize(){
return this.size;
}
/**
* put data with key and value
* if read max data size then return true ,either return false.
* @param k
* @param v
* @return
*/
public boolean put(K k, V v) {
boolean outOfSize = false;
if (this.eden.size() >= size) {
cacheLock.lock();
try{
this.longterm.putAll(this.eden);
}
finally {
cacheLock.unlock();
}
outOfSize = true;
this.eden.clear();
}
this.eden.put(k, v);
return outOfSize;
}
public int longtermSize(){
return this.longterm.size();
}
public int edenSize(){
return this.eden.size();
}
public void clear(){
this.eden.clear();
cacheLock.lock();
try {
this.longterm.clear();
}
finally {
cacheLock.unlock();
}
}
public long increamentMissing() {
return missing.incrementAndGet();
}
public boolean needLogWarn(long misses,long warnInterval){
return misses >= size && misses % warnInterval == 0;
}
}