zoukankan      html  css  js  c++  java
  • 属性集 Properties

    5.1 概述

    java.util.Properties 继承于 Hashtable ,来表示一个持久的属性集。它使用键值结构存储数据,每个键及其对应值都是一个字符串。该类也被许多Java类使用,比如获取系统属性时,System.getProperties 方法就是返回一个Properties对象。

    5.2 Properties类

    构造方法

    • public Properties() :创建一个空的属性列表。

    基本的存储方法

    • public Object setProperty(String key, String value) : 保存一对属性。
    • public String getProperty(String key) :使用此属性列表中指定的键搜索属性值。
    • public Set<String> stringPropertyNames() :所有键的名称的集合。
    public class ProDemo {
        public static void main(String[] args) throws FileNotFoundException {
            // 创建属性集对象
            Properties properties = new Properties();
            // 添加键值对元素
            properties.setProperty("filename", "a.txt");
            properties.setProperty("length", "209385038");
            properties.setProperty("location", "D:\a.txt");
            // 打印属性集对象
            System.out.println(properties);
            // 通过键,获取属性值
            System.out.println(properties.getProperty("filename"));
            System.out.println(properties.getProperty("length"));
            System.out.println(properties.getProperty("location"));
    
            // 遍历属性集,获取所有键的集合
            Set<String> strings = properties.stringPropertyNames();
            // 打印键值对
            for (String key : strings ) {
              	System.out.println(key+" -- "+properties.getProperty(key));
            }
        }
    }
    输出结果:
    {filename=a.txt, length=209385038, location=D:a.txt}
    a.txt
    209385038
    D:a.txt
    filename -- a.txt
    length -- 209385038
    location -- D:a.txt
    

    与流相关的方法

    • public void load(InputStream inStream): 从字节输入流中读取键值对。

    参数中使用了字节输入流,通过流对象,可以关联到某文件上,这样就能够加载文本中的数据了。文本数据格式:

    filename=a.txt
    length=209385038
    location=D:a.txt
    

    加载代码演示:

    public class ProDemo2 {
        public static void main(String[] args) throws FileNotFoundException {
            // 创建属性集对象
            Properties pro = new Properties();
            // 加载文本中信息到属性集
            pro.load(new FileInputStream("read.txt"));
            // 遍历集合并打印
            Set<String> strings = pro.stringPropertyNames();
            for (String key : strings ) {
              	System.out.println(key+" -- "+pro.getProperty(key));
            }
         }
    }
    

    输出结果:

    filename -- a.txt
    length -- 209385038
    location -- D:a.txt
    

    小贴士:文本中的数据,必须是键值对形式,可以使用空格、等号、冒号等符号分隔。

    store方法

    store(OutputStream out, String comments)

    store(Writer writer, String comments)

     public static void main(String[] args) throws IOException {
            Properties properties=new Properties();
    //        System.out.println(pt);
    //        pt.put(12,24);
            // 添加键值对元素
            properties.setProperty("filename", "你妈妈"); //只能为字符串
            properties.setProperty("length", "209385038");
            properties.setProperty("location", "D:\a.txt");
            System.out.println(properties);
    
            String property = properties.getProperty("filename", "b.txt");
            Set<String> strings = properties.stringPropertyNames();
            System.out.println(property);
            System.out.println(properties);
            for (String string : strings) {
                System.out.println(string+":"+properties.getProperty(string));
            }
    //        FileWriter fW = new FileWriter("D:\桌面\123\789.txt");
    //        properties.store(fW,"Store");
    //        fW.close();
            FileOutputStream fos=new FileOutputStream("D:\桌面\123\789.txt");
            properties.store(fos,"Store");
            fos.close();
        }
    
  • 相关阅读:
    Zookeeper系列二:分布式架构详解、分布式技术详解、分布式事务
    Zookeeper系列一:Zookeeper介绍、Zookeeper安装配置、ZK Shell的使用
    Mysql系列九:使用zookeeper管理远程Mycat配置文件、Mycat监控、Mycat数据迁移(扩容)
    Mysql系列八:Mycat和Sharding-jdbc的区别、Mycat分片join、Mycat分页中的坑、Mycat注解、Catlet使用
    Mysql系列七:分库分表技术难题之分布式全局唯一id解决方案
    Mysql系列五:数据库分库分表中间件mycat的安装和mycat配置详解
    学习Mysql过程中拓展的其他技术栈:Docker入门介绍
    学习Mysql过程中拓展的其他技术栈:设置linux虚拟机的固定ip和克隆linux虚拟机
    Mysql系列四:数据库分库分表基础理论
    Mysql系列三:Centos6下安装Mysql和Mysql主从复制的搭建
  • 原文地址:https://www.cnblogs.com/zgrey/p/13348199.html
Copyright © 2011-2022 走看看