【小家java】聊聊Java中的Runtime类

简介: 【小家java】聊聊Java中的Runtime类

概述


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


我们不能实例化一个Runtime对象,应用程序也不能创建自己的 Runtime 类实例,但可以通过 getRuntime 方法获取当前Runtime运行时对象的引用。一旦得到了一个当前的Runtime对象的引用,就可以调用Runtime对象的方法去控制Java虚拟机的状态和行为


当Applet和其他不被信任的代码调用任何Runtime方法时,常常会引起SecurityException异常。


API方法示例


我们先来看看几个native方法:


public native int availableProcessors();
public native long freeMemory();
public native long totalMemory();
public native long maxMemory();


使用示例如下:


Runtime rt = Runtime.getRuntime();
        System.out.println("处理器数量:" + rt.availableProcessors()); //处理器数量:4
        System.out.println("空闲内存数:" + rt.freeMemory() / 1024 / 1024 + "mb"); //空闲内存数:111mb
        System.out.println("总内存数:" + rt.totalMemory() / 1024 / 1024 + "mb"); //总内存数:120mb
        System.out.println("可用最大内存数:" + rt.maxMemory() / 1024 / 1024 + "mb"); //可用最大内存数:1910mb


使用场景:

通过totalMemory()和freeMemory()方法可以知道对象的堆内存有多大,还剩多少。


Java会周期性的回收垃圾对象(未使用的对象),以便释放内存空间。但是如果想先于收集器的下一次指定周期来收集废弃的对象,可以通过调用gc()方法来根据需要运行无用单元收集器。一个很好的试验方法是先调用gc()方法,然后调用freeMemory()方法来查看基本的内存使用情况,接着执行代码,然后再次调用freeMemory()方法看看分配了多少内存。


     version()方法 (since Java9)


     java9t提供了Version方法,可以放我们和方便的获取到运行时的一些参数信息,可以说是非常的人性化。我们看看这个方法源码:

public static Version version() {
        if (version == null) {
            version = new Version(VersionProps.versionNumbers(),
                    VersionProps.pre(), VersionProps.build(),
                    VersionProps.optional());
        }
        return version;
    }


我们发现所有的参数都来自于VersionProps,所以我们贴一些它的源码,大家就都清晰了


class VersionProps {
        private static final String launcher_name = "java";
        private static final String java_version = "10.0.2";
        private static final String java_version_date = "2018-07-17";
        private static final String java_runtime_name = "Java(TM) SE Runtime Environment";
        private static final String java_runtime_version = "10.0.2+13";
        private static final String VERSION_NUMBER = "10.0.2";
        private static final String VERSION_BUILD = "13";
        private static final String VERSION_PRE = "";
        private static final String VERSION_OPT = "";
        private static final boolean isLTS = "".startsWith("LTS");
        private static final String VENDOR_VERSION_STRING = "18.3";
        private static final String vendor_version = (VENDOR_VERSION_STRING.length() > 0
                        ? " " + VENDOR_VERSION_STRING : "");
        static {
            init();
        }
    }


由于我的JDK版本是Java10,所以各位的参数可能和我的不太一样。我运行一下如下:


System.out.println(Runtime.version()); //10.0.2+13


执行其它程序


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


 public static void main(String[] args) throws IOException {
        Runtime rt = Runtime.getRuntime();
        //rt.exec("notepad.exe"); //打开记事本 备注:.exe可以省略 下同
        Process process = rt.exec("calc.exe");//打开计算器
        System.out.println(process); //Process[pid=8108, exitValue="not exited"]
    }


在新程序开始运行后就可以使用Process的方法了。可以用destory()方法杀死子进程,也可以使用waitFor()方法等待程序直到子程序结束,exitValue()方法返回子进程结束时返回的值。如果没有错误,将返回0,否则返回非0。


public static void main(String[] args) throws IOException, InterruptedException {
        Runtime rt = Runtime.getRuntime();
        Process process = rt.exec("notepad.exe"); //打开记事本 备注:.exe可以省略 下同
        //Process process = rt.exec("calc.exe");//打开计算器
        process.waitFor(); //阻塞  等到子进程执行结束
        System.out.println("字进行执行完事了~~~");
        process.destroyForcibly(); //强制杀死子进程 destroy
    }
