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

 

转自:http://blog.csdn.net/lastsweetop/article/details/3961911

目录(?)[-]

  1. javalang 类 Runtime
    1. getRuntime
    2. exit
    3. addShutdownHook
    4. removeShutdownHook
    5. halt
    6. runFinalizersOnExit
    7. exec
    8. exec
    9. exec
    10. exec
    11. exec
    12. exec
    13. availableProcessors
    14. freeMemory
    15. totalMemory
    16. maxMemory
    17. gc
    18. runFinalization
    19. traceInstructions
    20. traceMethodCalls
    21. load
    22. loadLibrary
    23. getLocalizedInputStream
    24. getLocalizedOutputStream

 

前言:Java的类库日益庞大,所包含的类和接口也不计其数。但其中有一些非常重要的类和接口,是Java类库中的核心部分。常见的有String、Object、Class、Collection、ClassLoader、Runtime、Process...,熟悉这些类是学好Java的基础。而这些类一般不容易理解,需要做深入的研究和实践才能掌握。下面是我对这些类理解和使用的一些总结。欢迎你在阅读后将你宝贵的意见和读后感留下!

 

一、概述
      Runtime类封装了运行时的环境。每个 Java 应用程序都有一个 Runtime 类实例,使应用程序能够与其运行的环境相连接。
      一般不能实例化一个Runtime对象,应用程序也不能创建自己的 Runtime 类实例,但可以通过 getRuntime 方法获取当前Runtime运行时对象的引用。
      一旦得到了一个当前的Runtime对象的引用,就可以调用Runtime对象的方法去控制Java虚拟机的状态和行为。 
      当Applet和其他不被信任的代码调用任何Runtime方法时,常常会引起SecurityException异常。

 

二、API预览
    addShutdownHook(Thread hook) 
      注册新的虚拟机来关闭挂钩。 
    availableProcessors() 
      向 Java 虚拟机返回可用处理器的数目。 
    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) 
      在有指定环境和工作目录的独立进程中执行指定的字符串命令。 
    exit(int status) 
      通过启动虚拟机的关闭序列,终止当前正在运行的 Java 虚拟机。 
    freeMemory() 
      返回 Java 虚拟机中的空闲内存量。 
    gc() 
      运行垃圾回收器。 
    InputStream getLocalizedInputStream(InputStream in) 
      已过时。 从 JDK 1.1 开始,将本地编码字节流转换为 Unicode 字符流的首选方法是使用 InputStreamReader 和 BufferedReader 类。 
    OutputStream getLocalizedOutputStream(OutputStream out) 
      已过时。 从 JDK 1.1 开始,将 Unicode 字符流转换为本地编码字节流的首选方法是使用 OutputStreamWriter、BufferedWriter 和 PrintWriter 类。 
    getRuntime() 
      返回与当前 Java 应用程序相关的运行时对象。 
    halt(int status) 
      强行终止目前正在运行的 Java 虚拟机。 
    load(String filename) 
      加载作为动态库的指定文件名。 
    loadLibrary(String libname) 
      加载具有指定库名的动态库。 
    maxMemory() 
      返回 Java 虚拟机试图使用的最大内存量。 
    removeShutdownHook(Thread hook) 
      取消注册某个先前已注册的虚拟机关闭挂钩。 
    runFinalization() 
      运行挂起 finalization 的所有对象的终止方法。 
    runFinalizersOnExit(value) 
      已过时。 此方法本身具有不安全性。它可能对正在使用的对象调用终结方法,而其他线程正在操作这些对象,从而导致不正确的行为或死锁。 
    totalMemory() 
      返回 Java 虚拟机中的内存总量。 
    traceInstructions(on) 
      启用/禁用指令跟踪。 
    traceMethodCalls(on) 
      启用/禁用方法调用跟踪。

 

三、常见的应用

1、内存管理:
Java提供了无用单元自动收集机制。通过totalMemory()和freeMemory()方法可以知道对象的堆内存有多大,还剩多少。
Java会周期性的回收垃圾对象(未使用的对象),以便释放内存空间。但是如果想先于收集器的下一次指定周期来收集废弃的对象,可以通过调用gc()方法来根据需要运行无用单元收集器。一个很好的试验方法是先调用gc()方法,然后调用freeMemory()方法来查看基本的内存使用情况,接着执行代码,然后再次调用freeMemory()方法看看分配了多少内存。下面的程序演示了这个构想。

//此实例来自《java核心技术》卷一
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

 

2、执行其他程序
在安全的环境中,可以在多任务操作系统中使用Java去执行其他特别大的进程(也就是程序)。ecec()方法有几种形式命名想要运行的程序和它的输入参数。ecec()方法返回一个Process对象,可以使用这个对象控制Java程序与新运行的进程进行交互。ecec()方法本质是依赖于环境。
下面的例子是使用ecec()方法启动windows的记事本notepad。这个例子必须在Windows操作系统上运行。

