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

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
    评论
单例模式是一种常用的设计模式,可以确保一个类只有一个实例,并提供一个全局访问点。 实现读取配置文件信息单例模式可以采用以下步骤: 1. 创建一个配置文件读取类,该类包含一个私有构造函数,确保该类不能被直接实例化。 2. 添加一个私有的静态成员变量,用于保存唯一的实例对象。 3. 添加一个公共的静态方法,用于获取该类的唯一实例对象,如果实例对象不存在,则创建该对象并返回。 4. 在读取配置文件信息的方法,实例化一个 Properties 对象,并使用该对象的 load() 方法加载配置文件内容。 5. 通过 Properties 对象的 getProperty() 方法获取配置文件配置信息。 下面是一个示例代码,演示如何使用单例模式实现读取配置文件信息: ```java import java.io.FileInputStream; import java.io.IOException; import java.util.Properties; public class ConfigReader { private static ConfigReader instance = null; private Properties prop = null; private ConfigReader() { prop = new Properties(); try { prop.load(new FileInputStream("config.properties")); } catch (IOException e) { e.printStackTrace(); } } public static ConfigReader getInstance() { if (instance == null) { instance = new ConfigReader(); } return instance; } public String getProperty(String key) { return prop.getProperty(key); } } ``` 在上面的示例代码,我们创建了一个 ConfigReader 类,该类使用单例模式实现。在类的私有构造函数,我们加载了配置文件的内容,并创建了一个 Properties 对象用于保存配置信息。在公共的静态方法 getInstance() ,我们检查唯一的实例对象是否存在,如果不存在,则创建该对象并返回。在读取配置信息的方法 getProperty() ,我们调用 Properties 对象的 getProperty() 方法获取配置信息

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值