`
yznxing
  • 浏览: 367031 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

google Collection 的MapMaker使用体验

    博客分类:
  • java
阅读更多

       前几天准备在写一个本地缓存的时候,有一个功能是设置超时时间,我当时用的是每次get的时候判断上次get的时间,跟当前时间对比看是否超过预期时间,来决定是否过期的。

       RednaxelaFX提示我说,可以考虑使用googleCollection的MapMaker,除了可以设置超时功能外,还可以绑定key的未取到值的function,当通过get(key)取缓存为空的时候,可以通过这个绑定的function来将返回值put到缓存中,留着下一次get。

       听完这些介绍,心动不已,找个时间,简单的test了下MapMaker,果然感觉很强大。

 

       GoogleCollection的下载地址:http://code.google.com/p/google-collections/       

 

       下面是我的测试代码。

 

 

import java.util.concurrent.ConcurrentMap;
import java.util.concurrent.TimeUnit;

import com.google.common.base.Function;
import com.google.common.collect.MapMaker;

/**
 * @author guoliang created GoogleColTestMain.java
 * @since 2010-4-28 下午05:48:55
 */
public class GoogleColTestMain {

    /**
     * @param args
     */
    public static void main(String[] args) {
    	/**
    	 * softKeys
    	 * weakValues
    	 * 可以设置key跟value的strong,soft,weak属性。不错不错。
    	 * expiration(3, TimeUnit.SECONDS)设置超时时间为3秒
    	 * 
    	 */
        ConcurrentMap<String, String> testMap = new MapMaker().concurrencyLevel(32).softKeys().weakValues().expiration(
                3, TimeUnit.SECONDS).makeComputingMap(new Function<String, String>() {
            /**
             * 这里就是绑定的根据key没找到value的时候触发的function,
             * 可以将这里的返回值放到对应的key的value中!
             * @param arg0
             * @return
             */
            @Override
            public String apply(String arg0) {
                return "create:" + arg0;
            }

        });

        testMap.put("a", "testa");
        testMap.put("b", "testb");

        System.out.println(testMap.get("a"));
        System.out.println(testMap.get("b"));
        System.out.println(testMap.get("c"));

        /**
         * 这里sleep4秒钟过后,
         * 缓存都失效,再get就会根据绑定的function去获得value放在map中了。
         */
        try {
            Thread.sleep(4000);
        } catch (InterruptedException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        
        /**
         * 看看这里的再输出,是不是就是新的值了!~
         */

        System.out.println(testMap.get("a"));
        System.out.println(testMap.get("b"));
        System.out.println(testMap.get("c"));
    }

}
 

 

       感觉果然很强大!感谢开源,感谢google~~~

 

 

 

 

5
2
分享到:
评论
7 楼 li361879355 2013-07-12  
[flash=200,200][url][img][img][list]
[*]
引用
引用
[u][i][b][list]
[*][*][img][url][flash=200,200]
[*][*]
[*][*]
[/flash][/url][/img]||||||| |||||||[*][/list][/b][/i][/u]|||||||
[/flash][/flash]
|||||||||||||||||
||||||||||||||||
||||||||||||||||
|||||||||||||||
|||||||||||||||
||||||||||||||
||||||||||||||
|||||||||||||
|||||||||||||
||||||||||||
||||||||||||
|||||||||||
|||||||||||
||||||||||
||||||||||
|||||||||
|||||||||
||||||||
||||||||
|||||||
|||||||
||||||
||||||
|||||
|||||
||||
||||
|||
|||
||
||
|
|

|||||||[/list][/img][/img][/url][/flash]|||||||
||||||
||||||
|||||
|||||
||||
||||
|||
|||
||
||
|
|
6 楼 allenny 2010-10-31  
RednaxelaFX 写道
话说你忘记感谢国家了……

哪一个国家?
5 楼 yznxing 2010-05-02  
melin 写道
可以了解一下这个:
http://code.google.com/p/concurrentlinkedhashmap/wiki/ExpirableCache



谢谢哇,先了解下!~
4 楼 melin 2010-05-01  
可以了解一下这个:
http://code.google.com/p/concurrentlinkedhashmap/wiki/ExpirableCache
3 楼 RednaxelaFX 2010-05-01  
话说你忘记感谢国家了……
2 楼 yznxing 2010-05-01  
恩 ,呵呵 !
多线程这块,我还没测试,
不过既然是create出来的ConcurrentMap
我想还是放心的,
下次有时间对并发再做个测试,
哈哈~~~

我准备吧这个放进我的cache小轮子里边去,写出来了,你给抓抓虫子哈~~~
1 楼 RednaxelaFX 2010-05-01  
最关键是get()操作去调用传进去的Function、超时清理之类的地方都考虑到了多线程使用的场景,都保证线程安全,可以少操心这点非常棒~

相关推荐

Global site tag (gtag.js) - Google Analytics