第十五天

一、通过Java程序的入口main(String[] args)方法的参数获取用户的输入值

我们讲第一个Java程序HelloWorld的时候:

第一步:java源代码程序:HelloWorld.java

第二步:javac命令,生成HelloWorld.class文件,字节码文件

第三步:java运行HelloWorld.class文件种的程序

 

这里java命令实质上是通知JVMJava虚拟机)来执行HelloWorld里的main方法:

public class HelloWorld{

public static void main(String[] args){

System.out.println("Hello World!");

}

}

这里有两个问值得我们来讨论讨论:

1Java虚拟机是什么?

JVMJRE的一部分。它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来实现的。JVM有自己完善的硬件架构,如处理器、堆栈、寄存器等,还具有相应的指令系统。Java语言最重要的特点就是跨平台运行。使用JVM就是为了支持与操作系统无关,实现跨平台。所以,JAVA虚拟机JVM是属于JRE的,而现在我们安装JDK时也附带安装了JREJRE又包含了JVM.

2、谁调用main()方法,JVM调用的,那么main方法中的args参数当然也应该是JVM赋值的,但JVM怎么知道如何为args数组赋值呢?

 

二、Scanner获取键盘的输入

接下来我们演示一个最简单的数据输入,并通过 Scanner 类的 next() nextLine() 方法获取输入的字符串,在读取前我们一般需要 使用 hasNext hasNextLine 判断是否还有输入的数据:

next() nextLine() 区别

next()的使用方法演示:

package coursetest;

import java.util.Scanner;

public class Demo {
    public static void main (String[] args) {
        //想要获取用户在键盘上输入的信息,以字符串数据类型来获取,next()或nextline()都可以实现
        //先用next()
        Scanner scanner = new Scanner(System.in);
        //一般情况下,再获取信息之前,我们要先判断一下,有没得信息
        System.out.println("请输入String类信息");
        if(scanner.hasNext()) {
            String rs = scanner.next();
            System.out.println("刚刚您输入的字符串为:"+rs);
        }
    }    //结果为:请输入String类信息
}                // a b c  1
               // 刚刚您输入的字符串为:a

总结next方法:

·        1、一定要读取到有效字符后才可以结束输入。

·        2、对输入有效字符之前遇到的空白,next() 方法会自动将其去掉。

·        3、只有输入有效字符后才将其后面输入的空白作为分隔符或者结束符。

·        4next() 不能得到带有空格的字符串。

nextLine()的使用方法演示:

package coursetest;

import java.util.Scanner;

public class Demo {
    public static void main (String[] args) {
        //想要获取用户在键盘上输入的信息,以字符串数据类型来获取,next()或nextline()都可以实现
        //先用next()
        Scanner scanner = new Scanner(System.in);
        //一般情况下,再获取信息之前,我们要先判断一下,有没得信息
        System.out.println("请输入String类信息");
        if(scanner.hasNext()) {
            String rs = scanner.nextLine();
            System.out.println("刚刚您输入的字符串为:"+rs);
        }
    }    //结果为:请输入String类信息
}                  //     xax    x    x
//刚刚您输入的字符串为:     xax    x    x

 

 

由上面可以看出,nextLine()方法具有以下特点:

·        1Enter为结束符,也就是说 nextLine()方法返回的是输入回车之前的所有字符;

·        2、可以获得空白,都会读入,空格等均会被识别;

 

注意:如果要输入 int float 类型的数据,在 Scanner 类中也有支持,但是在输入之前最好先使用 hasNextXxx() 方法进行验证,再使用nextXxx() 来读取,下面实现的功能是可以输入多个数字,并求其总和与平均数,每输入一个数字用回车确认,通过输入非数字来结束输入并输出执行结果:

 

package coursetest;

import java.util.Scanner;

public class Demo {
    public static void main (String[] args) {
        //想要获取用户在键盘上输入的信息,以字符串数据类型来获取,next()或nextline()都可以实现
        //先用next()
        Scanner scanner = new Scanner(System.in);
        //一般情况下,再获取信息之前,我们要先判断一下,有没得信息
        System.out.println("请输入int类信息");
        if(scanner.hasNextInt()) {
            int rs = scanner.nextInt();
            System.out.println("刚刚您输入的字符串为:"+rs);
        }
    }    //结果为:请输入int类信息
}//    123
//    刚刚您输入的字符串为:123

