Java常用API-System

简介: Java常用API,System

2 System类

2.1 概述

tips:了解内容

查看API文档,我们可以看到API文档中关于System类的定义如下:

1576049347968

System类所在包为java.lang包,因此在使用的时候不需要进行导包。并且System类被final修饰了,因此该类是不能被继承的。

System包含了系统操作的一些常用的方法。比如获取当前时间所对应的毫秒值,再比如终止当前JVM等等。

要想使用System类我们就需要先创建该类的对象,那么创建对象就需要借助于构造方法。因此我们就需要首先查看一下API文档,看看API文档中针对System类有没有提供对应的构造方法。通过API文档来

查看一下System类的成员,如下所示:

1576049535584

在API文档中没有体现可用的构造方法,因此我们就不能直接通过new关键字去创建System类的对象。同时我们发现System类中的方法都是静态的,因此在使用的时候我们可以直接通过类名去调用(Nested

Class Summary内部类或者内部接口的描述)。

2.2 常见方法

tips:重点讲解内容

常见方法介绍

我们要学习的System类中的常见方法如下所示:

public static long currentTimeMillis()          // 获取当前时间所对应的毫秒值(当前时间为0时区所对应的时间即就是英国格林尼治天文台旧址所在位置)

public static void exit(int status)             // 终止当前正在运行的Java虚拟机,0表示正常退出,非零表示异常退出

public static native void arraycopy(Object src,  int  srcPos, Object dest, int destPos, int length); // 进行数值元素copy

案例演示

接下来我们就来通过一些案例演示一下这些方法的特点。

案例1:演示currentTimeMillis方法

public class SystemDemo01 {

   public static void main(String[] args) {

       // 获取当前时间所对应的毫秒值

       long millis = System.currentTimeMillis();

       // 输出结果

       System.out.println("当前时间所对应的毫秒值为:" + millis);

   }

}

运行程序进行测试,控制台的输出结果如下:

当前时间所对应的毫秒值为:1576050298343

获取到当前时间的毫秒值的意义:我们常常来需要统计某一段代码的执行时间。此时我们就可以在执行这段代码之前获取一次时间,在执行完毕以后再次获取一次系统时间,然后计算两个时间的差值,

这个差值就是这段代码执行完毕以后所需要的时间。如下代码所示:

public class SystemDemo2 {

   public static void main(String[] args) {

       //判断1~100000之间有多少个质数

       long start = System.currentTimeMillis();

       for (int i = 1; i <= 100000; i++) {

           boolean flag = isPrime2(i);

           if (flag) {

               System.out.println(i);

           }

       }

       long end = System.currentTimeMillis();

       //获取程序运行的总时间

       System.out.println(end - start); //方式一:1514 毫秒  方式二:71毫秒

   }

   //以前判断是否为质数的方式

   public static boolean isPrime1(int number) {

       for (int i = 2; i < number; i++) {

           if (number % i == 0) {

               return false;

           }

       }

       return true;

   }

   //改进之后判断是否为质数的方式(效率高)

   public static boolean isPrime2(int number) {

       for (int i = 2; i <= Math.sqrt(number); i++) {

           if (number % i == 0) {

               return false;

           }

       }

       return true;

   }

}

案例2:演示exit方法

public class SystemDemo01 {

   public static void main(String[] args) {

       

       // 输出

       System.out.println("程序开始执行了.....");

       

       // 终止JVM

       System.exit(0);

       

       // 输出

       System.out.println("程序终止了..........");

       

   }

   

}

运行程序进行测试,控制台输出结果如下:

程序开始执行了.....

此时可以看到在控制台只输出了"程序开始了...",由于JVM终止了,因此输出"程序终止了..."这段代码没有被执行。

案例3:演示arraycopy方法

方法参数说明:

// src:      源数组

// srcPos:  源数值的开始位置

// dest:    目标数组

// destPos: 目标数组开始位置

// length:   要复制的元素个数

public static native void arraycopy(Object src,  int  srcPos, Object dest, int destPos, int length);

代码如下所示:

public class SystemDemo01 {

   public static void main(String[] args) {

       // 定义源数组

       int[] srcArray = {23 , 45 , 67 , 89 , 14 , 56 } ;

       // 定义目标数组

       int[] desArray = new int[10] ;

       // 进行数组元素的copy: 把srcArray数组中从0索引开始的3个元素,从desArray数组中的1索引开始复制过去

       System.arraycopy(srcArray , 0 , desArray , 1 , 3);

       // 遍历目标数组

       for(int x = 0 ; x < desArray.length ; x++) {

           if(x != desArray.length - 1) {

               System.out.print(desArray[x] + ", ");

           }else {

               System.out.println(desArray[x]);

           }

       }

   }

}

运行程序进行测试,控制台输出结果如下所示:

0, 23, 45, 67, 0, 0, 0, 0, 0, 0

通过控制台输出结果我们可以看到,数组元素的确进行复制了。

