properties文件的加载方式

下面1-4的内容是网上收集的相关知识,总结来说,就是如下几个知识点:

  1. 最常用读取properties文件的方法
  2. InputStream in = getClass().getResourceAsStream("资源Name");这种方式要求properties文件和当前类在同一文件夹下面。如果在不同的包中,必须使用:
  3. InputStream ins = this.getClass().getResourceAsStream("/cn/zhao/properties/testPropertiesPath2.properties");
  4. Java中获取路径方法
  5. 获取路径的一个简单实现
  6. 反射方式获取properties文件的三种方式

1 反射方式获取properties文件最常用方法以及思考:

Java读取properties文件的方法比较多,网上最多的文章是"Java读取properties文件的六种方法",但在Java应用中,最常用还是通过java.lang.Class类的getResourceAsStream(String name) 方法来实现,但我见到众多读取properties文件的代码中,都会这么干:

InputStream in = getClass().getResourceAsStream("资源Name");

这里面有个问题,就是getClass()调用的时候默认省略了this!我们都知道,this是不能在static(静态)方法或者static块中使用的,原因是static类型的方法或者代码块是属于类本身的,不属于某个对象,而this本身就代表当前对象,而静态方法或者块调用的时候是不用初始化对象的。

问题是:假如我不想让某个类有对象,那么我会将此类的默认构造方法设为私有,当然也不会写别的共有的构造方法。并且我这个类是工具类,都是静态的方法和变量,我要在静态块或者静态方法中获取properties文件,这个方法就行不通了。

那怎么办呢?其实这个类就不是这么用的,他仅仅是需要获取一个Class对象就可以了,那还不容易啊--

取所有类的父类Object,用Object.class难道不比你的用你正在写类自身方便安全吗 ?呵呵,下面给出一个例子,以方便交流。

  1. import  java.util.Properties;
  2. import  java.io.InputStream;
  3. import  java.io.IOException;
  4. /**
  5. * 读取Properties文件的例子
  6. * File: TestProperties.java
  7. * User: leizhimin
  8. * Date: 2008-2-15 18:38:40
  9. */
  10. public   final   class  TestProperties {
  11. private   static  String param1;
  12. private   static  String param2;
  13. static  {
  14. Properties prop =  new  Properties();
  15. InputStream in = Object. class .getResourceAsStream( "/test.properties" );
  16. try  {
  17. prop.load(in);
  18. param1 = prop.getProperty( "initYears1" ).trim();
  19. param2 = prop.getProperty( "initYears2" ).trim();
  20. }  catch  (IOException e) {
  21. e.printStackTrace();
  22. }
  23. }
  24. /**
  25. * 私有构造方法,不需要创建对象
  26. */
  27. private  TestProperties() {
  28. }
  29. public   static  String getParam1() {
  30. return  param1;
  31. }
  32. public   static  String getParam2() {
  33. return  param2;
  34. }
  35. public   static   void  main(String args[]){
  36. System.out.println(getParam1());
  37. System.out.println(getParam2());
  38. }
  39. }
  40. 运行结果:
  41. 151
  42. 152

当然,把Object.class换成int.class照样行,呵呵,大家可以试试。

另外,如果是static方法或块中读取Properties文件,还有一种最保险的方法,就是这个类的本身名字来直接获取Class对象,比如本例中可写成TestProperties.class,这样做是最保险的方法

2 获取路径的方式:

  1. File fileB = new File( this .getClass().getResource( "" ).getPath());
  2. System. out .println( "fileB path: " + fileB);

2.2获取当前类所在的工程名:

  1. System. out .println("user.dir path: " + System. getProperty ("user.dir"))<span style="background-color: white;">3 获取路径的一个简单的Java实现</span>
  1. /**
  2. *获取项目的相对路径下文件的绝对路径
  3. *
  4. * @param parentDir
  5. *目标文件的父目录,例如说,工程的目录下,有lib与bin和conf目录,那么程序运行于lib or
  6. * bin,那么需要的配置文件却是conf里面,则需要找到该配置文件的绝对路径
  7. * @param fileName
  8. *文件名
  9. * @return一个绝对路径
  10. */
  11. public static String getPath(String parentDir, String fileName) {
  12. String path = null;
  13. String userdir = System.getProperty("user.dir");
  14. String userdirName = new File(userdir).getName();
  15. if (userdirName.equalsIgnoreCase("lib")
  16. || userdirName.equalsIgnoreCase("bin")) {
  17. File newf = new File(userdir);
  18. File newp = new File(newf.getParent());
  19. if (fileName.trim().equals("")) {
  20. path = newp.getPath() + File.separator + parentDir;
  21. } else {
  22. path = newp.getPath() + File.separator + parentDir
  23. + File.separator + fileName;
  24. }
  25. } else {
  26. if (fileName.trim().equals("")) {
  27. path = userdir + File.separator + parentDir;
  28. } else {
  29. path = userdir + File.separator + parentDir + File.separator
  30. + fileName;
  31. }
  32. }
  33. return path;
  34. }