请输入数字: 20.0 30.0 40.0 end 3个数的和为90.0 3个数的平均值是30.0

 

 

 

一、System

System类代表了当前Java程序的运行时平台,程序不能创建System类的对象(它的构造器是private修饰的),System类提供了一些类变量和方法(都是static修饰的),允许直接通过System类来调用这些变量和方法。

 1、成员变量

System类内部包含inouterr三个成员变量,分别代表标准输入流(键盘输入),标准输出流(显示器)和标准错误输出流(显示器)

      例如:System.out.println(“Test”);

该行代码的作用是将字符串”Test”输出到系统的标准输出设备上,也就是显示在屏幕上。

后续在学习完IO相关的知识以后,可以使用System类中的成员方法改变标准输入流等对应的设备,例如可以将标准输出流输出的信息输出到文件内部,从而形成日志文件等。

 

2、成员方法

System类中提供了一些系统级的操作方法,这些方法实现的功能分别如下:

aarraycopy方法

该方法的作用是数组拷贝,也就是将一个数组中的内容复制到另外一个数组中的指定位置,由于该方法是native方法,所以性能上比使用循环高效。

使用示例:

import java.lang.reflect.Array;
import java.util.Arrays;
import java.util.Scanner;

public class Demo {
    public static void main (String[] args) {
        int[] a = {1,2,3};
        int[] b = {4,5,6};
      System.arraycopy(a, 1, b, 1,2);//将a数组下标为1之后的2个数组元素复制到b数组下标为1的后面
      //b后面不能为3因为数组长度不能改变
      System.out.println(Arrays.toString(b));
      //Arrays.toString(b)打印数组b
    }//结果如下:[4, 2, 3]
}

该代码的作用是将数组a中,从下标为1开始,复制到数组b从下标1开始的位置,总共复制2个。 

bcurrentTimeMillis方法

public static long currentTimeMillis()

该方法的作用是返回当前的计算机时间,时间的表达格式为当前计算机时间和GMT时间(格林威治时间)197011000秒所差的毫秒数。

例如:

         long l = System. currentTimeMillis();

则获得的将是一个长整型的数字,该数字就是以差值表达的当前时间。

使用该方法获得的时间不够直观,主要用在计算程序运行需要的时间:

 

public class Demo {
    public static void main (String[] args) {
    System.out.println(System.currentTimeMillis());
    //格林威治时间与运行时相差多少毫秒
    long start = System.currentTimeMillis();
    //格林威治时间与运行时相差多少毫秒
    for(int i=0;i<10000;i++) {
        int a = i;
    }
    long end = System.currentTimeMillis();
    System.out.println("for循环执行的时间:"+(end-start)+"毫秒");
    }//运行结果:for循环执行的时间:1毫秒
}

则这里变量time的值就代表该代码中间的for循环执行需要的毫秒数,使用这种方式可以测试不同算法的程序的执行效率高低,也可以用于后期线程控制时的精确延时实现。

cexit方法

public static void exit(int status)

该方法的作用是退出程序。其中status的值为0代表正常退出,非零代表异常退出。使用该方法可以在图形界面编程中实现程序的退出功能等。        dgc方法

public static void gc()

该方法的作用是请求系统进行垃圾回收。至于系统是否立刻回收,则取决于系统中垃圾回收算法的实现以及系统执行时的情况

 egetProperty方法

public static String getProperty(String key)

该方法的作用是获得系统中属性名为key的属性对应的值。常用的属性如下:

public class Demo {
    public static void main (String[] args) {
    System.out.println(System.getProperty("java.version"));
    System.out.println(System.getProperty("os.name"));
    System.out.println(System.getProperty("user.dir"));
    }//运行结果:1.8.0_73
}                //Windows 10
                //D:stsworkspacedemo

 

一、概述

      Runtime类封装了当前JVM运行时的环境。

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

      一般不能实例化一个Runtime对象,应用程序也不能创建自己的 Runtime 类实例,

但可以通过 getRuntime 方法获取当前Runtime运行时对象的引用。

      一旦得到了一个当前的Runtime对象的引用,就可以调用Runtime对象的方法去控制Java虚拟机的状态和行为。 

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

 

二、Runtime类的常见应用

1、查看机器的处理器数量(了解)

 

public class Demo {
   public static void main(String[] args) {
    //用一下runtime类的对象,获取当前计算机的cpu的处理数量
       Runtime rt = Runtime.getRuntime();
       System.out.println(rt.availableProcessors());
    }
}//运行结果:8  

2、内存管理(了解)

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

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

 

public class Demo {
   public static void main(String[] args) {
    //用一下runtime类的对象,获取当前计算机的cpu的处理数量
       Runtime rt = Runtime.getRuntime();
     System.out.println("jvm从物理内存中分配的总内存:"+rt.totalMemory()+"byte");     
     System.out.println("初始的时候,可用的内存:"+rt.freeMemory()+"byte");
     rt.gc();
     System.out.println("第一次gc后,可用的内存:"+rt.freeMemory()+"byte");
   //人为占用一部分内存
     Integer[] arr = new Integer[10000000];
     for(int i=0;i<1000000;i++) {
         arr[i] = new Integer(i);//对象数组
     }
     System.out.println("循环后,可用的内存:"+rt.freeMemory()+"byte");
     for(int i=0;i<1000000;i++) {
         arr[i] = null;//这个操作就是我们刚刚示意图上的,引用删除掉,没有删除对象
     } 
     rt.gc();
     System.out.println("第二次gc后,可用的内存:"+rt.freeMemory()+"byte");
   }
}//运行结果:jvm从物理内存中分配的总内存:64487424byte
//初始的时候,可用的内存:62808992byte
//第一次gc后,可用的内存:63606208byte
//循环后,可用的内存:7530336byte
//第二次gc后,可用的内存:23605608byte

注意知识点:这里的Runtime和前面的System都含有gc方法,他们的异同

1java.lang.System.gc()只是java.lang.Runtime.getRuntime().gc()的简写,两者的行为没有任何不同。

2、唯一的区别就是System.gc()写起来比Runtime.getRuntime().gc()简单点.

总结:其实基本没什么机会用得到这个命令, 因为这个命令只是建议JVM安排GC运行, 还有可能完全被拒绝。 GC本身是会周期性的自动运行的,JVM决定运行的时机,而且现在的版本有多种更智能的模式可以选择,还会根据运行的机器自动去做选择,就算真的有性能上的需求,也应该去对GC的运行机制进行微调,而不是通过使用这个命令来实现性能的优化

3、在java程序中调用第三方程序(实用)

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

 下面的例子是使用exec()方法启动windows的记事本notepad。这个例子必须在Windows操作系统上运行。

 

import java.io.IOException;

public class Demo {
   public static void main(String[] args) {
    //拿到Rt
       Runtime rt = Runtime.getRuntime();
       Process p = null;
       try {
           p = rt.exec("notepad");
       }catch (IOException e) {
        System.out.println("调用记事本程序失败");
    }
   }
}//运行结果:记事本被打开

exec()还有其他几种形式,例子中演示的是最常用的一种。ecec()方法返回Process对象后,在新程序开始运行后就可以使用Process的方法了。可以用destory()方法杀死子进程,也可以使用waitFor()方法暂停程序直到子程序结束,exitValue()方法返回子进程结束时返回的值。如果没有错误,将返回0,否则返回非0

下面是关于exec()方法的例子的改进版本。例子被修改为等待,直到运行的进程退出:

 

import java.io.IOException;

public class Demo {
   public static void main(String[] args) {
    //拿到Rt
       Runtime rt = Runtime.getRuntime();
       Process p = null;
       try {
           p = rt.exec("notepad");
           //p.waitFor(); //等待打开的新的程序,执行完成以后,才继续后面的Java程序
           Thread.sleep(3000);//延时执行后面代码
           p.destroy();//打开后瞬间关掉
       }catch (IOException | InterruptedException  e) {
        System.out.println("调用记事本程序失败");
    }
       System.out.println("exec方法后面的程序");
   }
}//运行结果:记事本被打开  加上p.waitfor 关掉记事本才运行下个程序

 

JAVA现在执行外部命令,主要的方式,WINDOWS下面就用CMDLINUX或者是UNIX下面就用SHELL

原文地址:https://www.cnblogs.com/jikebin/p/12513616.html