使用这个方法我们也可以完成数组元素的删除操作,如下所示:

public class SystemDemo02 {

   public static void main(String[] args) {

       // 定义一个数组

       int[] srcArray = {23 , 45 , 67 , 89 , 14 , 56 } ;

       // 删除数组中第3个元素(67):要删除67这个元素,我们只需要将67后面的其他元素依次向前进行移动即可

       System.arraycopy(srcArray , 3 , srcArray , 2 , 3);

       // 遍历srcArray数组

       for(int x = 0 ; x < srcArray.length ; x++) {

           if(x != desArray.length - 1) {

               System.out.print(srcArray[x] + ", ");

           }else {

               System.out.println(srcArray[x]);

           }

       }

   }

}

运行程序进行测试,控制台的输出结果如下所示:

23, 45, 89, 14, 56, 56

通过控制台输出结果我们可以看到此时多出了一个56元素,此时我们只需要将最后一个位置设置为0即可。如下所示:

public class SystemDemo02 {

   public static void main(String[] args) {

       // 定义一个数组

       int[] srcArray = {23 , 45 , 67 , 89 , 14 , 56 } ;

       // 删除数组中第3个元素(67):要删除67这个元素,我们只需要将67后面的其他元素依次向前进行移动即可

       System.arraycopy(srcArray , 3 , srcArray , 2 , 3);

       // 将最后一个位置的元素设置为0

       srcArray[srcArray.length - 1] = 0 ;

       // 遍历srcArray数组

       for(int x = 0 ; x < srcArray.length ; x++) {

           if(x != srcArray.length - 1 ) {

               System.out.print(srcArray[x] + ", ");

           }else {

               System.out.println(srcArray[x]);

           }

       }

   }

}

运行程序进行测试,控制台输出结果如下所示:

23, 45, 89, 14, 56, 0

此时我们可以看到元素"67"已经被删除掉了。67后面的其他元素依次向前进行移动了一位。

arraycopy方法底层细节:

1.如果数据源数组和目的地数组都是基本数据类型,那么两者的类型必须保持一致,否则会报错

2.在拷贝的时候需要考虑数组的长度,如果超出范围也会报错

3.如果数据源数组和目的地数组都是引用数据类型,那么子类类型可以赋值给父类类型

代码示例:

public class SystemDemo3 {

   public static void main(String[] args) {

       //public static void arraycopy(数据源数组,起始索引,目的地数组,起始索引,拷贝个数) 数组拷贝

       //细节:

       //1.如果数据源数组和目的地数组都是基本数据类型,那么两者的类型必须保持一致,否则会报错

       //2.在拷贝的时候需要考虑数组的长度,如果超出范围也会报错

       //3.如果数据源数组和目的地数组都是引用数据类型,那么子类类型可以赋值给父类类型

       Student s1 = new Student("zhangsan", 23);

       Student s2 = new Student("lisi", 24);

       Student s3 = new Student("wangwu", 25);

       Student[] arr1 = {s1, s2, s3};

       Person[] arr2 = new Person[3];

       //把arr1中对象的地址值赋值给arr2中

       System.arraycopy(arr1, 0, arr2, 0, 3);

       //遍历数组arr2

       for (int i = 0; i < arr2.length; i++) {

           Student stu = (Student) arr2[i];

           System.out.println(stu.getName() + "," + stu.getAge());

       }

   }

}

class Person {

   private String name;

   private int age;

   public Person() {

   }

   public Person(String name, int age) {

       this.name = name;

       this.age = age;

   }

   /**

    * 获取

    *

    * @return name

    */

   public String getName() {

       return name;

   }

   /**

    * 设置

    *

    * @param name

    */

   public void setName(String name) {

       this.name = name;

   }

   /**

    * 获取

    *

    * @return age

    */

   public int getAge() {

       return age;

   }

   /**

    * 设置

    *

    * @param age

    */

   public void setAge(int age) {

       this.age = age;

   }

   public String toString() {

       return "Person{name = " + name + ", age = " + age + "}";

   }

}

class Student extends Person {

   public Student() {

   }

   public Student(String name, int age) {

       super(name, age);

   }

}


