全局变量的单例模式 从指定的配置文件中读取配置信息

1/** *//**
 2 * 全局变量的单例模式,使用eager instance。
 3 * 从指定的配置文件中读取配置信息,并将配置信息储存到properties属性。
 4 * 提供访问属性的方法,不提供修改属性的方法。
 5 */
 6
 7import java.io.FileInputStream;
 8import java.io.FileNotFoundException;
 9import java.io.IOException;
10import java.util.HashMap;
11import java.util.Properties;
12
13public class RuntimeConstants
14{
15  private final static String _CONF_FILE_NAME="d://conf.properties";
16  private static RuntimeConstants _instance=new RuntimeConstants();
17  private HashMap properties=new HashMap();
18 
19  private RuntimeConstants()
20  {
21    init();
22  }
23
24  public static void main(String[] args)
25  {
26    System.out.println((String)RuntimeConstants.getInstance().getProperty("log.level"));
27    RuntimeConstants.getInstance().setProperty("log.level","DEBUG5555555");
28    System.out.println((String)RuntimeConstants.getInstance().getProperty("log.level"));
29  }
30 
31  /** *//**
32   * 获取单例实例。
33
34   */
35  public static RuntimeConstants getInstance()
36  {
37    return _instance;
38  }
39 
40  /** *//**
41   * 从指定的配置文件读取配置信息,并装配到properties属性
42   */
43  private void init()
44  {
45    Properties p=new Properties();
46    try
47    {
48      p.load(new FileInputStream(_CONF_FILE_NAME));
49      Object[] keys=p.keySet().toArray();
50      int i=0;
51      for(i=0;i<keys.length;i++)
52      {
53        properties.put((String)keys[i],p.getProperty((String)keys[i]));
54      }
55    }
56    catch (FileNotFoundException e)
57    {
58      System.out.println("[ERROR] 没有找到配置文件 "+e);
59    }
60    catch (IOException e)
61    {
62      System.out.println("[ERROR] 读取文件失败 "+e);
63    }
64    p.clear();
65  }
66 
67  public Object getProperty(Object key)
68  {
69    return properties.get(key);
70  }
71
72  public void setProperty(Object key, Object value)
73 {
74      properties.put(key,value);
75 }
76
77}
78

conf.properties 如下:

 1db.target.driver=com.microsoft.jdbc.sqlserver.SQLServerDriver
 2db.target.user=sa
 3db.target.password=123456
 4db.target.schema=soman
 5db.target.url=
 6db.target.connections=10
 7
 8db.source.driver=com.microsoft.jdbc.sqlserver.SQLServerDriver
 9db.source.user=sa
10db.source.password=654321
11db.source.schema=somanQuery
12db.source.url=
13db.source.connections=20
14
15runtime.thread.max=50
16
17log.level=DEBUG

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值