4 利用反射的方式获取路径:

    1. InputStream ips1 = Enumeration . class .getClassLoader() .getResourceAsStream( "cn/zhao/enumStudy/testPropertiesPath1.properties" );
    2. InputStream ips2 = Enumeration . class .getResourceAsStream( "testPropertiesPath1.properties" );
    3. InputStream ips3 = Enumeration . class .getResourceAsStream( "properties/testPropertiesPath2.properties" );
时间: 2024-10-25 02:04:07

properties文件的加载方式的相关文章

C语言中库文件的加载方式

Linux下使用库有三种方式,静态链接库,动态链接库和动态加载库. -静态链接库: 在编译过程中,将所需要的库文件生成a文件并直接链接到最终的可执行文件当中,所以相对来讲,静态方式生成的image大小最大,对外界依赖小. -动态链接库: 在编译过程中,不会将库文件链接到最终的可执行文件当中,当程序运行之初会加载所需要的动态库.知道程序运行结束在卸载,如果运行时无法找到对应的库文件,运行失败. -动态加载库: 编译过程跟动态链接库并无区别.在运行方式上,当需要加载库文件的时候,需要显式的调用动态库

SpringMVC加载配置Properties文件的几种方式

最近开发的项目使用了SpringMVC的框架,用下来感觉SpringMVC的代码实现的非常优雅,功能也非常强大, 网上介绍Controller参数绑定.URL映射的文章都很多了,写这篇博客主要总结一下SpringMVC加载配置Properties文件的几种方式 通过读取Config文件的配置例如: Map<String, String> group = ConfigurationManager.GetConfiguration("config1"); this.setBcp

1.引入必要的文件 2.加载 UI 组件的方式 4.Parser 解析器

1 //引入 jQuery 核心库,这里采用的是 2.0 <scripttype="text/javascript"src="easyui/jquery.min.js"></script> //引入 jQuery EasyUI 核心库,这里采用的是 1.3.6 <scripttype="text/javascript"src="easyui/jquery.easyui.min.js"><

三种加载方式

重点总结:    即:三种加载方式    1>传统加载方式------默认路径:tomcat/bin/目录    2>使用ServletContext对象-----默认路径:web应用(工程)目录    3>使用类加载器------默认路径:WEB-INF/classes/目录 一.利用ServletContext对象读取资源文件--默认目录为:工程(应用)路径                重点方法:                        InputStream getReso

log4j.properties配置与加载应用

log4j.properties总结: 一.介绍 Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI组件.甚至是套接口服务 器.NT的事件记录器.UNIX Syslog守护进程等:我们也可以控制每一条日志的输出格式:通过定义每一条日志信息的级别,我们能够更加细致地控制日志的生成过程. Log4j由三个重要的组件构成:日志信息的优先级,日志信息的输出目的地,日志信息的输出格式.日志信息的优先级从高到低有ERROR.WARN. I

实现异步加载js文件及加载完成后回调

模块化工具类实现方式 基于AMD.CMD模式的JS模块化管理工具越来越流行,这些工具通常只需在页面中加载对应的工具JS,其他JS文件都是异步加载的,比如RequireJS就可以象下面这样做. 首先在页面加载 <script data-main="scripts/main.js" src="scripts/require.js"></script> 然后工具会自动识别data-main属性值,并加载对应的JS文件,在main.js可以加载更多模

iOS 正确选择图片加载方式

正确选择图片加载方式能够对内存优化起到很大的作用,常见的图片加载方式有下面三种: //方法1 UIImage *imag1 = [UIImage imageNamed:@"image.png"]; //方法2 UIImage *image2 = [UIImage imageWithContentsOfFile:[[NSBundle mainBundle] pathForResource:@"image.png" ofType:nil]]; //方法3 NSData

浅谈Entity Framework中的数据加载方式

小分享:我有几张阿里云优惠券,用券购买或者升级阿里云相应产品最多可以优惠五折!领券地址:https://promotion.aliyun.com/ntms/act/ambassador/sharetouser.html?userCode=ohmepe03 如果你还没有接触过或者根本不了解什么是Entity Framework,那么请看这里http://www.entityframeworktutorial.net/EntityFramework-Architecture.aspx,其中的一系列文

sql*loader的直接加载方式和传统加载方式的性能差异

1.确认数据库版本 2.数据准备 3.创建导入表及控制文件 4.直接加载方式演示 查看具体的日志: 5.传统加载方式演示 查看日志文件: 6.结论及两种方式的差异 经过比对direct比conventional要提高了10倍效率. 对比这两种加载方式的区别: Direct 特点 ü  数据绕过SGA直接写入磁盘的数据文件. ü  数据直接写入高水位线HWM之后的新块,不会扫描HWM之前的空闲块. ü  commit之后移动HWM他人才能看到. ü  不对已用空间进行扫描. ü  使用direct