相关文章
|
14天前
|
Java API Spring
打造未来电商新引擎:揭秘Java可扩展API设计,让支付与物流灵活如丝,引领电商时代潮流!
【8月更文挑战第30天】本文通过电商平台案例,探讨了如何设计可扩展的Java API。首先定义支付和物流服务的接口与抽象类,然后实现具体服务,接着引入工厂模式或依赖注入管理服务实例,最后通过配置实现灵活扩展。这种设计确保了应用架构的灵活性和长期稳定性。
35 3
|
15天前
|
安全 Java API
告别繁琐编码,拥抱Java 8新特性:Stream API与Optional类助你高效编程,成就卓越开发者!
【8月更文挑战第29天】Java 8为开发者引入了多项新特性,其中Stream API和Optional类尤其值得关注。Stream API对集合操作进行了高级抽象,支持声明式的数据处理,避免了显式循环代码的编写;而Optional类则作为非空值的容器,有效减少了空指针异常的风险。通过几个实战示例,我们展示了如何利用Stream API进行过滤与转换操作,以及如何借助Optional类安全地处理可能为null的数据,从而使代码更加简洁和健壮。
44 0
|
23天前
|
Java 编译器 API
Java新手必看:轻松掌握API文档使用技巧!
API是预定义的接口,允许开发人员使用一组例程及协议而无需了解内部实现细节。Java API文档详述了标准类库,支持平台无关性和安全性,确保Java程序跨平台的一致性行为。Java类可通过单文件或多文件定义,并支持内部类及包组织。常用API如`Scanner`用于输入处理,`Random`生成随机数,`ArrayList`提供动态列表管理,而`Arrays`和`Math`分别简化数组操作和数学计算。掌握这些API能显著提升Java开发效率。
|
2天前
|
Java API C++
Java 8 Stream Api 中的 peek 操作
本文介绍了Java中`Stream`的`peek`操作,该操作通过`Consumer&lt;T&gt;`函数消费流中的每个元素,但不改变元素类型。文章详细解释了`Consumer&lt;T&gt;`接口及其使用场景,并通过示例代码展示了`peek`操作的应用。此外,还对比了`peek`与`map`的区别,帮助读者更好地理解这两种操作的不同用途。作者为码农小胖哥,原文发布于稀土掘金。
Java 8 Stream Api 中的 peek 操作
|
7天前
|
安全 Java API
【本地与Java无缝对接】JDK 22外部函数和内存API:JNI终结者,性能与安全双提升!
【9月更文挑战第6天】JDK 22的外部函数和内存API无疑是Java编程语言发展史上的一个重要里程碑。它不仅解决了JNI的诸多局限和挑战,还为Java与本地代码的互操作提供了更加高效、安全和简洁的解决方案。随着FFM API的逐渐成熟和完善,我们有理由相信,Java将在更多领域展现出其强大的生命力和竞争力。让我们共同期待Java编程新纪元的到来!
30 11
|
4天前
|
监控 Java 大数据
【Java内存管理新突破】JDK 22:细粒度内存管理API,精准控制每一块内存!
【9月更文挑战第9天】虽然目前JDK 22的确切内容尚未公布,但我们可以根据Java语言的发展趋势和社区的需求,预测细粒度内存管理API可能成为未来Java内存管理领域的新突破。这套API将为开发者提供前所未有的内存控制能力,助力Java应用在更多领域发挥更大作用。我们期待JDK 22的发布,期待Java语言在内存管理领域的持续创新和发展。
|
6天前
|
Java API 数据处理
【Java的SIMD革命】JDK 22向量API:释放硬件潜能,让Java应用性能飙升!
【9月更文挑战第7天】 JDK 22向量API的发布标志着Java编程语言在SIMD技术领域的重大突破。这一新特性不仅释放了现代硬件的潜能,更让Java应用性能实现了飙升。我们有理由相信,在未来的发展中,Java将继续引领编程语言的潮流,为开发者们带来更加高效、更加强大的编程体验。让我们共同期待Java在SIMD技术的推动下开启一个全新的性能提升时代!
|
7天前
|
Java API 开发者
【Java字节码操控新篇章】JDK 22类文件API预览:解锁Java底层的无限可能!
【9月更文挑战第6天】JDK 22的类文件API为Java开发者们打开了一扇通往Java底层世界的大门。通过这个API,我们可以更加深入地理解Java程序的工作原理,实现更加灵活和强大的功能。虽然目前它还处于预览版阶段,但我们已经可以预见其在未来Java开发中的重要地位。让我们共同期待Java字节码操控新篇章的到来!
|
5天前
|
Java API 开发者
【Java字节码的掌控者】JDK 22类文件API:解锁Java深层次的奥秘,赋能开发者无限可能!
【9月更文挑战第8天】JDK 22类文件API的引入,为Java开发者们打开了一扇通往Java字节码操控新世界的大门。通过这个API,我们可以更加深入地理解Java程序的底层行为,实现更加高效、可靠和创新的Java应用。虽然目前它还处于预览版阶段,但我们已经可以预见其在未来Java开发中的重要地位。让我们共同期待Java字节码操控新篇章的到来,并积极探索类文件API带来的无限可能!
|
14天前
|
Java API
Java 8新特性:Lambda表达式与Stream API的深度解析
【7月更文挑战第61天】本文将深入探讨Java 8中的两个重要特性:Lambda表达式和Stream API。我们将首先介绍Lambda表达式的基本概念和语法,然后详细解析Stream API的使用和优势。最后,我们将通过实例代码演示如何结合使用Lambda表达式和Stream API,以提高Java编程的效率和可读性。