1、概述
- 每个java应用程序都包含一个Runtime类的实例,使应用程序能与其运行环境相连接(exec方法与运行环境进行交互);
- 一般不能实例化Runtime(中文名:运行时)实例,应用程序也无法创建自身的Runtime实例,只能通过调用getRuntime方法获得其Runtime对象的引用;
- 一旦得到一个Runtime对象的引用,就可以调用Runtime对象的方法去控制java虚拟机的状态和行为;(问:虚拟机状态和行为都有哪些?)
- 当Applet或者不被信任的代码调用任何Runtime方法时,常常会引起SecurityException异常
2、API预览(主要介绍exec方法,其他方法可查jdk)
- exec(String command)
在单独的进程中执行指定的字符串命令。 - exec(String[] cmdarray)
在单独的进程中执行指定命令和变量。 - exec(String[] cmdarray, String[] envp)
在指定环境的独立进程中执行指定命令和变量。 - exec(String[] cmdarray, String[] envp, File dir)
在指定环境和工作目录的独立进程中执行指定的命令和变量。 - exec(String command, String[] envp)
在指定环境的单独进程中执行指定的字符串命令。 - exec(String command, String[] envp, File dir)
在有指定环境和工作目录的独立进程中执行指定的字符串命令。
3、常见应用
public static void main(String[] args) {
// 1、内存管理
/**
* Java提供了无用单元自动收集机制。通过totalMemory()和freeMemory()方法可以知道对象
* 的堆内存有多大,还剩多少。Java会周期性的回收垃圾对象(未使用的对象),以便释放内存空间。
* 但是如果想先于收集器的下一次指定周期来收集废弃的对象,可以通过调用gc()方法来根据需要运行
* 无用单元收集器。一个很好的试验方法是先调用gc()方法,然后调用freeMemory()方法来查看基
* 本的内存使用情况,接着执行代码,然后再次调用freeMemory()方法看看分配了多少内存。下面 的程序演示了这个构想。
*/
Runtime r = Runtime.getRuntime();
long mem1, mem2;
Integer someints[] = new Integer[1000];
System.out.println("Total memory is :" + r.totalMemory());
mem1 = r.freeMemory();
System.out.println("Initial free is : " + mem1);
// 主动调用垃圾回收方法,释放堆内存
r.gc();
mem1 = r.freeMemory();
System.out.println("Free memory after garbage collection : " + mem1);
// 分配整数数组空间
for (int i = 0; i < 1000; i++)
someints[i] = new Integer(i);
mem2 = r.freeMemory();
System.out.println("Free memory after allocation : " + mem2);
System.out.println("Memory used by allocation : " + (mem1 - mem2));
// 分配的数组置空
for (int i = 0; i < 1000; i++)
someints[i] = null;
r.gc(); // request garbage collection
mem2 = r.freeMemory();
System.out.println("Free memory after collecting "
+ "discarded integers : " + mem2);
// 2、执行其他程序
/**
* 在安全的环境中,可以在多任务操作系统中使用Java去执行其他特别大的进程(也就是程序)。
* ecec()方法有几种形式命名想要运行的程序和它的输入参数。ecec()方法返回一个
* Process对象,可以使用这个对象控制Java程序与新运行的进程进行交互。ecec()方法 本质是依赖于环境。
*/
Process p = null;
try {
p = r.exec("notepad"); // 开启notepad子进程
p.waitFor(1, TimeUnit.SECONDS); // 等待子进程结束后(设置等待1秒),方可继续执行
p.destroy(); // 关闭子进程
} catch (Exception e) {
System.out.println("Error executing notepad.");
}
}
当子进程正在运行时,可以对标准输入输出进行读写。getOutputStream()方法和getInPutStream()方法返回对子进程的标准输入和输出。
以上大部分内容来自SUN公司的java.long.Runtime类的API文档,相关代码来《java核心技术》