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


Java ConfigurationCacheReferenceType.HARD屬性代碼示例

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


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

示例1: DataCacheExpiringImpl

/**
 * Ctor.
 *
 * @param maxAgeSec                      is the maximum age in seconds
 * @param purgeIntervalSec               is the purge interval in seconds
 * @param cacheReferenceType             indicates whether hard, soft or weak references are used in the cache
 * @param schedulingService              is a service for call backs at a scheduled time, for purging
 * @param scheduleSlot                   slot for scheduling callbacks for this cache
 * @param epStatementAgentInstanceHandle is the statements-own handle for use in registering callbacks with services
 * @param timeAbacus                     time abacus
 */
public DataCacheExpiringImpl(double maxAgeSec,
                             double purgeIntervalSec,
                             ConfigurationCacheReferenceType cacheReferenceType,
                             SchedulingService schedulingService,
                             long scheduleSlot,
                             EPStatementAgentInstanceHandle epStatementAgentInstanceHandle,
                             TimeAbacus timeAbacus) {
    this.maxAgeSec = maxAgeSec;
    this.purgeIntervalSec = purgeIntervalSec;
    this.schedulingService = schedulingService;
    this.scheduleSlot = scheduleSlot;
    this.timeAbacus = timeAbacus;

    if (cacheReferenceType == ConfigurationCacheReferenceType.HARD) {
        this.cache = new HashMap<Object, Item>();
    } else if (cacheReferenceType == ConfigurationCacheReferenceType.SOFT) {
        this.cache = new ReferenceMap(ReferenceMap.SOFT, ReferenceMap.SOFT);
    } else {
        this.cache = new WeakHashMap<Object, Item>();
    }

    this.epStatementAgentInstanceHandle = epStatementAgentInstanceHandle;
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:34,代碼來源:DataCacheExpiringImpl.java

示例2: testPurgeInterval

public void testPurgeInterval() {
    SchedulingServiceImpl scheduler = new SchedulingServiceImpl(new TimeSourceServiceImpl());
    cache = new DataCacheExpiringImpl(10, 20, ConfigurationCacheReferenceType.HARD, scheduler, 1, null, TimeAbacusMilliseconds.INSTANCE);   // age 10 sec, purge 1000 seconds

    // test single entry in cache
    scheduler.setTime(5000);
    cache.put(make("a"), 1, new EventTable[]{lists[0]}); // a at 5 sec
    assertSame(lists[0], cache.getCached(make("a"), 1)[0]);

    scheduler.setTime(26000);
    SupportSchedulingServiceImpl.evaluateSchedule(scheduler);
    assertEquals(0, cache.getSize());

    // test 4 entries in cache
    scheduler.setTime(30000);
    cache.put(make("b"), 1, new EventTable[]{lists[1]});  // b at 30 sec

    scheduler.setTime(35000);
    cache.put(make("c"), 1, new EventTable[]{lists[2]});  // c at 35 sec

    scheduler.setTime(40000);
    cache.put(make("d"), 1, new EventTable[]{lists[3]});  // d at 40 sec

    scheduler.setTime(45000);
    cache.put(make("e"), 1, new EventTable[]{lists[4]});  // d at 40 sec

    scheduler.setTime(50000);
    SupportSchedulingServiceImpl.evaluateSchedule(scheduler);
    assertEquals(2, cache.getSize());   // only d and e

    assertSame(lists[3], cache.getCached(make("d"), 1)[0]);
    assertSame(lists[4], cache.getCached(make("e"), 1)[0]);
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:33,代碼來源:TestDataCacheExpiringImpl.java

示例3: DataCacheExpiringImpl

/**
 * Ctor.
 * @param maxAgeSec is the maximum age in seconds
 * @param purgeIntervalSec is the purge interval in seconds
 * @param cacheReferenceType indicates whether hard, soft or weak references are used in the cache
 * @param schedulingService is a service for call backs at a scheduled time, for purging
 * @param scheduleSlot slot for scheduling callbacks for this cache
 * @param epStatementAgentInstanceHandle is the statements-own handle for use in registering callbacks with services
 */
public DataCacheExpiringImpl(double maxAgeSec,
                             double purgeIntervalSec,
                             ConfigurationCacheReferenceType cacheReferenceType,
                             SchedulingService schedulingService,
                             ScheduleSlot scheduleSlot,
                             EPStatementAgentInstanceHandle epStatementAgentInstanceHandle)
{
    this.maxAgeMSec = (long) maxAgeSec * 1000;
    this.purgeIntervalMSec = (long) purgeIntervalSec * 1000;
    this.schedulingService = schedulingService;
    this.scheduleSlot = scheduleSlot;

    if (cacheReferenceType == ConfigurationCacheReferenceType.HARD)
    {
        this.cache = new HashMap<Object, Item>();
    }
    else if (cacheReferenceType == ConfigurationCacheReferenceType.SOFT)
    {
        this.cache = new ReferenceMap(ReferenceMap.SOFT, ReferenceMap.SOFT);
    }
    else
    {
        this.cache = new WeakHashMap<Object, Item>();
    }

    this.epStatementAgentInstanceHandle = epStatementAgentInstanceHandle;
}
 
開發者ID:mobile-event-processing,項目名稱:Asper,代碼行數:36,代碼來源:DataCacheExpiringImpl.java

示例4: testPurgeInterval

public void testPurgeInterval()
{
    SchedulingServiceImpl scheduler = new SchedulingServiceImpl(new TimeSourceServiceImpl());
    cache = new DataCacheExpiringImpl(10, 20, ConfigurationCacheReferenceType.HARD, scheduler, new ScheduleSlot(1, 2), null);   // age 10 sec, purge 1000 seconds

    // test single entry in cache
    scheduler.setTime(5000);
    cache.put(make("a"), lists[0]); // a at 5 sec
    assertSame(lists[0], cache.getCached(make("a")));

    scheduler.setTime(26000);
    SupportSchedulingServiceImpl.evaluateSchedule(scheduler);
    assertEquals(0, cache.getSize());

    // test 4 entries in cache
    scheduler.setTime(30000);
    cache.put(make("b"), lists[1]);  // b at 30 sec

    scheduler.setTime(35000);
    cache.put(make("c"), lists[2]);  // c at 35 sec

    scheduler.setTime(40000);
    cache.put(make("d"), lists[3]);  // d at 40 sec

    scheduler.setTime(45000);
    cache.put(make("e"), lists[4]);  // d at 40 sec

    scheduler.setTime(50000);
    SupportSchedulingServiceImpl.evaluateSchedule(scheduler);
    assertEquals(2, cache.getSize());   // only d and e

    assertSame(lists[3], cache.getCached(make("d")));
    assertSame(lists[4], cache.getCached(make("e")));
}
 
開發者ID:mobile-event-processing,項目名稱:Asper,代碼行數:34,代碼來源:TestDataCacheExpiringImpl.java

示例5: testGet

public void testGet() {
    scheduler = new SupportSchedulingServiceImpl();
    cache = new DataCacheExpiringImpl(10, 1000, ConfigurationCacheReferenceType.HARD, scheduler, 1, null, TimeAbacusMilliseconds.INSTANCE);   // age 10 sec, purge 1000 seconds

    assertNull(cache.getCached(make("a"), 1));

    scheduler.setTime(5000);
    cache.put(make("a"), 1, new EventTable[]{lists[0]}); // a at 5 sec
    assertSame(lists[0], cache.getCached(make("a"), 1)[0]);

    scheduler.setTime(10000);
    cache.put(make("b"), 1, new EventTable[]{lists[1]}); // b at 10 sec
    assertSame(lists[0], cache.getCached(make("a"), 1)[0]);
    assertSame(lists[1], cache.getCached(make("b"), 1)[0]);

    scheduler.setTime(11000);
    cache.put(make("c"), 1, new EventTable[]{lists[2]}); // c at 11 sec
    cache.put(make("d"), 1, new EventTable[]{lists[3]}); // d at 11 sec

    scheduler.setTime(14999);
    assertSame(lists[0], cache.getCached(make("a"), 1)[0]);

    scheduler.setTime(15000);
    assertSame(lists[0], cache.getCached(make("a"), 1)[0]);

    scheduler.setTime(15001);
    assertNull(cache.getCached(make("a"), 1));

    scheduler.setTime(15001);
    assertNull(cache.getCached(make("a"), 1));

    scheduler.setTime(15001);
    assertNull(cache.getCached(make("a"), 1));
    assertSame(lists[1], cache.getCached(make("b"), 1)[0]);
    assertSame(lists[2], cache.getCached(make("c"), 1)[0]);
    assertSame(lists[3], cache.getCached(make("d"), 1)[0]);

    scheduler.setTime(20000);
    assertSame(lists[1], cache.getCached(make("b"), 1)[0]);

    scheduler.setTime(20001);
    assertNull(cache.getCached(make("b"), 1));

    scheduler.setTime(21001);
    assertNull(cache.getCached(make("a"), 1));
    assertNull(cache.getCached(make("b"), 1));
    assertNull(cache.getCached(make("c"), 1));
    assertNull(cache.getCached(make("d"), 1));

    scheduler.setTime(22000);
    cache.put(make("b"), 1, new EventTable[]{lists[1]}); // b at 22 sec
    cache.put(make("d"), 1, new EventTable[]{lists[3]}); // d at 22 sec

    scheduler.setTime(32000);
    assertSame(lists[1], cache.getCached(make("b"), 1)[0]);
    assertSame(lists[3], cache.getCached(make("d"), 1)[0]);
}
 
開發者ID:espertechinc,項目名稱:esper,代碼行數:57,代碼來源:TestDataCacheExpiringImpl.java

示例6: testGet

public void testGet()
{
    scheduler = new SupportSchedulingServiceImpl();
    cache = new DataCacheExpiringImpl(10, 1000, ConfigurationCacheReferenceType.HARD, scheduler, null, null);   // age 10 sec, purge 1000 seconds

    assertNull(cache.getCached(make("a")));

    scheduler.setTime(5000);
    cache.put(make("a"), lists[0]); // a at 5 sec
    assertSame(lists[0], cache.getCached(make("a")));

    scheduler.setTime(10000);
    cache.put(make("b"), lists[1]); // b at 10 sec
    assertSame(lists[0], cache.getCached(make("a")));
    assertSame(lists[1], cache.getCached(make("b")));

    scheduler.setTime(11000);
    cache.put(make("c"), lists[2]); // c at 11 sec
    cache.put(make("d"), lists[3]); // d at 11 sec

    scheduler.setTime(14999);
    assertSame(lists[0], cache.getCached(make("a")));

    scheduler.setTime(15000);
    assertSame(lists[0], cache.getCached(make("a")));

    scheduler.setTime(15001);
    assertNull(cache.getCached(make("a")));

    scheduler.setTime(15001);
    assertNull(cache.getCached(make("a")));

    scheduler.setTime(15001);
    assertNull(cache.getCached(make("a")));
    assertSame(lists[1], cache.getCached(make("b")));
    assertSame(lists[2], cache.getCached(make("c")));
    assertSame(lists[3], cache.getCached(make("d")));

    scheduler.setTime(20000);
    assertSame(lists[1], cache.getCached(make("b")));

    scheduler.setTime(20001);
    assertNull(cache.getCached(make("b")));

    scheduler.setTime(21001);
    assertNull(cache.getCached(make("a")));
    assertNull(cache.getCached(make("b")));
    assertNull(cache.getCached(make("c")));
    assertNull(cache.getCached(make("d")));

    scheduler.setTime(22000);
    cache.put(make("b"), lists[1]); // b at 22 sec
    cache.put(make("d"), lists[3]); // d at 22 sec

    scheduler.setTime(32000);
    assertSame(lists[1], cache.getCached(make("b")));
    assertSame(lists[3], cache.getCached(make("d")));
}
 
開發者ID:mobile-event-processing,項目名稱:Asper,代碼行數:58,代碼來源:TestDataCacheExpiringImpl.java


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