JAVA通信编程(二)——如何读取java的properties配置文件(插播)

如何读取java的properties配置文件本不属于java通讯编程这个系列的范畴,但是在做一些应用中编写通讯编程需要读取一些通讯参数,这样可以使程序更加的通用化。并且博主在读取properties文件中遇到了点小坑,在这里说明一下,防止各位读者遇到同样的麻烦。

其实问一下度娘,就有很多信息关于如何读取java的properties配置文件的,这里我做一下小封装。

package com.zzh.comm;

import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.HashMap;
import java.util.Map;
import java.util.Properties;
import java.util.Set;

import org.apache.log4j.Logger;

public final class ReadProperties
{
	private static Logger logger = Logger.getLogger(Object.class.getName());

	public Map<String, String> getPropertiesMap(String fileName)
	{
		Map<String,String> map  = new HashMap<String,String>();
		Properties prop = new Properties();
		InputStream in = null;
		try
		{
			in = Object.class.getResourceAsStream(fileName);
			prop.load(in); 

			Set<String> set = prop.stringPropertyNames();
			for(String s: set)
			{
				String value = prop.getProperty(s);
				if(value != null)
				{
					map.put(s,value);
				}
			}
		}
		catch(Exception e)
		{
			logger.error(e.getMessage());
		}
		finally
		{
			if(in != null)
			{
				try
				{
					in.close();
				}
				catch (IOException e)
				{
					logger.error(e.getMessage());
				}
			}
		}

		return map;
	}
}

这样可以通过Map<String,String> map = new ReadProperties().getPropertiesMap(fileName);的方式很方便的读取配置文件中的内容,然后在上层应用中直接读取Map中的参数。

这里主要关注下in = Object.class.getResourceAsStream(fileName);这一句,博主是在Eclipse下建立的一个project来编写这个程序,我直接在project存放properties文件,但是当我将project打成jar包然后在linux下独立运行的时候就会发生错误,主要是因为涉及到一些规范,需要将properties存放在某些规定的目录下,而并不在project下,即不在打包的jar中,所以这样是会有读取错误的,需要将in
= Object.class.getResourceAsStream(fileName);换成in = new BufferedInputStream(new FileInputStream(new File(fileName)));这样可以读取非classpath路径下的properties文件,反之,如果要读取classpath下的properties文件需要采用in = Object.class.getResourceAsStream(fileName);这种方式或者类似的方式。

时间: 2025-01-01 16:33:58

JAVA通信编程(二)——如何读取java的properties配置文件(插播)的相关文章

JAVA通信编程(三)——TCP通讯

继上一篇小插曲之后继续回到正题,本篇讲述的是java的TCP通讯.TCP编程分为server端和client端,一般在网上都能搜到相关的例子,为了方便大家,我这里先整理下server端和client端的应用案例,然后再根据在本系列中第一篇串口通讯中的结构一样实现CommBuff接口. java tcp socket编程server端: import java.io.*; import java.net.*; import java.applet.Applet; public class Talk

《Java并发编程的艺术》-Java并发包中的读写锁及其实现分析

作者:魏鹏  本文是<Java并发编程的艺术>的样章 1. 前言 在Java并发包中常用的锁(如:ReentrantLock),基本上都是排他锁,这些锁在同一时刻只允许一个线程进行访问,而读写锁在同一时刻可以允许多个读线程访问,但是在写线程访问时,所有的读线程和其他写线程均被阻塞.读写锁维护了一对锁,一个读锁和一个写锁,通过分离读锁和写锁,使得并发性相比一般的排他锁有了很大提升. 除了保证写操作对读操作的可见性以及并发性的提升之外,读写锁能够简化读写交互场景的编程方式.假设在程序中定义一个共享

JAVA通信编程(四)——UDP通讯

经过TCP和串口通讯编程的了解,相信大家应该掌握CommBuff的套路了,这里首先展示的是通过UDP编程的方式实现CommBuff接口,之后通过简单工厂模式的应用说明如何屏蔽底层通讯差异. UdpImpl类如下: package com.zzh.comm; import java.io.IOException; import java.net.DatagramPacket; import java.net.DatagramSocket; import java.net.InetAddress;

Java函数式编程(二):集合的使用_java

第二章:集合的使用 我们经常会用到各种集合,数字的,字符串的还有对象的.它们无处不在,哪怕操作集合的代码要能稍微优化一点,都能让代码清晰很多.在这章中,我们探索下如何使用lambda表达式来操作集合.我们用它来遍历集合,把集合转化成新的集合,从集合中删除元素,把集合进行合并. 遍历列表 遍历列表是最基本的一个集合操作,这么多年来,它的操作也发生了一些变化.我们使用一个遍历名字的小例子,从最古老的版本介绍到现在最优雅的版本. 用下面的代码我们很容易创建一个不可变的名字的列表: 复制代码 代码如下:

java基础-java面向对象编程二

01.面向对象(static关键字) 用法:是一个修饰符,用于修饰成员(成员变量和成员函数). 当成员被静态修饰后,就多了一种调用方式,除了可以被对象调用之外,还可以被类名直接调用.类名.静态成员. 对象的特有内容随着对象存储,共有内容可以定义为静态的,放在共享区. 类中的方法区,共享区,数据区都在同一个区. static的特点: (1)随着类的加载而加载,随着类的消失而消失.也就是说,静态会随着类的消失而消失,说明他的生命周期最长. (2)优先于对象存在:明确一点:静态先存在,对象后存在. (

flex+java 通信 怎么调用不到java的方法

问题描述 就是一个很简单的heollword的例子 开始我能调用java方法 可是后来我怎么也调用不到java方法了.在此谢谢了但是我在别的机器上发布了 测试可以调用java方法 为什么我的机器不能.FirstJavaFlex.mxml 文件代码 <?xml version="1.0" encoding="utf-8"?><mx:Application xmlns:mx="http://www.adobe.com/2006/mxml&qu

Java多线程编程中使用Condition类操作锁的方法详解_java

Condition的作用是对锁进行更精确的控制.Condition中的await()方法相当于Object的wait()方法,Condition中的signal()方法相当于Object的notify()方法,Condition中的signalAll()相当于Object的notifyAll()方法.不同的是,Object中的wait(),notify(),notifyAll()方法是和"同步锁"(synchronized关键字)捆绑使用的:而Condition是需要与"互斥

详解Java设计模式编程中的策略模式_java

定义:定义一组算法,将每个算法都封装起来,并且使他们之间可以互换.类型:行为类模式类图: 策略模式是对算法的封装,把一系列的算法分别封装到对应的类中,并且这些类实现相同的接口,相互之间可以替换.在前面说过的行为类模式中,有一种模式也是关注对算法的封装--模版方法模式,对照类图可以看到,策略模式与模版方法模式的区别仅仅是多了一个单独的封装类Context,它与模版方法模式的区别在于:在模版方法模式中,调用算法的主体在抽象的父类中,而在策略模式中,调用算法的主体则是封装到了封装类Context中,抽

详解Java设计模式编程中的中介者模式_java

定义:用一个中介者对象封装一系列的对象交互,中介者使各对象不需要显示地相互作用,从而使耦合松散,而且可以独立地改变它们之间的交互. 类型:行为类模式 类图: 中介者模式的结构       中介者模式又称为调停者模式,从类图中看,共分为3部分:  抽象中介者:定义好同事类对象到中介者对象的接口,用于各个同事类之间的通信.一般包括一个或几个抽象的事件方法,并由子类去实现. 中介者实现类:从抽象中介者继承而来,实现抽象中介者中定义的事件方法.从一个同事类接收消息,然后通过消息影响其他同时类. 同事类: