• Java 读写Properties配置文件


    Java 读写Properties配置文件

    1.Properties类与Properties配置文件

      Properties类继承自Hashtable类并且实现了Map接口,也是使用一种键值对的形式来保存属性集。不过Properties有特殊的地方,就是它的键和值都是字符串类型。

    2.Properties中的主要方法

    (1)load(InputStream inStream)

       这个方法可以从.properties属性文件对应的文件输入流中,加载属性列表到Properties类对象如下面的代码:

    Properties pro = new Properties();
    FileInputStream in = new FileInputStream("a.properties");
    pro.load(in);
    in.close();

    (2)store(OutputStream out, String comments)

       这个方法将Properties类对象的属性列表保存到输出流中如下面的代码:

    FileOutputStream oFile = new FileOutputStream(file, "a.properties");
    pro.store(oFile, "Comment");
    oFile.close();

      如果comments不为空,保存后的属性文件第一行会是#comments,表示注释信息;如果为空则没有注释信息。

      注释信息后面是属性文件的当前保存时间信息。

    (3)getProperty/setProperty

       这两个方法是分别是获取和设置属性信息。

    3.代码实例

     属性文件a.properties如下:

    name=root
    pass=liu
    key=value

    读取a.properties属性列表,与生成属性文件b.properties。代码如下:

    复制代码
     1 import java.io.BufferedInputStream;
     2 import java.io.FileInputStream;
     3 import java.io.FileOutputStream;
     4 import java.io.InputStream; 
     5 import java.util.Iterator;
     6 import java.util.Properties; 
     7 
     8 public class PropertyTest {
     9     public static void main(String[] args) { 
    10         Properties prop = new Properties();     
    11         try{
    12             //读取属性文件a.properties
    13             InputStream in = new BufferedInputStream (new FileInputStream("a.properties"));
    14             prop.load(in);     ///加载属性列表
    15             Iterator<String> it=prop.stringPropertyNames().iterator();
    16             while(it.hasNext()){
    17                 String key=it.next();
    18                 System.out.println(key+":"+prop.getProperty(key));
    19             }
    20             in.close();
    21             
    22             ///保存属性到b.properties文件
    23             FileOutputStream oFile = new FileOutputStream("b.properties", true);//true表示追加打开
    24             prop.setProperty("phone", "10086");
    25             prop.store(oFile, "The New properties file");
    26             oFile.close();
    27         }
    28         catch(Exception e){
    29             System.out.println(e);
    30         }
    31     } 
    32 }
    复制代码
  • 相关阅读:
    动态规划
    关键路径
    拓扑排序
    最小生成树
    Floyd 多源最短路径
    SPFA算法
    Bellman_Ford算法(负环的单源路径)
    Dijkstra算法
    fill和memset的区别
    Codeforces Round #655 (Div. 2) 题解
  • 原文地址:https://www.cnblogs.com/keyi/p/5825036.html
Copyright © 2020-2023  润新知