运行结果:(当关闭记事本后,会接着运行程序,打印信息)


和Gc相关的方法


exit(int status)


通过启动虚拟机的关闭序列,终止当前正在运行的 Java 虚拟机。


gc()


运行垃圾回收器。


halt(int status)


强行终止目前正在运行的 Java 虚拟机。


load和loadLibrary


这两个方法是我们在使用Java的JNI机制时,会用到的一个非常重要的函数,它的作用即是把实现了我们在Java code中声明的native方法的那个libraryload进来,或者load其他什么动态连接库


这儿JNI编程才会用到。小弟不才,这里只能先给一个大写的略字了


相关文章
|
2月前
|
Java 编译器 API
Java 密封类:精细化控制继承关系
Java 密封类:精细化控制继承关系
267 83
|
3月前
|
IDE Java 数据挖掘
Java 基础类从入门到精通实操指南
这份指南专注于**Java 17+**的新特性和基础类库的现代化用法,涵盖开发环境配置、数据类型增强(如文本块)、字符串与集合处理进阶、异常改进(如密封类)、IO操作及实战案例。通过具体代码示例,如CSV数据分析工具,帮助开发者掌握高效编程技巧。同时提供性能优化建议和常用第三方库推荐,适合从入门到精通的Java学习者。资源链接:[点此下载](https://pan.quark.cn/s/14fcf913bae6)。
177 35
|
4月前
|
存储 安全 Java
【高薪程序员必看】万字长文拆解Java并发编程!(7):不可变类设计指南
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发编程中Java不可变类设计指南,废话不多说让我们直接开始。
73 0
|
6月前
|
Java 开发者
重学Java基础篇—Java类加载顺序深度解析
本文全面解析Java类的生命周期与加载顺序,涵盖从加载到卸载的七个阶段,并深入探讨初始化阶段的执行规则。通过单类、继承体系的实例分析,明确静态与实例初始化的顺序。同时,列举六种触发初始化的场景及特殊场景处理(如接口初始化)。提供类加载完整流程图与记忆口诀,助于理解复杂初始化逻辑。此外,针对空指针异常等问题提出排查方案,并给出最佳实践建议,帮助开发者优化程序设计、定位BUG及理解框架机制。最后扩展讲解类加载器层次与双亲委派机制,为深入研究奠定基础。
224 0
|
25天前
|
安全 IDE Java
Java记录类型(Record):简化数据载体类
Java记录类型(Record):简化数据载体类
129 0
|
2月前
|
Java API
Java API中Math类功能全景扫描
在实际使用时,这些方法的精确度和性能得到了良好的优化。当处理复杂数学运算或高精度计算时,`Math`类通常是足够的。然而,对于非常精细或特殊的数学运算,可能需要考虑使用 `java.math`包中的 `BigDecimal`类或其他专业的数学库。
86 11
|
2月前
|
Java API
深入解析Java API中Object类的功能
了解和合理运用 Object类的这些方法,对于编写可靠和高效的Java应用程序至关重要。它们构成了Java对象行为的基础,影响着对象的创建、识别、表达和并发控制。
60 0
|
2月前
|
安全 Java
JAVA:Collections类的shuffle()方法
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的工具方法,适用于洗牌、抽奖等场景。该方法直接修改原列表,支持自定义随机数生成器以实现可重现的打乱顺序。使用时需注意其原地修改特性及非线程安全性。
95 0
|
2月前
|
存储 Java 编译器
深入理解Java虚拟机--类文件结构
本内容介绍了Java虚拟机与Class文件的关系及其内部结构。Class文件是一种与语言无关的二进制格式,包含JVM指令集、符号表等信息。无论使用何种语言,只要能生成符合规范的Class文件,即可在JVM上运行。文章详细解析了Class文件的组成,包括魔数、版本号、常量池、访问标志、类索引、字段表、方法表和属性表等,并说明其在Java编译与运行过程中的作用。