//此实例来自《Java核心技术》卷一
class ExecDemo {
    public static void main(String args[]){
        Runtime r = Runtime.getRuntime();
        Process p = null;
        try{
            p = r.exec("notepad");
        } catch (Exception e) {
            System.out.println("Error executing notepad.");
        }
    }
}

ecec()还有其他几种形式,例子中演示的是最常用的一种。ecec()方法返回Process对象后,在新程序开始运行后就可以使用Process的方法了。可以用destory()方法杀死子进程,也可以使用waitFor()方法等待程序直到子程序结束,exitValue()方法返回子进程结束时返回的值。如果没有错误,将返回0,否则返回非0。下面是关于ecec()方法的例子的改进版本。例子被修改为等待,直到运行的进程退出:

//此实例来自《Java核心技术》卷一
class ExecDemoFini {
    public static void main(String args[]){
        Runtime r = Runtime.getRuntime();
        Process p = null;
        try{
            p = r.exec("notepad");
            p.waitFor();
        } catch (Exception e) {
            System.out.println("Error executing notepad.");
        }
        System.out.println("Notepad returned " + p.exitValue());
    }
}
下面是运行的结果(当关闭记事本后,会接着运行程序,打印信息):
Notepad returned 0
请按任意键继续. . .

 

当子进程正在运行时,可以对标准输入输出进行读写。getOutputStream()方法和getInPutStream()方法返回对子进程的标准输入和输出。


四、来自SUN公司的java.long.Runtime类的API文档,网上有chm中文版的,很好找。为了查阅方便,我从SUN公司的JavaDoc站点上复制出来了Runtime类的API文档。

java.lang 
类 Runtime

java.lang.Object
java.lang.Runtime

public class Runtimeextends Object

每个 Java 应用程序都有一个 Runtime 类实例,使应用程序能够与其运行的环境相连接。可以通过 getRuntime 方法获取当前运行时。

应用程序不能创建自己的 Runtime 类实例。

 

 

从以下版本开始:
JDK1.0
另请参见:
getRuntime()

方法摘要
 voidaddShutdownHook(Thread hook) 
          注册新的虚拟机来关闭挂钩。
 intavailableProcessors() 
          向 Java 虚拟机返回可用处理器的数目。
 Processexec(String command) 
          在单独的进程中执行指定的字符串命令。
 Processexec(String[] cmdarray) 
          在单独的进程中执行指定命令和变量。
 Processexec(String[] cmdarray, String[] envp) 
          在指定环境的独立进程中执行指定命令和变量。
 Processexec(String[] cmdarray, String[] envp, File dir) 
          在指定环境和工作目录的独立进程中执行指定的命令和变量。
 Processexec(String command, String[] envp) 
          在指定环境的单独进程中执行指定的字符串命令。
 Processexec(String command, String[] envp, File dir) 
          在有指定环境和工作目录的独立进程中执行指定的字符串命令。
 voidexit(int status) 
          通过启动虚拟机的关闭序列,终止当前正在运行的 Java 虚拟机。
 longfreeMemory() 
          返回 Java 虚拟机中的空闲内存量。
 voidgc() 
          运行垃圾回收器。
 InputStreamgetLocalizedInputStream(InputStream in) 
          已过时。 从 JDK 1.1 开始,将本地编码字节流转换为 Unicode 字符流的首选方法是使用 InputStreamReader 和 BufferedReader类。
 OutputStreamgetLocalizedOutputStream(OutputStream out) 
          已过时。 从 JDK 1.1 开始,将 Unicode 字符流转换为本地编码字节流的首选方法是使用 OutputStreamWriterBufferedWriter和 PrintWriter 类。
static RuntimegetRuntime() 
          返回与当前 Java 应用程序相关的运行时对象。
 voidhalt(int status) 
          强行终止目前正在运行的 Java 虚拟机。
 voidload(String filename) 
          加载作为动态库的指定文件名。
 voidloadLibrary(String libname) 
          加载具有指定库名的动态库。
 longmaxMemory() 
          返回 Java 虚拟机试图使用的最大内存量。
 booleanremoveShutdownHook(Thread hook) 
          取消注册某个先前已注册的虚拟机关闭挂钩。
 voidrunFinalization() 
          运行挂起 finalization 的所有对象的终止方法。
static voidrunFinalizersOnExit(boolean value) 
          已过时。 此方法本身具有不安全性。它可能对正在使用的对象调用终结方法,而其他线程正在操作这些对象,从而导致不正确的行为或死锁。
 longtotalMemory() 
          返回 Java 虚拟机中的内存总量。
 voidtraceInstructions(boolean on) 
          启用/禁用指令跟踪。
 voidtraceMethodCalls(boolean on) 
          启用/禁用方法调用跟踪。
 
从类 java.lang.Object 继承的方法
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

方法详细信息

getRuntime

public static Runtime getRuntime()
返回与当前 Java 应用程序相关的运行时对象。Runtime 类的大多数方法是实例方法,并且必须根据当前的运行时对象对其进行调用。

 

返回:
与当前 Java 应用程序相关的 Runtime 对象。

exit

public void exit(int status)
通过启动虚拟机的关闭序列,终止当前正在运行的 Java 虚拟机。此方法从不正常返回。可以将变量作为一个状态码;根据惯例,非零的状态码表示非正常终止。

虚拟机的关闭序列包含两个阶段。在第一个阶段中,会以某种未指定的顺序启动所有已注册的关闭挂钩(如果有的话),并且允许它们同时运行直至结束。在第二个阶段中,如果已启用退出终结,则运行所有未调用的终结方法。一旦完成这个阶段,虚拟机就会暂停

如果在虚拟机已开始其关闭序列后才调用此方法,那么若正在运行关闭挂钩,则将无限期地阻断此方法。如果已经运行完关闭挂钩,并且已启用退出终结 (on-exit finalization),那么此方法将利用给定的状态码(如果状态码是非零值)暂停虚拟机;否则将无限期地阻断虚拟机。

System.exit 方法是调用此方法的一种传统而便捷的方式。

 

 

参数:
status - 终止状态。按照惯例,非零的状态码表明非正常终止。
抛出:
SecurityException - 如果安全管理器存在,并且其 checkExit 方法不允许存在指定的状态
另请参见:
SecurityExceptionSecurityManager.checkExit(int)addShutdownHook(java.lang.Thread)removeShutdownHook(java.lang.Thread),runFinalizersOnExit(boolean)halt(int)

addShutdownHook

public void addShutdownHook(Thread hook)
注册新的虚拟机来关闭挂钩。

Java 虚拟机会为了响应以下两类事件而关闭

 

  • 程序正常退出,这发生在最后的非守护线程退出时,或者在调用 exit(等同于System.exit)方法时。或者,

     

  • 为响应用户中断而终止 虚拟机,如键入 ^C;或发生系统事件,比如用户注销或系统关闭。

关闭挂钩 只是一个已初始化但尚未启动的线程。虚拟机开始启用其关闭序列时,它会以某种未指定的顺序启动所有已注册的关闭挂钩,并让它们同时运行。运行完所有的挂钩后,如果已启用退出终结,那么虚拟机接着会运行所有未调用的终结方法。最后,虚拟机会暂停。注意,关闭序列期间会继续运行守护线程,如果通过调用 exit 方法来发起关闭序列,那么也会继续运行非守护线程。

一旦开始了关闭序列,则只能通过调用 halt 方法来停止这个序列,此方法可强行终止虚拟机。

一旦开始了关闭序列,则不可能注册新的关闭挂钩或取消注册先前已注册的挂钩。尝试执行这些操作会导致抛出 IllegalStateException

关闭挂钩可在虚拟机生命周期中的特定时间运行,因此应保护性地对其进行编码。特别是应将关闭挂钩编写为线程安全的,并尽可能地避免死锁。关闭挂钩还应该不盲目地依靠某些服务,这些服务可能已注册了自己的关闭挂钩,所以其本身可能正处于关闭进程中。

关闭挂钩应该快速地完成其工作。当程序调用 exit 时,虚拟机应该迅速地关闭并退出。由于用户注销或系统关闭而终止虚拟机时,底层的操作系统可能只允许在固定的时间内关闭并退出。因此在关闭挂钩中尝试进行任何用户交互或执行长时间的计算都是不明智的。

与其他所有线程一样,通过调用线程 ThreadGroup 对象的 uncaughtException 方法,可在关闭挂钩中处理未捕获的异常。此方法的默认实现是将该异常的堆栈跟踪 (stack trace) 打印至 System.err 并终止线程;它不会导致虚拟机退出或暂停。

仅在很少的情况下,虚拟机可能会中止,也就是没有完全关闭就停止运行。虚拟机被外部终止时会出现这种现象,比如在 Unix 上使用 SIGKILL 信号或者在 Microsoft Windows 上调用 TerminateProcess。如果由于内部数据结构损坏或试图访问不存在的内存而导致本机方法执行错误,那么可能也会中止虚拟机。如果虚拟机中止,则无法保证是否将运行关闭挂钩。

 

 

参数:
hook - 一个已初始化但尚未启动的 Thread 对象
抛出:
IllegalArgumentException - 如果指定的挂钩已注册,或者可以确定挂钩正在运行或者已运行完毕
IllegalStateException - 如果虚拟机已经处于关闭进程中
SecurityException - 如果安全管理器存在并且拒绝 RuntimePermission("shutdownHooks")
从以下版本开始:
1.3
另请参见:
removeShutdownHook(java.lang.Thread)halt(int)exit(int)

removeShutdownHook

public boolean removeShutdownHook(Thread hook)
取消注册某个先前已注册的虚拟机关闭挂钩。

 

 

参数:
hook - 要删除的挂钩
返回:
如果指定的挂钩先前已注册并且成功地取消注册,则返回 true,其他情况返回 false
抛出:
IllegalStateException - 如果虚拟机已经处于关闭进程中
SecurityException - 如果安全管理器存在并且拒绝 RuntimePermission("shutdownHooks")
从以下版本开始:
1.3
另请参见:
addShutdownHook(java.lang.Thread)exit(int)

halt

public void halt(int status)
强行终止目前正在运行的 Java 虚拟机。此方法从不正常返回。

应小心使用此方法。与 exit 方法不同,此方法不会启动关闭挂钩,并且如果已启用退出终结,此方法也不会运行未调用的终结方法。如果已经发起关闭序列,那么此方法不会等待所有正在运行的关闭挂钩或终结方法完成其工作。

 

 

参数:
status - 终止状态。按照惯例,非零的状态码表明非正常终止。如果已经调用了 exitSystem.exit 也一样)方法,那么该状态码将重写已传递至此方法的状态码。
抛出:
SecurityException - 如果安全管理器存在,并且其 checkExit 方法不允许具有指定状态时退出
从以下版本开始:
1.3
另请参见:
exit(int)addShutdownHook(java.lang.Thread)removeShutdownHook(java.lang.Thread)

runFinalizersOnExit

@Deprecated
public static void runFinalizersOnExit(boolean value)
已过时。 此方法本身具有不安全性。它可能对正在使用的对象调用终结方法,而其他线程正在操作这些对象,从而导致不正确的行为或死锁。

 

在退出时启用或禁用终结;这样做可指定拥有未被自动调用终结方法的所有对象的终结方法,并将在退出 Java 运行时前运行此终结方法。默认情况下,禁用退出终结。

如果有安全管理器,则首先使用 0 作为变量来调用其 checkExit 方法,以确保允许退出。这可能会导致 SecurityException。

 

参数:
value - 如果启用退出时终结,则该参数为 true,如果禁用退出时终结,则该参数为 false
抛出:
SecurityException - 如果安全管理器存在并且其 checkExit 方法不允许退出。
从以下版本开始:
JDK1.1
另请参见:
exit(int)gc()SecurityManager.checkExit(int)

exec

public Process exec(String command)throws IOException
在单独的进程中执行指定的字符串命令。

这是一个很有用的方法。对于 exec(command) 形式的调用而言,其行为与调用 exec(command, null, null) 完全相同。

 

参数:
command - 一条指定的系统命令。
返回:
一个新的 Process 对象,用于管理子进程
抛出:
SecurityException - 如果安全管理器存在,并且其 checkExec 方法不允许创建子进程
IOException - 如果发生 I/O 错误
NullPointerException - 如果 command 为 null
IllegalArgumentException - 如果 command 为空
另请参见:
exec(String[], String[], File)ProcessBuilder

exec

public Process exec(String command,String[] envp)throws IOException
在指定环境的单独进程中执行指定的字符串命令。

这是一个很有用的方法。对于 exec(command, envp) 形式的调用而言,其行为与调用 exec(command, envp, null) 完全相同。

 

参数:
command - 一条指定的系统命令。
envp - 字符串数组,其中每个元素的环境变量的设置格式为 name=value;如果子进程应该继承当前进程的环境,或该参数为 null
返回:
一个新的 Process 对象,用于管理子进程
抛出:
SecurityException - 如果安全管理器存在,并且其 checkExec 方法不允许创建子进程
IOException - 如果发生 I/O 错误
NullPointerException - 如果 command 为 null,或 envp 的元素之一为 null
IllegalArgumentException - 如果 command 为空
另请参见:
exec(String[], String[], File)ProcessBuilder

exec

public Process exec(String command,String[] envp,File dir)throws IOException
在有指定环境和工作目录的独立进程中执行指定的字符串命令。

这是一个很有用的方法。对于 exec(command, envp, dir) 形式的调用而言,其行为与调用 exec(cmdarray, envp, dir) 完全相同,其中 cmdarray是 command 中所有标记的数组。

更准确地说,可以使用通过调用 new StringTokenizer(command) 创建的 StringTokenizer 将 command 字符串拆解成标记,调用时不对字符类别做进一步的修改。然后将标记生成器所生成的标记以相同的顺序放入新的字符串数组 cmdarray 中。

 

