⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 timestampsregionimpl.java

📁 hibernate-distribution-3.3.1.GA-dist.zip源码
💻 JAVA
字号:
/* * Hibernate, Relational Persistence for Idiomatic Java * * Copyright (c) 2007, Red Hat Middleware LLC or third-party contributors as * indicated by the @author tags or express copyright attribution * statements applied by the authors.  All third-party contributions are * distributed under license by Red Hat Middleware LLC. * * This copyrighted material is made available to anyone wishing to use, modify, * copy, or redistribute it subject to the terms and conditions of the GNU * Lesser General Public License, as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License * for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this distribution; if not, write to: * Free Software Foundation, Inc. * 51 Franklin Street, Fifth Floor * Boston, MA  02110-1301  USA */package org.hibernate.cache.jbc2.timestamp;import java.util.Map;import java.util.Properties;import java.util.Set;import java.util.concurrent.ConcurrentHashMap;import javax.transaction.Transaction;import org.hibernate.cache.CacheException;import org.hibernate.cache.TimestampsRegion;import org.hibernate.cache.jbc2.TransactionalDataRegionAdapter;import org.hibernate.cache.jbc2.util.CacheHelper;import org.jboss.cache.Cache;import org.jboss.cache.Fqn;import org.jboss.cache.config.Option;import org.jboss.cache.notifications.annotation.CacheListener;import org.jboss.cache.notifications.annotation.NodeModified;import org.jboss.cache.notifications.annotation.NodeRemoved;import org.jboss.cache.notifications.event.NodeModifiedEvent;import org.jboss.cache.notifications.event.NodeRemovedEvent;/** * Defines the behavior of the timestamps cache region for JBossCache 2.x. *  * TODO Need to define a way to ensure asynchronous replication events * do not result in timestamps moving backward, while dealing with the fact * that the normal sequence of UpdateTimestampsCache.preinvalidate() then * UpdateTimestampsCache.invalidate() will result in 2 calls to put() with * the latter call having an earlier timestamp. *  * @author Brian Stansberry * @version $Revision: 14368 $ */@CacheListenerpublic class TimestampsRegionImpl extends TransactionalDataRegionAdapter implements TimestampsRegion {    public static final String TYPE = "TS";    private Map localCache = new ConcurrentHashMap();        /**     * Create a new TimestampsRegionImpl.	 *     * @param jbcCache The JBC cache instance to use to store the timestamps data     * @param regionName The name of the region (within the JBC cache)     * @param regionPrefix Any region prefix to apply	 * @param properties The configuration properties.     */    public TimestampsRegionImpl(Cache jbcCache, String regionName, String regionPrefix, Properties properties) {        super(jbcCache, regionName, regionPrefix, null);        jbcCache.addCacheListener(this);        populateLocalCache();    }    @Override    protected Fqn<String> createRegionFqn(String regionName, String regionPrefix) {        return getTypeFirstRegionFqn(regionName, regionPrefix, TYPE);    }    public void evict(Object key) throws CacheException {               ensureRegionRootExists();                // TODO Is this a valid operation on a timestamps cache?        Option opt = getNonLockingDataVersionOption(true);        CacheHelper.removeNode(getCacheInstance(), getRegionFqn(), key, opt);    }    public void evictAll() throws CacheException {        // TODO Is this a valid operation on a timestamps cache?        Option opt = getNonLockingDataVersionOption(true);        CacheHelper.removeAll(getCacheInstance(), getRegionFqn(), opt);    }    public Object get(Object key) throws CacheException {        Object value = localCache.get(key);        if (value == null) {                       ensureRegionRootExists();                        value = suspendAndGet(key, null, false);            if (value != null)                localCache.put(key, value);        }        return value;    }    public void put(Object key, Object value) throws CacheException {               ensureRegionRootExists();        // Don't hold the JBC node lock throughout the tx, as that        // prevents reads and other updates        Transaction tx = suspend();        try {            // TODO Why not use the timestamp in a DataVersion?            Option opt = getNonLockingDataVersionOption(false);            // We ensure ASYNC semantics (JBCACHE-1175)            opt.setForceAsynchronous(true);            CacheHelper.put(getCacheInstance(), getRegionFqn(), key, value, opt);        } catch (Exception e) {            throw new CacheException(e);        } finally {            resume(tx);        }    }    @Override    public void destroy() throws CacheException {        localCache.clear();        getCacheInstance().removeCacheListener(this);        super.destroy();    }    /**     * Monitors cache events and updates the local cache     *      * @param event     */    @NodeModified    public void nodeModified(NodeModifiedEvent event) {        if (event.isPre())            return;        Fqn fqn = event.getFqn();        Fqn regFqn = getRegionFqn();        if (fqn.size() == regFqn.size() + 1 && fqn.isChildOf(regFqn)) {            Object key = fqn.get(regFqn.size());            localCache.put(key, event.getData().get(ITEM));        }    }    /**     * Monitors cache events and updates the local cache     *      * @param event     */    @NodeRemoved    public void nodeRemoved(NodeRemovedEvent event) {        if (event.isPre())            return;        Fqn fqn = event.getFqn();        Fqn regFqn = getRegionFqn();        if (fqn.size() == regFqn.size() + 1 && fqn.isChildOf(regFqn)) {            Object key = fqn.get(regFqn.size());            localCache.remove(key);        }        else if (fqn.equals(regFqn)) {            localCache.clear();        }    }    /**     * Brings all data from the distributed cache into our local cache.     */    private void populateLocalCache() {        Set children = CacheHelper.getChildrenNames(getCacheInstance(), getRegionFqn());        for (Object key : children) {            get(key);        }    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -