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);

   }

}


相关文章
|
15天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
45 2
|
22天前
|
缓存 监控 Java
如何运用JAVA开发API接口?
本文详细介绍了如何使用Java开发API接口,涵盖创建、实现、测试和部署接口的关键步骤。同时,讨论了接口的安全性设计和设计原则,帮助开发者构建高效、安全、易于维护的API接口。
53 4
|
1月前
|
Java API 数据处理
探索Java中的Lambda表达式与Stream API
【10月更文挑战第22天】 在Java编程中,Lambda表达式和Stream API是两个强大的功能,它们极大地简化了代码的编写和提高了开发效率。本文将深入探讨这两个概念的基本用法、优势以及在实际项目中的应用案例,帮助读者更好地理解和运用这些现代Java特性。
|
2月前
|
Java 大数据 API
别死脑筋,赶紧学起来!Java之Steam() API 常用方法使用,让开发简单起来!
分享Java Stream API的常用方法,让开发更简单。涵盖filter、map、sorted等操作,提高代码效率与可读性。关注公众号,了解更多技术内容。
|
2月前
|
存储 Java API
如何使用 Java 中的 API 更改 PDF 纸张大小
如何使用 Java 中的 API 更改 PDF 纸张大小
50 11
|
2月前
|
机器学习/深度学习 算法 Java
通过 Java Vector API 利用 SIMD 的强大功能
通过 Java Vector API 利用 SIMD 的强大功能
47 10
|
2月前
|
分布式计算 Java 大数据
大数据-147 Apache Kudu 常用 Java API 增删改查
大数据-147 Apache Kudu 常用 Java API 增删改查
33 1
|
3月前
|
Java API C++
Java 8 Stream Api 中的 peek 操作
本文介绍了Java中`Stream`的`peek`操作,该操作通过`Consumer&lt;T&gt;`函数消费流中的每个元素,但不改变元素类型。文章详细解释了`Consumer&lt;T&gt;`接口及其使用场景,并通过示例代码展示了`peek`操作的应用。此外,还对比了`peek`与`map`的区别,帮助读者更好地理解这两种操作的不同用途。作者为码农小胖哥,原文发布于稀土掘金。
123 9
Java 8 Stream Api 中的 peek 操作
|
3月前
|
Java 程序员 API
Java 8新特性之Lambda表达式与Stream API的探索
【9月更文挑战第24天】本文将深入浅出地介绍Java 8中的重要新特性——Lambda表达式和Stream API,通过实例解析其语法、用法及背后的设计哲学。我们将一探究竟,看看这些新特性如何让Java代码变得更加简洁、易读且富有表现力,同时提升程序的性能和开发效率。
|
2月前
|
SQL Java API
深入探索Java的持久化技术——JPA(Java Persistence API)
【10月更文挑战第10天】深入探索Java的持久化技术——JPA(Java Persistence API)
44 0