一般我们在java中运行其它类中的方法时,无论是静态调用,还是动态调用,都是在当前的进程中执行的,也就是说,只有一个java虚拟机实例在运行。而有的时候,我们需要通过java代码启动多个java子进程。这样做虽然占用了一些系统资源,但会使程序更加稳定,因为新启动的程序是在不同的虚拟机进程中运行的,如果有一个进程发生异常,并不影响其它的子进程。
// test1.java文件 【相关文章:java中传值及引伸深度克隆的思考】
在java中我们可以使用两种方法来实现这种要求。最简单的方法就是通过runtime中的exec方法执行java classname。如果执行成功,这个方法返回一个process对象,如果执行失败,将抛出一个ioexception错误。下面让我们来看一个简单的例子。 【扩展阅读:Java技术在嵌入式系统中的应用】
【扩展信息:Java实现ftp功能】 import java.io.*; public class test { public static void main(string[] args) { fileoutputstream fout = new fileoutputstream("c:\\test1.txt"); fout.close(); system.out.println("被调用成功!"); } }// test_exec.java
public class test_exec { public static void main(string[] args) { runtime run = runtime.getruntime(); process p = run.exec("java test1"); } }通过java test_exec运行程序后,发现在c盘多了个test1.txt文件,但在控制台中并未出现“被调用成功!”的输出信息。因此可以断定,test已经被执行成功,但因为某种原因,test的输出信息未在test_exec的控制台中输出。这个原因也很简单,因为使用exec建立的是test_exec的子进程,这个子进程并没有自己的控制台,因此,它并不会输出任何信息。
如果要输出子进程的输出信息,可以通过process中的getinputstream得到子进程的输出流(在子进程中输出,在父进程中就是输入),然后将子进程中的输出流从父进程的控制台输出。具体的实现代码如下如示:
// test_exec_out.java
import java.io.*; public class test_exec_out { public static void main(string[] args) { runtime run = runtime.getruntime(); process p = run.exec("java test1"); ... 下一页