首页 > 学院 > 开发设计 > 正文

JBuilder 9.0开发实用技巧七招

2019-11-18 12:02:55
字体:
来源:转载
供稿:网友

  同步输出目录
  在java开发过程中,有时候我们要创建一些简单的类来测试某些功能,测试完成后就从磁盘删除该类的源文件,因为我们不想让该类出现在最终的产品中。但是,虽然源文件已经被删除,编译好的class文件仍可能留在磁盘上,当有其他的类依靠于该类,就可能导致开发环境的不稳定。
  
  在JBuilder中,我们可以设置一个编译选项来同步(Synchronize)Java的源文件和对应的类,这样,一旦Java源文件被删除,对应的class文件也将被删除。按照如下步骤设置该同步选项:
  
  打开 PRoject Project Properties...
  
  选择 Compiler 选项卡,看到如下对话框:
  
 JBuilder 9.0开发实用技巧七招(图一)


  注重Synchronize output dir选项。选中该选项就可以实现输出目录同步,每次编译时JBuilder将保证Java源文件与Java class文件的同步。
  输出调试信息
  
  很多时候,我们要向标准输出设备输出一些简单的变量值,以便了解程序的运行情况。例如,在程序中加入类似下面的代码:
  
  System.out.println("调试信息: 变量的值是" + value);
  
  当编写和调试代码的工作结束,接下去就要进行最后的编译和打包,这时就要删除所有上面这些System.out.println代码。为了避免这些麻烦,我们可以引入一个逻辑变量debugMode,把它设置为true,并在输出调试信息之前检查这个变量的值:
  
  if (debugMode)
  System.out.println("调试信息: 变量的值是" + value);
  
  所有调试工作结束之后,再把debugMode变量设置成false,这样程序运行时就不会再输出调试信息。
  
  但是,这还不是处理类似调试信息的最佳办法,我们可以用Diagnostic类来改进。Diagnostic类有三个与输出流有关的方法,除了标准的System.err输出流,还可以赋予其他不同的输出流(例如文件或URL)。最重要的是,当编写和调试代码的工作结束之后,我们可以在正式编译时排除Diagnostic类,从而也就排除了对Diagnostic类方法的所有调用。
  
  下面是Diagnostic类中可用于输出信息的三个方法:
  
  print(String message):输出信息
  println(String message):输出信息,并追加行结束符。
  printlnc(String message):输出带有行结束符、计数器(它的值不断递进)和Tab字符的信息。
  
  因此,我们可以把上面的System.out.println替换为:
  
  Diagnostic.printlnc("调试信息:变量的值是:" + value);
  
  这些输出方法的标准输出设备是System.err,但我们可以用setLogStream(PrintStream log)方法改变它。例如,假设要把输出发送到log.txt文件,只需插入如下代码:
  
  Diagnostic.setLogStream(new java.io.PrintStream(new
  java.io.FileOutputStream("log.txt")));
  
  最后,在开发期间,我们只需调用一个方法就可以关闭所有的输出:
  
  Diagnostic.enable(false);
  
  资源捆绑
  在Java中,要把直接嵌入到程序的字符串作为资源使用是很轻易的。例如,只要把字符串保存到一个独立的文件,我们就可以很方便地通过创建不同的文件实现对多种语言的支持。
  
  为了把“硬编码”的字符串保存到资源捆绑文件,标准Java API提供两种办法:
  
  • 把键-值对以属性文件的形式保存到文本文件。
  
  • 把键-值对保存到Java源文件中的String[][]数组对象,该Java源文件从java.util.ListResourceBundle扩展。
  
  第一种方法具有较好的灵活性,可以在不重新编译的前提下修改字符串值。第二种方法具有较好的性能,但每次修改字符串值,包含键-值对的Java源代码文件都必须重新编译。JBuilder提供了保存硬编码字符串值的第三种方法,即com.borland.jb.util.ArrayResourceBundle。
  
  ArrayResourceBundle类通过一个String[]数组对象保存键的值,但不包含键,我们可以通过索引访问值,即第一个值的索引为0,第二个值的索引为1,等等。由于可以直接访问值,因此性能相当好。但也有缺点——维护保存值的文件很困难,因为值和键之间没有直接的(直观的)联系。
  异常跟踪
  
  在Java中,利用try..catch(..finally)语句可以捕捉和处理异常,非常方便。catch块的常见异常处理方式是输出异常,例如把异常输出到日志文件。
  
  Exception类有一个printStackTrace()方法,它能够从发生异常的方法中输出堆栈信息,默认输出位置是System.err。但是,有时候我们要把堆栈信息输出到System.err之外的其他地方,例如在出现异常时把堆栈信息输出到email,或者用一个对话框显示出来。
  
  printStackTrace()方法有几种不同的类型:
  
  • printStackTrace(),输出到标准错误流。
  
  • printStackTrace(PrintStream ps),输出到名为ps的PrintStream。
  
  • printStackTrace(PrintWriter pw),输出到名为pw的PrintWriter。
  
  我们可以用最后一种printStackTrace()方法把堆栈信息保存到String对象。只要在String对象中捕捉了堆栈信息,我们就可以方便地在应用的任何地方使用这些信息了。下面的代码片断示范了具体的实现步骤:
  
  private String getStackTraceAsString() {
  // StringWriter将包含堆栈信息
  StringWriter stringWriter = new StringWriter();
  //必须将StringWriter封装成PrintWriter对象,
  //以满足printStackTrace的要求
  PrintWriter printWriter = new PrintWriter(stringWriter);
  //获取堆栈信息
  e.printStackTrace(printWriter);
  //转换成String,并返回该String
  StringBuffer error = stringWriter.getBuffer();
  return error.toString();
  }
  
  快速查看JavaBean基本信息
  在JBuilder中,要查看JavaBean的内部信息是非常方便的。我们可以把JavaBean拖入设计窗口中,通过Object Inspector查看JavaBean的属性和事件。但是,即使不通过设计器,我们也可以查看JavaBean的信息,这就是使用BeanInsight(菜单:Tools BeanInsight)。
  
