码迷,mamicode.com
首页 > 其他好文 > 详细

序列键生成器之多例模式实现

时间:2015-08-10 07:03:49      阅读:110      评论:0      收藏:0      [点我收藏+]

标签:

public class MutilKeyGenerator {
    private static HashMap keys=new HashMap();
    private static final int POOL_SIZE=20;
    private KeyInfo keyInfo=null;
    private MutilKeyGenerator(){}
    private MutilKeyGenerator(String keyName){
        keyInfo=new KeyInfo(POOL_SIZE, keyName);
    }
    /*
     * 静态工厂提供自己的实例
     * */
    public synchronized static MutilKeyGenerator getInstance(String keyName){
        MutilKeyGenerator keyGenerator=null;
        if(keys.containsKey(keyName)){
            keyGenerator=(MutilKeyGenerator)keys.get(keyName);
            System.out.println(keyName+"    founded");
        }
        else{
            keyGenerator=new MutilKeyGenerator(keyName);
            keys.put(keyName, keyGenerator);
            System.out.println(keyName+"    created");
        }
        return keyGenerator;
    }
    
    public int getNextKey(){
        return keyInfo.getNextKey();
    }
}

class KeyInfo
{
    private int keyMax;
    private int keyMin;
    private int nextKey;
    private int poolSize;
    private String keyName;
    public KeyInfo(int poolSize,String keyName)
    {
        this.poolSize=poolSize;
        this.keyName=keyName;
        retriveFromDB();
    }
    public int getKeyMax(){
        return keyMax;
    }
    public int getKeyMin(){
        return keyMin;
    }
    public int getNextKey()
    {
        if(nextKey>keyMax){
            retriveFromDB();
        }
        return nextKey++;
    }
    /*
     * 从数据库提取当前的键值
     * */
    private void retriveFromDB()
    {
        String sql1="update keyTable set keyValue=keyValue+"+poolSize+"where keyname=‘"+keyName+"‘";
        String sql2="select keyValue from keyTable where keyName=‘"+keyName+"‘";
        //excute the sql,assume the  value returned is 1000
        int keyFromDB=1000;
        this.keyMax=keyFromDB;
        this.keyMin=keyFromDB-poolSize+1;
        this.nextKey=keyMin;
    }
}

序列键生成器之多例模式实现

标签:

原文地址:http://www.cnblogs.com/xtsylc/p/4716878.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!