参数:
command - 一条指定的系统命令。
envp - 字符串数组,其中每个元素的环境变量的设置格式为 name=value;如果子进程应该继承当前进程的环境,或该参数为 null
dir - 子进程的工作目录;如果子进程应该继承当前进程的工作目录,则该参数为 null
返回:
一个新的 Process 对象,用于管理子进程
抛出:
SecurityException - 如果安全管理器存在,并且其 checkExec 方法不允许创建子进程
IOException - 如果发生 I/O 错误
NullPointerException - 如果 command 为 null,或者 envp 的某个元素为 null
IllegalArgumentException - 如果 command 为空
从以下版本开始:
1.3
另请参见:
ProcessBuilder

exec

public Process exec(String[] cmdarray)throws IOException
在单独的进程中执行指定命令和变量。

这是一个很有用的方法。对于 exec(cmdarray) 形式的调用而言,其行为与调用 exec(cmdarray, null, null) 完全相同。

 

参数:
cmdarray - 包含所调用命令及其参数的数组。
返回:
一个新的 Process 对象,用于管理子进程
抛出:
SecurityException - 如果安全管理器存在,并且其 checkExec 方法不允许创建子进程
IOException - 如果发生 I/O 错误
NullPointerException - 如果 cmdarray 为 null,或者 cmdarray 的某个元素为 null
IndexOutOfBoundsException - 如果 cmdarray 是一个空数组(长度为 0
另请参见:
ProcessBuilder

exec

public Process exec(String[] cmdarray,String[] envp)throws IOException
在指定环境的独立进程中执行指定命令和变量。

这是一个很有用的方法。对于 exec(cmdarray, envp) 形式的调用而言,其行为与调用 exec(cmdarray, envp, null) 完全相同。

 

参数:
cmdarray - 包含所调用命令及其参数的数组。
envp - 字符串数组,其中每个元素的环境变量的设置格式为 name=value;如果子进程应该继承当前进程的环境,或该参数为 null
返回:
一个新的 Process 对象,用于管理子进程
抛出:
SecurityException - 如果安全管理器存在,并且其 checkExec 方法不允许创建子进程
IOException - 如果发生 I/O 错误
NullPointerException - 如果 cmdarray 为 null,或者 cmdarray 的某个元素为 null,或者 envp 的某个元素为 null
IndexOutOfBoundsException - 如果 cmdarray 是一个空数组(长度为 0
另请参见:
ProcessBuilder

exec

public Process exec(String[] cmdarray,String[] envp,File dir)throws IOException
在指定环境和工作目录的独立进程中执行指定的命令和变量。

给定的字符串数组 cmdarray 表示一个命令行标记,字符串数组 envp 则表示“环境”变量设置,此方法会创建一个新进程,而指定的命令就在这个进程中执行。

此方法检查 cmdarray 是否是一条有效的操作系统命令。哪些命令有效取决于系统,但是该命令至少必须有一个非 null 字符串的非空列表。

如果 envp 为 null,那么子进程会继承当前进程的环境设置。

ProcessBuilder.start() 现在是启用一个具有已修改环境的进程的首选方法。

dir 指定了新子进程的工作目录。如果 dir 为 null,那么子进程会继承当前进程的当前工作目录。

如果安全管理器存在,则用数组 cmdarray 的第一个元素作为变量来调用安全管理器的 checkExec 方法。这可能导致抛出 SecurityException

启动操作系统进程的方式完全取决于系统。其中有很多方面会导致错误:

  • 未找到操作系统程序文件。
  • 对程序文件的访问被拒绝。
  • 工作目录不存在。

这些情况都会抛出一个异常。该异常的具体特性取决于系统,但它总是 IOException 的一个子类。

 

参数:
cmdarray - 包含所调用命令及其参数的数组。
envp - 字符串数组,其中每个元素的环境变量的设置格式为 name=value,如果子进程应该继承当前进程的环境,或该参数为 null
dir - 子进程的工作目录;如果子进程应该继承当前进程的工作目录,则该参数为 null
返回:
一个新的 Process 对象,用于管理子进程
抛出:
SecurityException - 如果安全管理器存在,并且其 checkExec 方法不允许创建子进程
IOException - 如果发生 I/O 错误
NullPointerException - 如果 cmdarray 为 null,或者 cmdarray 的某个元素为 null,抑或 envp 的某个元素为 null
IndexOutOfBoundsException - 如果 cmdarray 是一个空数组(长度为 0
从以下版本开始:
1.3
另请参见:
ProcessBuilder

availableProcessors

public int availableProcessors()
向 Java 虚拟机返回可用处理器的数目。

该值在特定的虚拟机调用期间可能发生更改。因此,对可用处理器数目很敏感的应用程序应该不定期地轮询该属性,并相应地调整其资源用法。

 

返回:
虚拟机可用的最大处理器数目;从不小于 1
从以下版本开始:
1.4

freeMemory

public long freeMemory()
返回 Java 虚拟机中的空闲内存量。调用 gc 方法可能导致 freeMemory 返回值的增加。

 

返回:
供将来分配对象使用的当前可用内存的近似总量,以字节为单位。

totalMemory

public long totalMemory()
返回 Java 虚拟机中的内存总量。此方法返回的值可能随时间的推移而变化,这取决于主机环境。

注意,保存任意给定类型的一个对象所需的内存量可能取决于实现方法。

 

返回:
目前为当前和后续对象提供的内存总量,以字节为单位。

maxMemory

public long maxMemory()
返回 Java 虚拟机试图使用的最大内存量。如果内存本身没有限制,则返回值 Long.MAX_VALUE

 

 

返回:
虚拟机试图使用的最大内存量,以字节为单位。
从以下版本开始:
1.4

gc

public void gc()
运行垃圾回收器。调用此方法意味着 Java 虚拟机做了一些努力来回收未用对象,以便能够快速地重用这些对象当前占用的内存。当控制从方法调用中返回时,虚拟机已经尽最大努力回收了所有丢弃的对象。

名称 gc 代表“垃圾回收器”。虚拟机根据需要在单独的线程中自动执行回收过程,甚至不用显式调用 gc 方法。

方法 System.gc() 是调用此方法的一种传统而便捷的方式。

 


runFinalization

public void runFinalization()
运行挂起 finalization 的所有对象的终止方法。调用此方法意味着 Java 虚拟机做了一些努力运行已被丢弃对象的 finalize 方法,但是这些对象的finalize 方法还没有运行。当控制从方法调用中返回时,Java 虚拟机已经尽最大努力去完成所有未执行的终止方法。

如果不显式调用 runFinalization 方法,则 Java 虚拟机会根据需要在单独的线程中自动执行此终止过程。

方法 System.runFinalization() 是调用此方法的一种传统而便捷的方式。

 

另请参见:
Object.finalize()

traceInstructions

public void traceInstructions(boolean on)
启用/禁用指令跟踪。如果 boolean 变量为 true,则执行此方法意味着让 Java 虚拟机发送虚拟机中每条指令执行的调试信息。该信息的格式,以及虚拟机所发送的文件或其他输出流的格式取决于主机的环境。如果虚拟机不支持此功能,则忽略这一 请求。跟踪输出的目的地取决于系统。

如果 boolean 变量为 false,则执行此方法时将使 Java 虚拟机停止执行详细的指令跟踪。

 

参数:
on - 为 true 时启用指令跟踪;为 false 时则禁用此功能。

traceMethodCalls

public void traceMethodCalls(boolean on)
启用/禁用方法调用跟踪。如果 boolean 变量为 true,则执行此方法意味着让 Java 虚拟机发送虚拟机中每个方法的调试信息。该信息的格式,以及虚拟机所发送的文件或其他输出流的格式取决于主机的环境。如果虚拟机不支持此功能,则忽略这一请求。

使用变量 false 调用此方法意味着虚拟机停止发送每个调用的调试信息。

 

参数:
on - 为 true 时启用指令跟踪;为 false 时则禁用此功能。

load

public void load(String filename)
加载作为动态库的指定文件名。文件名变量必须是一个完整的路径名。对于 java_g,会自动在 "_g" 前面插入 ".so"(例如Runtime.getRuntime().load("/home/avh/lib/libX11.so");)。

首先,如果有安全管理器,则用 filename 作为参数调用 checkLink 方法。这可能导致安全异常。

这与 loadLibrary(String) 方法类似,但它接受通用文件名作为变量,而不仅仅是库名,从而能够加载所有的本机代码文件。

方法 System.load(String) 是调用此方法的一种传统而便捷的方式。

 

参数:
filename - 要加载的文件。
抛出:
SecurityException - 如果安全管理器存在,并且其 checkLink 方法不允许加载指定的动态库
UnsatisfiedLinkError - 如果文件不存在。
NullPointerException - 如果 filename 为 null
另请参见:
getRuntime()SecurityExceptionSecurityManager.checkLink(java.lang.String)

loadLibrary

public void loadLibrary(String libname)
加载具有指定库名的动态库。从以前获取库文件的本地文件系统中加载含有本机代码的文件。这一过程的细节取决于实现方法。可以以某种特定于系统的方式完成从库名到特定文件名的映射。

首先,如果有安全管理器,则用 libname 作为参数调用 checkLink 方法。这可能导致安全性异常。

方法 System.loadLibrary(String) 是调用此方法的一种传统而便捷的方式。如果在某个类实现中使用本机方法,则标准的策略是将本机代码放入一个库文件中(称为 LibFile),然后在类声明中放入一个静态的初始值设定项:

static { System.loadLibrary("LibFile"); }
当加载并初始化这个类时,也将加载实现本机方法所需的本机代码。

如果用相同库名多次调用此方法,则忽略第二次及后续的调用。

 

参数:
libname - 库名。
抛出:
SecurityException - 如果安全管理器存在,并且其 checkLink 方法不允许加载指定的动态库
UnsatisfiedLinkError - 如果库不存在。
NullPointerException - 如果 libname 为 null
另请参见:
SecurityExceptionSecurityManager.checkLink(java.lang.String)

getLocalizedInputStream

@Deprecated
public InputStream getLocalizedInputStream(InputStream in)
已过时。 从 JDK 1.1 开始,将本地编码字节流转换为 Unicode 字符流的首选方法是使用 InputStreamReader 和 BufferedReader 类。

 

创建输入流的本地化版本。此方法获取 InputStream,并返回除本地化外其他所有方面都和变量等效的 InputStream,这些方面包括:作为本地字符集中的字符从流中被读取,并将它们从本地字符集自动转换为 Unicode。

如果参数已经是本地化流,则可作为结果返回。

 

参数:
in - 要本地化的 InputStream
返回:
已本地化的输入流
另请参见:
InputStreamBufferedReader.BufferedReader(java.io.Reader)InputStreamReader.InputStreamReader(java.io.InputStream)

getLocalizedOutputStream

@Deprecated
public OutputStream getLocalizedOutputStream(OutputStream out)
已过时。 从 JDK 1.1 开始,将 Unicode 字符流转换为本地编码字节流的首选方法是使用 OutputStreamWriterBufferedWriter 和 PrintWriter类。

 

创建输出流的本地化版本。此方法获取 OutputStream,并返回除本地化外其他所有方面都和变量等效的 OutputStream,这些方面包括:作为 Unicode 字符被写入流中,并被自动转换为本地字符集。

如果参数已经是本地流,则可作为结果返回。

 

参数:
out - 要本地化的 OutputStream
返回:
已本地化的输出流
另请参见:
OutputStreamBufferedWriter.BufferedWriter(java.io.Writer)OutputStreamWriter.OutputStreamWriter(java.io.OutputStream),PrintWriter.PrintWriter(java.io.OutputStream)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/542552.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java队列实现限流,java中应对高并发的两种策略

目的&#xff1a;提高可用性通过ExecutorService实现队列泄洪//含有20个线程的线程池private ExecutorService executorService Executors.newFixedThreadPool(20);将有并发压力的下游代码放入到线程池的submit方法中&#xff0c;如下&#xff1a;//同步调用线程池的submit方法…

crontab 日志_liunx 中定时清理过期日志文件

问题描述经常遇到日志文件过多&#xff0c;占用大量磁盘空间&#xff0c;需要定期删除过期日志。问题涉及方面删除过期日志的脚本。定时任务删除任务脚本先查询到过期的日志文件&#xff0c;然后删除。语法find path -option [ -print ] [ -exec -ok command ] …

JavaScript | 数组的常用属性和方法

JavaScript的通用属性和数组方法 (Common properties and methods of array in JavaScript ) Properties/MethodsDescriptionsarray.lengthReturns the length of the array/total number of elements of the array array[index]Returns the item name stored at “index” pos…

php dbutils 使用,dbutilsapi

相对lisp?而?言,可以使?用.net的强?大api,实现各种酷炫功能。相对c#及arx?...文件utils.py的模块名分别是mycompany.utils和 mycompany.web.utils。 mycompany......CouchDB -b 关闭后台运行的 CouchDB : CouchDB -d web 访问:http://127.0.0.1:5984/_utils/index.html E-…

html 导航栏

<!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>lvnian学习(http://lvnian.blog.51cto.com/)</title> <style> ul {list-style-type:none;margin:0;padding:0; }a:link,a:visited{display:block;font-weigh…

将搜索二叉树转换为链表_将给定的二叉树转换为双链表(DLL)

将搜索二叉树转换为链表Given a Binary tree and we have to convert it to a Doubly Linked List (DLL). 给定二叉树&#xff0c;我们必须将其转换为双链表(DLL)。 Algorithm: 算法&#xff1a; To solve the problem we can follow this algorithm: 为了解决这个问题&#…

cuda编程_CUDA刷新器:CUDA编程模型

CUDA刷新器&#xff1a;CUDA编程模型 CUDA Refresher: The CUDA Programming Model CUDA&#xff0c;CUDA刷新器&#xff0c;并行编程 这是CUDA更新系列的第四篇文章&#xff0c;它的目标是刷新CUDA中的关键概念、工具和初级或中级开发人员的优化。 CUDA编程模型提供了GPU体系结…

php curl_error源码,PHP curl_error函数

PHP curl_error函数(PHP 4 > 4.0.3, PHP 5)curl_error — 返回一个保护当前会话最近一次错误的字符串说明string curl_error ( resource $ch )返回一条最近一次cURL操作明确的文本的错误信息。参数ch由 curl_init() 返回的 cURL 句柄。返回值返回错误信息或 (空字符串) 如果…

SQL中Where与Having的区别

“Where” 是一个约束声明&#xff0c;使用Where来约束来之数据库的数据&#xff0c;Where是在结果返回之前起作用的&#xff0c;且Where中不能使用聚合函数。“Having”是一个过滤声明&#xff0c;是在查询返回结果集以后对查询结果进行的过滤操作&#xff0c;在Having中可以使…

java 逻辑表达式 布尔_使用基本逻辑门实现布尔表达式

java 逻辑表达式 布尔将布尔表达式转换为逻辑电路 (Converting Boolean Expression to Logic Circuit) The simplest way to convert a Boolean expression into a logical circuit is to follow the reverse approach in which we start from the output of the Boolean expre…

python自然语言处理书籍_精通Python自然语言处理pdf

自然语言处理&#xff08;NLP&#xff09;是有关计算语言学与人工智能的研究领域之一。NLP主要关注人机交互&#xff0c;它提供了计算机和人类之间的无缝交互&#xff0c;使得计算机在机器学习的帮助下理解人类语言。 本书详细介绍如何使用Python执行各种自然语言处理&#xff…

通达oa 2013 php解密,通达OA漏洞学习 - 安全先师的个人空间 - OSCHINA - 中文开源技术交流社区...

说明通达OA漏洞在去年上半年已爆出&#xff0c;这不趁着周末没事做&#xff0c;将源码下载下来进行复现学习。文件包含测试文件包含检测&#xff0c;payload1:ip/ispirit/interface/gateway.php?json{"url":"/general/../../mysql5/my.ini"}利用文件包含访…

温赵轮 访谈

“温赵轮”三大软狗&#xff0c;你听说过吗&#xff1f;今天的1024访谈录给大家介绍的就是程序员中当之无愧的偶像组合——温赵轮。 Winter寒冬。阿里P8&#xff0c;正在向P9的道路上奔跑。传说中的他有钱、出身好&#xff0c;可不是搞互联网的屌丝程序员。 老赵&#xff0c;…

linux开源文档管理系统_Linux中的系统管理员问题 免费和开源软件

linux开源文档管理系统根帐号 (Root Account) The "root" account is the most unrestrictive account on a Linux Operating system. This account enables you to complete all features of System admin, including accounts, changing client passwords, looking…

matlab上机实验1,上机实验1:熟悉matlab基本操作

其中 x 在 [-2, 2] 间共等切分为 21 点&#xff0c;y 在 [-1, 1] 间共等切分为 21 点&#xff0c;所以此曲面共有 21*21441 个点。a. 请用预设的颜色对应表(Colormap)来画出此曲面。 b. 请以曲面的斜率来设定曲面的颜色。 c. 请以曲面的曲率来设定曲面的颜色。2. 请用 meshc 指…

公众号 -「前端攻略 开光篇」

作为一枚程序员&#xff0c;每件重要项目的开始都忍不住使用"Hello World"。 这个公众号是不是来晚了&#xff1f;如果你有这个疑问&#xff0c;那么我想说&#xff1a;对于写作和思考&#xff0c;任何时候都不晚。我用四个简单的自问自答&#xff0c;来讲讲这个前端…

python 桌面应用 启动缓慢_如何加快Python 应用的启动时间

我听说pipenv9.0.2已经发布&#xff0c;启动时间有了很大的改进。 我很快就试了一下&#xff0c;但我觉得并不快。所以我用Python3.7的新特性来研究它。 在本文中&#xff0c;我将介绍该特性以及如何使用它。 启动时间≒导入时间 例如&#xff0c;pipenv -h 的执行时间比显示帮…

python单词首字母大写_在Python中将每个单词的首字母大写

python单词首字母大写Here, we are implementing a python program to capitalizes the first letter of each word in a string. 在这里&#xff0c;我们正在实现一个python程序来大写字符串中每个单词的首字母。 Example: 例&#xff1a; Input: "HELLO WORLD!"O…

matlab中求模最大,matlab求取模极大值时出错

本帖最后由 Nate_ 于 2016-4-17 15:57 编辑points1024 时&#xff0c;有波形输出&#xff0c;但信号有5438个点。改为5438就不行。主程序&#xff1a;%小波模极大值重构是采用的交替投影法close all;points5438; level4; sr360; num_inter6; wfdb4;%所处理数据的…

stl向量_如何检查C ++ STL中向量中是否存在元素?

stl向量Given a vector and an element to be searched in the vector. 给定一个向量和要在向量中搜索的元素。 To check whether an elements exists in a vector or not – we use find() function. find() function takes 3 arguments. 要检查向量中是否存在元素 –我们使用…