JBuilder 9.0开发实用技巧七招(图二)

  点击Examine Bean按钮就开始分析指定的JavaBean,在BeanInsight Result区域可以看到分析JavaBean的结果。假如要了解更具体的信息,点击“View Details...”按钮。
  
  多个行的属性值
  属性文件是保存应用配置信息的好方法。有了属性文件,修改应用参数时只需修改简单的属性文本文件,无需重新编译整个应用。
  
  属性文件以“键-值”对的形式保存数据。每一个行以键开头,加上一个等于符号,再加上与该键对应的值。键与值必须在同一个行上,这一点很重要。但是,有些时候,值的内容非常多,假如值能够分成多行存放,将带来很大的方便。下面我们就来看看如何使用多行的属性值。
  
  首先,下面这个代码片断读取test.properties属性文件:
  
  try {
  Properties p = new Properties();
  File file = new File("test.properties");
  FileInputStream fis = new FileInputStream(file);
  p.load(fis);
  } catch (IOException ioex) {
  ioex.printStackTrace();
  }
  
  Properties类的load()方法需要一个输入流作为参数,这里我们向它传入了一个FileInputStream对象。
  
  接下来,我们就可以通过调用getProperty()方法从Properties对象获取属性值。下面我们来看看test.properties属性文件的内容:
  
  singleline=Single line value
  multiline =This example shows how we
  can write a property
  value over multiple lines in a
  properties file
  
  这个属性文件保存了两个属性,键分别是singleline和multiline。singleline的值只有一行,而multiline的值有多行。
  
  假如我们调用Properties对象的getProperty()方法,并输出属性值,结果将是:
  
  调用:
  
  System.out.println("singleline? " + p.getProperty("singleline"));
  System.out.println("multiline ? " + p.getProperty("multiline"));
  
  结果:
  
  singleline? Single line value
  multiline ? This example shows how we
  
  multiline属性只包含了第一行值。那么,如何解决这个问题呢?其实很简单,只需要在每个行的末尾加上转义字符“/”就可以了。修改后的属性文件如下所示:
  
  singleline=Single line value
  multiline =This example shows how we can write a property value over multiple lines in a properties file
  
  再次读取属性文件的值,multiline的属性值就能够完整地读取出来

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表