java使用Runtime调用exp.exe导出Oracle数据进程挂起的问题

  写个批处理,来导出Oracle的数据,名字为:c:\t.bat,内容如下:
  exp hr/hr file=c:\hr.dmp

  然后使用Runtime.getRuntime().exec()函数来执行这个批处理,进程竟然挂起,始终不出结果。dmp文件会生成,但大小为0。

  这是个很奇怪的问题,经过不停的尝试,终于找到了解决的办法。代码如下:
        Process process=Runtime.getRuntime().exec(“c:\\t.bat”);
        try {
           String line = null;
           BufferedReader br = 
                   new BufferedReader(new InputStreamReader(process.getErrorStream()));
           //读取ErrorStream很关键,这个解决了挂起的问题。
           while ((line = br.readLine()) != null){
                System.out.println(line);
            }
           br = new BufferedReader(new InputStreamReader(process.getInputStream()));
           while ((line = br.readLine()) != null){
                System.out.println(line);
            }
           process.waitFor();
        } 
        catch (Exception ioe) {
            ;
        }


  使用Runtime执行操作系统命令的时候,如果命令中有空格,会遇到麻烦。JAVA有点弱智,不能像WINDOWS批处理一样,用引号来解决。我使用命令数组版本的exec函数,它也不能正常认识,哎。既然命令数组,是用来把命令、参数分开的,那它为什么还会受命令中的空格干扰??
  这时的处理办法是:使用cmd /C start "命令字符串",此时有命令字符串中就要以有空格了。如果是批处理命令,不要忘记在末尾加一个exit,不然Runtime会挂起。

你可能感兴趣的:(java,oracle,C++,c,C#)