PropertyUtil属性文件读写工具类


  1. /** 
  2.  * PropertyUtil属性文件读写工具类 
  3.  */  
  4. public class PropertyUtil {  
  5.   
  6.     /** 
  7.      * 指定property文件 
  8.      */  
  9.     public static final String PROPERTY_FILE =WindowsUtil.getOSName().equals("Windows XP")? "c:/windows/config.properties":"d:\\config.properties";  
  10.     public static final String LOG_FILE = "c:/windows/EcollectLog.properties";  
  11.   
  12.     /** 
  13.      * 根据Key 读取Value 
  14.      *  
  15.      * @param key 
  16.      * @return 
  17.      */  
  18.     public static String readData(String key) {  
  19.         Properties props = new Properties();  
  20.         try {  
  21.             InputStream in = new BufferedInputStream(new FileInputStream(  
  22.                     PROPERTY_FILE));  
  23.             props.load(in);  
  24.             in.close();  
  25.             String value = props.getProperty(key);  
  26.             return value;  
  27.         } catch (Exception e) {  
  28.             e.printStackTrace();  
  29.             return null;  
  30.         }  
  31.     }  
  32.   
  33.       
  34.     /** 
  35.      * 修改或添加键值对 如果key存在,修改 反之,添加。 
  36.      *  
  37.      * @param key 
  38.      * @param value 
  39.      */  
  40.     public static void writeData(String key, String value) {  
  41.         Properties prop = new Properties();  
  42.         try {  
  43.             File file = new File(PROPERTY_FILE);  
  44.             if (!file.exists())  
  45.                 file.createNewFile();  
  46.             InputStream fis = new FileInputStream(file);  
  47.             prop.load(fis);  
  48.             fis.close();//一定要在修改值之前关闭fis  
  49.             OutputStream fos = new FileOutputStream(PROPERTY_FILE);  
  50.             prop.setProperty(key, value);  
  51.             prop.store(fos, "Update '" + key + "' value");  
  52.             fos.close();  
  53.         } catch (IOException e) {  
  54.             System.err.println("Visit " + PROPERTY_FILE + " for updating "  
  55.                     + value + " value error");  
  56.         }  
  57.     }  
  58.     /** 
  59.      * 获取参数对象 
  60.      * @return 
  61.      */  
  62.     public static Parameter getParameterByFile(){  
  63.         Parameter p = null;  
  64.         File f = new File(PROPERTY_FILE);  
  65.         if(f.exists()){  
  66.             p = new Parameter();  
  67.             p.setIp(readData("ip"));      
  68.             p.setPort(readData("port"));  
  69.             p.setLocalFolder(readData("localFolder"));  
  70.             p.setLocalFolder2(readData("localFolder2"));  
  71.             p.setLocalFolder3(readData("localFolder3"));  
  72.             p.setUsername(readData("username"));  
  73.             p.setPassword(readData("password"));  
  74.         }  
  75.         return p;  
  76.     }  
  77.     public static void main(String[] args) {  
  78.         PropertyUtil.writeData("ip""192.168.1.1");  
  79.         PropertyUtil.writeData("port""21");  
  80.         PropertyUtil.writeData("username""ddb");  
  81.         PropertyUtil.writeData("password""ddd2");  
  82.         PropertyUtil.writeData("localFolder""d:\\dwg");  
  83.           
  84.     }  
  85. }  
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C语言是一种广泛使用的编程语言,它具有高效、灵活、可移植性强等特点,被广泛应用于操作系统、嵌入式系统、数据库、编译器等领域的开发。C语言的基本语法包括变量、数据类型、运算符、控制结构(如if语句、循环语句等)、函数、指针等。在编C程序时,需要注意变量的声明和定义、指针的使用、内存的分配与释放等问题。C语言中常用的数据结构包括: 1. 数组:一种存储同类型数据的结构,可以进行索引访问和修改。 2. 链表:一种存储不同类型数据的结构,每个节点包含数据和指向下一个节点的指针。 3. 栈:一种后进先出(LIFO)的数据结构,可以通过压入(push)和弹出(pop)操作进行数据的存储和取出。 4. 队列:一种先进先出(FIFO)的数据结构,可以通过入队(enqueue)和出队(dequeue)操作进行数据的存储和取出。 5. 树:一种存储具有父子关系的数据结构,可以通过中序遍历、前序遍历和后序遍历等方式进行数据的访问和修改。 6. 图:一种存储具有节点和边关系的数据结构,可以通过广度优先搜索、深度优先搜索等方式进行数据的访问和修改。 这些数据结构在C语言中都有相应的实现方式,可以应用于各种不同的场景。C语言中的各种数据结构都有其优缺点,下面列举一些常见的数据结构的优缺点: 数组: 优点:访问和修改元素的速度非常快,适用于需要频繁取和修改数据的场合。 缺点:数组的长度是固定的,不适合存储大小不固定的动态数据,另外数组在内存中是连续分配的,当数组较大时可能会导致内存碎片化。 链表: 优点:可以方便地插入和删除元素,适用于需要频繁插入和删除数据的场合。 缺点:访问和修改元素的速度相对较慢,因为需要遍历链表找到指定的节点。 栈: 优点:后进先出(LIFO)的特性使得栈在处理递归和括号匹配等问题时非常方便。 缺点:栈的空间有限,当数据量较大时可能会导致栈溢出。 队列: 优点:先进先出(FIFO)的特性使得

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值