对于ja va基础很好的人来讲,这个应该是简单的不能再简单的了。不过估计一些ja va新手不必定会知道(好比我,上次为别人写一个东西,须要从外存读文件来设置对象的值,由于不知道有ResourceBundle这种东西,就本身用FileReader在那搞,折腾了半天,最后还不能把配置文件和jar包打在一块儿发布,郁闷)。服务器
咱们能够在每一个对象中用ResourceBundle来读配置文件设置本身的值,也能够用一个固定的对象去读取而后保存下来以便之后使用。在每一个class中都去读配置文件会致使代码散乱,因此,只用一个class来进行读取是比较合理的作法。另外,因为I/O的速度比较慢,若是负责读取配置文件的class是在每次用到这些配置项的时候去读文件,就容易成为性能上的瓶颈。为避免这样的状况,能够在初始化的时候就把配置项一次所有读入,并保存在静态成员变量中。不过不排除会有对配置项进行动态读取的需求(由于某些应用是不能停掉的,好比应用服务器。在这些应用运行期间更新了配置文件,就须要在不不关闭应用的状况下从新读入配置项)。如下的例子只考虑了静态读取的状况,若是是动态读取,则能够把读取配置文件的代码放到某个方法中,经过对某个事件的响应来调用该方法更新配置项。
假设咱们用来读取配置文件的class叫TestResourceBundle,配置项的值来自一个叫property_en.properties的文件(该文件应该放到TestResourceBundle所对应的CLASSPATH的目录),有两个值须要配置:name和value。首先,须要在该class中定义一些字符串常量,以下:
public static final String PROPERTIES_FILE_NAME = "property";
public static final String MY_NAME_KEY = "name";
public static final String MY_VALUE_KEY = "value";
其中PROPERTIES_FILE_NAME指出了文件的名字。实际读取的文件应该是property_en.properties,可是只须要告诉ResourceBundle文件名是"property"就足够了。下划线和后面的"en"表示的是本地化信息。这里的en表明"ENGLISH",后缀properties是默认的。MY_NAME_KEY和MY_VALUE_KEY表示配置项在配置文件中的名字,用ResourceBundle的getString方法根据这些名字去读取相应的值。
而后,定义须要配置的变量。这些变量应该是静态的:
private static String myName;
private static String myValue;
而后进行静态初始化:
static {
try {
ResourceBundle bundle = ResourceBundle
.getBundle(PROPERTIES_FILE_NAME, Locale.ENGLISH);
myName = bundle.getString(MY_NAME_KEY).trim();
myValue = bundle.getString(MY_VALUE_KEY).trim();
}
catch(Exception ex) {
System.err.println( "[Property]:Can't Load property.properties");
myName = "default name";
myValue = "default value";
System.out.println( "myName will use the default value: " + myName);
System.out.println( "myValue will use the default value: " + myValue);
}
}
ResourceBundle bundle = ResourceBundle
.getBundle(PROPERTIES_FILE_NAME, Locale.ENGLISH);
这行代码初始化了一个ResourceBundle,Locale.ENGLISH用于指明本地化状况,所以会从"property_en.properties"中去读取配置项。若是是Locale.CHINA,则会从property_zh.properties中读取。这种机制使得程序的本地化变得简单。
myName = bundle.getString(MY_NAME_KEY).trim();
这行代码读入配置文件中名为"name"的变量的值,并赋给静态变量myName。
此外这段代码还包含了例外处理,当读取失败的时候,配置项会使用缺省值。
这样,该类就经过ResourceBundle读取外存上的配置文件对数据进行了配置。
property_en.properties文件的内容以下
# properties sample
#
name=sega
value=100
其中以'#'开头的行为注释,ResourceBundle在遇到这些行的时候会忽略掉。
如下为完整的测试代码:
public class TestResourceBundle {
public static final String PROPERTIES_FILE_NAME = "property";
public static final String MY_NAME_KEY = "name";
public static final String MY_VALUE_KEY = "value";
private static String myName;
private static String myValue;
static {
try {
ResourceBundle bundle = ResourceBundle
.getBundle(PROPERTIES_FILE_NAME, Locale.ENGLISH);
myName = bundle.getString(MY_NAME_KEY).trim();
myValue = bundle.getString(MY_VALUE_KEY).trim();
}
catch(Exception ex) {
System.err.println( "[Property]:Can't Load property.properties");
myName = "default name";
myValue = "default value";
System.out.println( "myName will use the default value: " + myName);
System.out.println( "myValue will use the default value: " + myValue);
}
}
public void print() {
System.out.println("My name is: " + myName);
System.out.println("My value is: " + myValue);
}
public static void main(String[] args) {
TestResourceBundle test = new TestResourceBundle();
test.print();
}
}