import java.util.*;
/** * 提供一个保存参数的容器,用来给那些参数多、可选参数多、参数易变的方法提供参数读取能力。 * 直接使用Map等类对于数据类型处理不是方便。本类提供常用数据类型的读取方法。用法示例:<br> * port = args.get("port",8080);<br> * 放入Map中的port值可以是"8443"或new Integer(8443)或其他任何类型,只要toString() * 能够解析出一个整数。 * @author sunlen * @version 1.0 */public class Args{ /** 一个常量空参数表。用于传递空参数,该参数列表已经锁定,不能修改。*/ public static final Args EMPTY = new Args().lock();
/** 参数列表是否已经锁定,锁定后的参数列表将只读。*/ boolean locked;
/** Map保存的参数。*/ Map args;
/** 创建空参数列表。*/ public Args() { this(new HashMap()); }
/** * 用Map创建参数。 * @param theArgs 保存参数的Map对象。 */ public Args(Map theArgs) { if (theArgs==null) { throw new NullPointerException("argument is null"); } args = theArgs; }
/** * 取得字符串参数的方法。 * @param key 参数名。 * @param def 参数值。 */ public String get(String key,String def) { try { return args.get(key).toString(); } catch (Exception ex) { return def; } }
/** * 取得整数参数的方法。 * @param key 参数名。 * @param def 参数值。 */ public int get(String key,int def) { try { return Integer.parseInt(args.get(key).toString()); } catch (Exception ex) { return def; } }
/** * 取得长整数参数的方法。 * @param key 参数名。 * @param def 参数值。 */ public long get(String key,long def) { try { return Long.parseLong(args.get(key).toString()); } catch (Exception ex) { return def; } }
/** * 取得浮点数参数的方法。 * @param key 参数名。 * @param def 参数值。 */ public float get(String key,float def) { try { return Float.parseFloat(args.get(key).toString()); } catch (Exception ex) { return def; } }
/** * 取得布尔参数的方法。只有"true"解析成true其他解析成false。 * @param key 参数名。 * @param def 参数值。 */ public boolean get(String key,boolean def) { try { return ("true".equals(args.get(key))); } catch (Exception ex) { return def; } }
/** * 取得原始对象类型。 * @param key 参数名。 * @param def 参数缺省值。 */ public Object get(String key,Object def) { try { Object obj = args.get(key); if (obj==null) { return def; } return obj; } catch (Exception ex) { return def; } }
/** * 往当前参数表中添加一个参数。 * @param key 参数名。 * @param value 参数值。 * @return 添加了新参数后的参数表(对象实例没有变)。 * @exception UnsupportedOperationException 如果参数列表已经被锁定。 */ public Args set(String key,Object value) { if(locked) { throw new UnsupportedOperationException( "Args have locked,can modify"); } args.put(key,value); return this; }
/** * 往当前参数表中添加一个参数。 * @param key 参数名。 * @param value 参数值。 * @return 添加了新参数后的参数表(对象实例没有变)。 * @exception UnsupportedOperationException 如果参数列表已经被锁定。 */ public Args set(String key,int value) { if(locked) { throw new UnsupportedOperationException( "Args have locked,can modify"); } args.put(key,new Integer(value)); return this; }
/** * 往当前参数表中添加一个参数。 * @param key 参数名。 * @param value 参数值。 * @return 添加了新参数后的参数表(对象实例没有变)。 * @exception UnsupportedOperationException 如果参数列表已经被锁定。 */ public Args set(String key,boolean value) { if(locked) { throw new UnsupportedOperationException( "Args have locked,can modify"); } args.put(key,new Boolean(value)); return this; }
/** * 往当前参数表中添加一个参数。 * @param key 参数名。 * @param value 参数值。 * @return 添加了新参数后的参数表(对象实例没有变)。 * @exception UnsupportedOperationException 如果参数列表已经被锁定。 */ public Args set(String key,long value) { if(locked) { throw new UnsupportedOperationException( "Args have locked,can modify"); } args.put(key,new Long(value)); return this; }
/** * 往当前参数表中添加一个参数。 * @param key 参数名。 * @param value 参数值。 * @return 添加了新参数后的参数表(对象实例没有变)。 * @exception UnsupportedOperationException 如果参数列表已经被锁定。 */ public Args set(String key,float value) { if(locked) { throw new UnsupportedOperationException("Args have locked,can modify"); } args.put(key,new Float(value)); return this; }
/** * 往当前参数表中添加一个参数。 * @param key 参数名。 * @param value 参数值。 * @return 添加了新参数后的参数表(对象实例没有变)。 * @exception UnsupportedOperationException 如果参数列表已经被锁定。 */ public Args set(String key,double value) { if(locked) { throw new UnsupportedOperationException( "Args have locked,can modify"); } args.put(key,new Double(value)); return this; }
/** * 锁定参数列表。锁定后该参数列表将变成只读的,任何对set()方法的调用都将抛出 * UnsupportedOperationException异常。已经锁定的参数表再次调用本方法没有任何影响。 * @return 锁定后的参数列表(对象实例没有变)。 */ public Args lock() { locked = true; return this; }
/** * 参数列表的字符串描述。 * @return 所有参数值。 */ public String toString() { return args.toString(); }}