java.lang.Runtime类总结 【转】

转自:http://blog.chinaunix.net/uid-128922-id-289994.html

 Runtime类封装了运行时的环境。每个 Java 应用程序都有一个 Runtime 类实例,使应用程序能够

与其运行的环境相连接。一般不能实例化一个Runtime对象,应用程序也不能创建自己的 Runtime 类

实例,但可以通过 getRuntime 方法获取当前Runtime运行时对象的引用。 一旦得到了一个当前的

Runtime对象的引用,就可以调用Runtime对象的方法去控制Java虚拟机的状态和行为。

常见的应用有 1:执行外部程序(调用外部命令) 举例:用java调用外部mcl数据分析工具(之前我已经把mcl安装的bin目录导入到了PATH中) String [] cmd={"cmd","/C","mcl D:\\input.txt --abc -o D:\\output.txt -I 1 -scheme 7"}; Process proc =Runtime.getRuntime().exec(cmd);

注意目录中用“\\”代替"\"。 如果外部命令过于复杂可以自己写一个bat或shell脚本然后调用 如下 String [] cmd={"cmd","/C","E:\\test3.bat"}; Process proc =Runtime.getRuntime().exec(cmd);

下面对Runtime.exec()做个总结

Windows下调用程序

Process proc =Runtime.getRuntime().exec("exefile");

Linux下调用程序就要改成下面的格式

Process proc =Runtime.getRuntime().exec("./exefile");

Windows下调用系统命令

String [] cmd={"cmd","/C","copy exe1 exe2"};
Process proc =Runtime.getRuntime().exec(cmd);

Linux下调用系统命令就要改成下面的格式

String [] cmd={"/bin/sh","-c","ln -s exe1 exe2"};
Process proc =Runtime.getRuntime().exec(cmd);

Windows下调用系统命令并弹出命令行窗口

String [] cmd={"cmd","/C","start copy exe1 exe2"};
Process proc =Runtime.getRuntime().exec(cmd);

Linux下调用系统命令并弹出终端窗口就要改成下面的格式

String [] cmd={"/bin/sh","-c","xterm -e ln -s exe1 exe2"};
Process proc =Runtime.getRuntime().exec(cmd);

还有要设置调用程序的工作目录就要

Process proc =Runtime.getRuntime().exec("exeflie",null, new File("workpath"));

2:内存管理

Java提供了无用单元自动收集机制。通过totalMemory()和freeMemory()方法可以知道对象的堆内存有多大,还剩多少。

Java会周期性的回收垃圾对象(未使用的对象),以便释放内存空间。但是如果想先于收集器的下一次指定周期来收集废弃的对象,可以通过调用gc()方法来根据需要运行无用单元收集器。

一个很好的试验方法是先调用gc()方法,然后调用freeMemory()方法来查看基本的内存使用情况,接着执行代码,然后再次调用freeMemory()方法看看分配了多少内存。

下面的程序演示了这个构想。

class MemoryDemo{ 
        public static void main(String args[]){ 
                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); 
                //allocate integers 
                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));    
                //discard Intergers 
                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); 
        } 
}

编译后运行结果如下(不同的机器不同时间运行的结果也不一定一样):

Total memory is :2031616

Initial free is : 1818488

Free memory after garbage collection : 1888808

Free memory after allocation : 1872224

Memory used by allocation : 16584

Free memory after collecting discarded integers : 1888808

 

时间: 2024-10-27 12:41:44

java.lang.Runtime类总结 【转】的相关文章

深入研究java.lang.Runtime类【转】

  转自:http://blog.csdn.net/lastsweetop/article/details/3961911 目录(?)[-] javalang 类 Runtime getRuntime exit addShutdownHook removeShutdownHook halt runFinalizersOnExit exec exec exec exec exec exec availableProcessors freeMemory totalMemory maxMemory g

源码-JDK1.7中java.lang.String类的toCharArray方法注释:不能用Arrays.copyOf实现?求解惑

问题描述 JDK1.7中java.lang.String类的toCharArray方法注释:不能用Arrays.copyOf实现?求解惑 JDK1.7重新设计了String类,各个String对象各自维护一个属于自身的char数组,下面是该类中的toCharArray方法的实现源码:public char[] toCharArray() { // Cannot use Arrays.copyOf because of class initialization order issues char

Java中java.lang.Void类学习笔记

在阅读JDK源代码的时候发现了有Void这么个类,Void类是一个不可实例化的占位符类,它持有对标识Java关键字void的Class对象的引用. Void的类定义如下: package java.lang; public final class Void {   private Void() {   }   public static final Class TYPE = Class.getPrimitiveClass("void"); } 我是在看ThreadGroup类的源码时发

从java.lang.Runtime看单例懒汉饿汉模式的选择

单例模式有懒汉和饿汉模式,代码就不在此赘述了.懒汉模式会带来线程安全的问题,所以一般采用饿汉模式.从Java的源代码中也可看出应该选择饿汉模式. public class Runtime {     private static Runtime currentRuntime = new Runtime();     public static Runtime getRuntime() {            return currentRuntime;     }     private Ru

java.lang.Runtime中的单例模式

public class Runtime {     private static Runtime currentRuntime = new Runtime();     public static Runtime getRuntime() {            return currentRuntime;     }     private Runtime() { } } 这是典型的饿汉模式.懒汉和饿汉各有应用场景,请看文章:http://blog.csdn.net/woshixuye/a

java.lang包下的类能不能被代理,为什么??

问题描述 java.lang包下的类能不能被代理,为什么?? 今天碰到一个问题,说是java.lang下的类不能被代理? 想知道原因是什么? 解决方案 绝对不能.要是你能随便代理,那JVM的安全何在? java.lang这个包是java的核心包.这个包下的类是有顶级的BootStrap 引导类加载器加载.java的类加载器是双亲委派机制,意思就是上层加载器加载过了,就不再加载. 举个例子,你自己定义一个类加载器.自己写个java.lang.String类,然后尝试着用自己的类加载器去加载,绝对加

java调用Runtime.getRuntime().exec执行解压RAR压缩包时只能在系统刚启动时解压一次,应该怎么解决?

问题描述 Processp=Runtime.getRuntime().exec(unrarCmd);iState=p.waitFor();核心语句就是上面两句,语句都正确,但只有在Tamcat重启时才能正常解压一次,很是郁闷,不知道怎么解决,如有高手赐教,不胜感激. 解决方案 解决方案二:该回复于2010-01-30 22:55:22被版主删除解决方案三:路过,两行代码看不出什么问题,整个流程贴出来还差不多解决方案四:....代码给的太少了,给你个能用的解压缩例子.java解压缩文件import

Java中的类反射机制

一.反射的概念 :反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问.检测和修改它本身状态或行为的一种能力.这一概念的提出很快引发了计算机科学领域关于应用反射性的研究.它首先被程序语言的设计领域所采用,并在Lisp和面向对象方面取得了成绩.其中LEAD/LEAD++ .OpenC++ .MetaXa和OpenJava等就是基于反射机制的语言.最近,反射机制也被应用到了视窗系统.操作系统和文件系统中. 反射本身并不是一个新概念,它可能会使我们联想到光学中的反射概念,尽管计算机科学

java.lang.UnsatisfiedLinkError: Couldn&amp;#039;t load hyphenate_av: findLibrary returned null

问题描述 用的是easeUI的library,参照ChatDemoUI3.0写的,运行直接报错:java.lang.UnsatisfiedLinkError: Couldn't load hyphenate_av: findLibrary returned null            at java.lang.Runtime.loadLibrary(Runtime.java:365)at java.lang.System.loadLibrary(System.java:535)at com.