11.常用类库

11.1包装类

Java是一种面向对象语言,但在Java中不能定义基本数据类型 的对象,为了能将基本数据类型视为对象进行处理,Java提出了包装类的概念,它主要是讲基本数据类型封装在包装类中,如int型的包装类Integer,boolean型的包装类Boolean等,这样便可以把这些基本数据类型转换为对象进行处理。Java中的包装类及其对应的基本数据类型的包装类Boolean等,这样便可以把这些基本数据类型转换为对象进行处理。

 

说明Java是可以直接处理基本数据类型的,但在有些情况下需要将其作为对象来处理,这时就需要将其转换为包装类了,这里的包装类相当于基本数据类型于对象类型之间的一个桥梁。由于包装类和基本数据类型之间的转换

11.1.1  Integer类

java.lang包中的Integer类,Bye类,Short类和Long类,分别将基本数据类型int,byte,short和long封装成一个类,由于这些类都是Number类的子类,区别就是封装不同的数据类型,其包含的方法基本相同,所以以Integer类为整数包装类。

Integer类的在对象中包装了一个基本数据类型int的值,该类的对象包含一个int类型的字段。此外,该类提供了多个方法,能在int类型和String类型之间互相转换,同时还提供了其他一些处理int类型时非常有用的常量和方法。Ieteger类的常用方法。

例题【11.1】代码如下:

运行结果:

Integer类提供了四个常量:

<:MAX_VALUE:表示int类型可取的最大值,即2的31次方-1.

<MIN_VALUE:表示int类型可取的最小值,即-2的31次方。

<SIZE:用来以二进制补码形式表示int值的位数。

<TYPE:表示基本类型int的Class实例。

例题代码【11.2】

 运行结果如下:

将常量值输出,获取Integer类的常量值。

final修饰成员变量
final关键字在修饰局部变量时,必须给定该变量一个值,这就是常见的final的用法,定义常量。但是final关键字再修饰成员变量时,却变得也可以“通融”一下,在Java中,final关键字所修饰的成员变量,在该类的所有构造方法中必须给该被final修饰的成员变量赋值,请注意,是所有的构造方法,如果没有构造方法,必须编写一个构造方法,在该构造方法中给该变量赋值。例如:此时定义了一个f类,在该类中定义了一个被final修饰的int类型的变量val,此时没有给定初值,此时也没有构造方法,所以编译器直接报了一个错误。

 

11.1.2  Double类

Double类和Float类是对double,float基本类型的封装,它们都是Number类的子类,都是对浮点数进行操作,所以常用方法基本相同。

Double类在对象中包装一个基本类型为double的值,每个Double类的对象都包含一个double类型的字段,此外,该类还提供多个方法,可以将double类型转换为String类型,String 类型转换为double类型,也提供了其他一些处理double类型时有用的常量和方法。

Double类的常用方法。

Double类的常用方法例题【11.3】代码如下

 运行结果如下:

 Double类主要提供了以下常量:

<MAX_EXPONENT:返回int值,表示有限double变量可能具有的最大指数。

<MIN_EXPONENT:返回int值,表示标准化double变量可能具有的最小指数。

<NEGATVE_INFINTY:返回double值,表示保存double类型的负无穷大值的常量。

<POSITIVE_INFINTY:返回double值,表示保存double类型的正无穷大值的常量。

11.1.3  Boolean类

Boolean类将基本类型为boolean的值包在一个对象中。一个Blooean类型的对象只包含一个类型为blooean的字段。此外,此类还为blooean类型和String类型的相互提供了许多方法,提供了处理boolean类型时非常有用的其他一些常量和方法。

Boolean类的常用方法如表。

【11.3】例题代码如下

 

  代码如下:

 Boolean提供了以下3个常量:

<TRUE:对应基值true的Boolean对象。

<FALSE:对应基值boolean的Class对象。

TYPE:基本类型boolean的Class对象。

11.1.4 Character类

Character类在对象中包装一个基本类型为char的值,该类提供了多种方法,以确定字符的类别(小写字母,数字等),并可以很方便将字符从大写转换小写,反之亦然。Character提供了很多方法来完成对字符的操作。

常用的方法如表

例题【11.4】

代码如下:

Character类提供了大量的表示特定字符的常量,例如:

<CONNECTOR_PUNCTUATION:返回byte型值,表示Unicode规范中的常规类别"Cn".

<TITLECASE_LETTER:返回byte型值,表示Unicode规范的常规类别“Li”。

11..1.5  Number 类

对于数值型的包装类,它们有一个共同的父类——Numebr类,该类是一个抽象类,它是Byte,Integer,Short,Long,Float,和Double类的父类,其子类必须提供将表示的数值转换为byte,int,short,long,float,double的方法。例如,doubleValue()方法返回双精度浮点值,floatValue()方法返回单精度浮点值,这些方法如下:

Numebr类的方法分别被其各子类所实现,也就是说,在Number类的所有子类中包含以上这几条各种方法。

11.2 数字处理

在Java语言中,提供了一个执行数学基本运算的Math类,该类包括常用的数学运算方法,如三角函数方法,指数函数方法,对数函数方法,平方根函数方法等一些常用数学函数方法,初次此后,提供了一些常用的数学运算方法,如角函数方法、指数函数方法、对数函数方法、平方根函数方法等一些常用数学函数方法。除此之外还提供了一些常用的数学常量,如 PI、E 等。\n\n在实际开发中,随机数的使用是很普遍的,所以要掌握生成随机数的操作。在Java 中主要提供]两种生成随机数的方式,分别为调用 Math 类的random()方法生成随机数和调用 Random 类生成各种整据类型的随机数。\n\n在Java 中,还提供了大数字的操作类,即 java.math.BigInteger 类与java.math.BigDecimal类。这个类用于高精度计算,其中 BigInteger 类是针对大整数的处理类,而 BigDecimal类则是针对大小数的处理类。

11.2.1 数字格式化
数字格式化在解决实际问题时应用非常普遍,如表示某超市的商品价格,需要保留两位有效数字数字格式化操作主要针对的是浮点型数据,包括 double 型和 float 型数据。在 Java 中使用 java.textDecimalFormat格式化数字。

在 Java 中,没有格式化的数据遵循以下原则:如果数据绝对值大于0.001并且小于10000000,使以常规小数形式表示。如果数据绝对值小于0.001或者大于10000000,使用科学记数法表示。由于上述输出格式不能满足解决实际问题的要求,通常将结果格式化为指定形式后输出。在 Jav中,可以使用DecimalFormat类进行格式化操作。DecimalFormat类是NumberFormat 的一个子类,用于格式化十进制数字。它可以将一些数字格式化为整数、浮点数、百分数等。通过使用该类可以为要输出的数字加上单位或控制数字的精度。一艘情况下,可以在实例化 DecimalFormat 对象时传递数字格式,也可以通过 DecimalFormat 类中applyPattern0方法来实现数字格式化。当格式化数字时,可在 DecimalFormat 类中使用一些特殊字符构成一个格式化模板,使数字按照定的特殊字符规则进行匹配。表 11.7 列举了格式化模板中的特殊字符及其所代表的含义。

11.2.2 Math类
Math 类提供了众多数学函数方法,主要包括三角函数方法,指数函数方法,取整函数方法,取量大值、最小值,以及平均值函数方法。这些方法都被定义为 static 形式,所以在程序中应用比较简便可以使用如下形式调用:


Math. 数学方法

 在Math类中,除函数方法外还存在一些常用数字常量,如PI、E等。这些数学常量作为Math 关的成员变量出现,调用起来也很简单。可以使用如下形式调用:

Math.PI
Math.E

Math 类中的常用数学运算方法较多,大致可以将其分为四大类别,分别为三角函数方法,指数函数方法,取整函数方法,以及取最大值、最小值和绝对值函数方法。

三角函数方法
Math 类中包含的三角函数方法如下

: public static double sin(doublea):返回角的三角正弦。public static double cos(double a):返回角的三角余弦。

public static double tan(double a):返回角的三角正切。public static double asin(doublea): 返回一个值的反正弦。

public static double acos(doublea): 返回一个值的反余弦。

public static double atan(doublea):返回一个值的反正切。

public static double toRadians(double angdeg): 将角度转换为弧度。 public static double toDegrees(double angrad): 将弧度转换为角度。

以上每个方法的参数和返回值都是double型的。将这些方法的参数的值设置为 double 型是有一定道理的,参数以弧度代替角度来实现,其中1°等于 /180 弧度,所以 180°可以使用弧度来表示。除了可以获取角的正弦、余弦、正切、反正弦、反余弦、反正切,Math 类还提供了角度和弧度相互转换的方法 toRadians()和 toDegrees()。但需要注意的是,角度与弧度的转换通常是不精确的。

例题【11.7】代码如下:

运行结果如下:

 取最大值、最小值、绝对值函数方法

在程序中最常用的方法就是取最大值、最小值、绝对值等,Math 类中包括的操作方法如下:

public static double max(double adouble b):取a与b之间的最大值。

public static int min(int a,int b):取a与b之间的最小值,参数为整型。

public static long min(long a,long b):取a与b之间的最小值,参数为长整型。

public static float min(float a,float b):取a与b之间的最小值,参数为单精度浮点型。

public static double min(double a double b):取a与b之间的最小值,参数为双精度浮点型。

public static int abs(int a):返回整型参数的绝对值。

public static long abs(long a):返回长整型参数的绝对值。

public static float abs(float a):返回单精度浮点型参数的绝对值。

 public static double abs(double a):返回双精度浮点型参数的绝对值。

 例题代码【11.8】

 运行结果:

  Random类
Random类是JDK 中的随机数生成器类,可以通过实例化一个 Random 对象创建一个随机数生成器,语法如下:

Random r = new Random();

以这种方式实例化对象时,Java 编译器将以系统当前时间作为随机数生成器的种子。因为每时每刻的时间不可能相同,所以产生的随机数不同。但是如果运行速度太快,也会产生两个运行结果相同的随机数。用户也可以在实例化 Random 类对象时,设置随机数生成器的种子。

语法如下:

Random r = new Random(seedValue);

 Random类对象。

seedValue:随机数生成器的种子。

在Random类中,提供了获取各种数类机数的方法,下面列举几个常用的方法:

public int nextint():返回一个随机整数。

public int nextInt(int n): 返回大于等于0且小于n 的随机整数。

public long nextLong():返回一个随机长整型值。

public boolean nextBoolean():返回一个随机布尔型值。

public float nextFloat0: 返回一个随机单精度浮点型值。

public double nextDouble():返回一个随机双精度浮点型值。

public double nextGaussian(): 返回一个概率察度为高斯分布的双精度浮点型值。

 例题代码如下:【11.6】

 运行结果:

 BigInteger类
BigInteger 类的数字范围校 Integer类的数字范围要大得多。前文介绍计 Ineger 类是int的包装类,int的最大值为 ,如果要计算更大的数字,使用 Integer 类就无法实现了,所以Java中提供了BigInteger类来处理更大的数字。Biglnteger 类支持任意精度的整数,也就是说,在运算中BigInteger类可以准确地表示任何大小的整数值而不会丢失信息。在BigInteger 类中封装了多种操作,除了基本的加、减、乘、除操作,还提供了绝对值、相反数、最大公约数以及判断是否为质数等操作。使用BigInteger 类,可以实例化一个BigInteger 对象,并自动调用相应的构造函数。BigInteger 类具有很多构造函数,但是直接的一种方式是参数以字符串形式代表有处理的数字。例如,将 2 转换为 BigInteger 类型,可以使用以下语句进行初始化操作:

Biginteger twolnstance = new Bigintegor(\"2\");

一且创建了对象实例,就可以调用 BigInteger 类中的一些方法进行运算操作,包括基本的数学运算和位运算以及一些取相反数、取绝对值等操作。

下面列举了 Biglnteger类中常用的几种运算方法:

public BigInteger add(BigInteger val): 做加法运算。

public BigInteger subtract(BigInteger val): 做减法运算。

public BigInteger multiply(BigInteger val): 做乘法运算。

public BigInteger divide(BigInteger val): 做除法运算。

public BigInteger remainder(BigInteger val): 做取余操作。

public BigInteger[] divideAndRemainder(BigInteger val): 用数组返回余数和商,结果数组中第一个值为商,第二个值为余数。

public BigInteger pow(int exponent): 进行取参数的 exponent 次方操作。

public BigInteger negate(): 取相反数。

 public BigInteger shifLeft(intn): 将数字左移n位,如果n为负数,做右移操作。

public BigInteger shiftRight(int n): 将数字右移n 位,如果n为负数,做左移操作。

public BigInteger and(BigInteger val): 做与操作。

public BigInteger or(BigInteger val): 做或操作。

public int compareTo(BigInteger val): 做数字比较操作。

public boolean equals(Object x): 当参数是 BigInteger 类型的数字并且数值与对象实例的数值相等时,返回 true。

public BigInteger min(BigInteger val): 返回较小的数值。

public BigInteger max(BigInteger val): 返回较大的数值。

 11.2.5 BigDecimal类

BigDecimal类和 BigInteger 类都能实现大数字的运算,不同的是 BigDecimal 类加入了小数的概念。一般的 float 型和 double 型数据只可以用来做科学计算或工程计算,但由于在商业计算中要求数字精度比较高,所以要用到 BigDecimal 类。BigDecimal 类支持任何精度的定点数,可以用它来精确计算货币值。在 BigDecimal类中,常用的两个构造方法如下表:

代码如下:

 运行结果如下:

BigDecimal 类型的数字可以用来做超大的浮点数的运算,如加、减、乘、除等,但是在所有的运算中除法是最复杂的,因为在除不尽的情况下商小数点后的末位的处理是需要考虑的。BigDecimal 实现的加、减、乘、除的方法如表下: 

 在上述方法中,BigDecimal类中 divide0方法有多种设置,用于返回商小数点后的末位的处理,这些模式的名称与含义如表11.10所示

System类\nsystem 类是JDK 中提供的系统类,该类是用 fmal 修饰的,所以不允许被继。 System 类提供了最多系统层面的操作方法,并且这些方法全部都是静态的。System 类提供的较常用方法如下表:

 11.3.1 控制台输出字符

System类提供了标准输入、标准输出和错误输出流,也就是说,System 类提供了3 个静态对象:in、out和err。本书中的代码多次使用了这些对象,最常见的就是out 对象。在控制台输出字符串,输出的方法有两种。

不会自动换行的print()方法
print()方法的语法如下:


System.out.print(\"Hello!\");


此方法输出“Hello”文字,输出完毕后,光标会停留在“Hello” 文字末尾,不会自动换行。

可以自动换行的println()方法

printin()方法在 print 后面加上了“ln”后缀 (就是 line 的简写),语法知下:

System.out.println(\"书籍是人类进步的阶梯!\");

此方法输出“书籍是人类进步的阶梯!”后会自动换行。光标停留在下一行的开头。println()方法与 println()方法输出的对比效果如表 11.12 所示:

 综上所述,Java 输出换行的方法有以下两种:


System.out.print(\"\\n\");

//利用换行符\\实现换行System.out.printIn();//空参数即可实现换行.

 11.3.2计时

System.currentTimeMillis()方法可以获取自 1970年1月1日零点至今的毫秒数。Date日期类也有类似的方法,但代码会比 System 类多,所以 System.currentTimeMillis()方法是为获取当前毫秒数最常用的方法。因为该方法的返回值精确到毫秒,所以可以利用该方法来记录程序的运行时间。

【11.14】代码如下:

 运行如下:

 Scanner类

与C 语言不同,Java 从控制台中读出用户输入的值,用到的不是一行可以直接使用的代码,而是 Scaner 的类来实现的。Scanner 英文直译就是扫描仪,它的用途就和现实生活的扫描仪一样,可以把数字化信息流转为人类可识别的文字。控制台输入内容用到了 System.out 就表示向控制台输出 ,System.in 就表示从控制台输入,让 Scanner 扫描 System.in 就可以获取用户输入的值了。\n\n使用 Scanner 类首先要引入该类,其语法如下

:\n\nimport java.util.Scanner; //引入 Scanner类 

Scanner 类提供了如表 11.13 所示的几种常用的方法,通过这些方法可以取控制台中输入的不同类型的值。

 使用Scanner类扫描控制台的代码如下:
Scanner se = new Scanner(System.in);

 【11.15】代码:

 

 运行结果:

11.5 日期时间类
11.5.1 Date类

Date 类用于表示日期时间,使用该类表示时间需要使用其构造方法创建对象,其构造方法及其说明如表 11.14 所示。

 

  例如,使用 Date 类的第 2种构造方法创建一个 Date 类的对象,代码如下:

\n\nlong timeMillis = System.currentTimeMillis();        //当前系统时间所经历的毫秒数
Date date = new Date(timeMillis);

Date 类的常用方法及其说明如表 11.15 所示。

获取当前的日期和时间并输出,代码如下:

 

 运行结果如下:

 11.5.2 日期时间格式化
DateFormat 类是日期时间格式化子类的抽象类,可以按照指定的格式对日期或时间进行格式化DateFormat 类提供了很多类方法,以获得基于默认或给定语言环境和多种格式化风格的默认日期时间Formatter,格式化风格主要包括 SHORT、MEDIUM、LONG 和FULL4种:


 SHORT:完全为数字,如 12.13.2或3:30pm。
MEDIUM:较长,如 Jan 12,1952。
LONG:更长,如January 12,1952 或3:30:32pm。 FULL:完全指定,如 Tuesday、April 12、1952AD 或3:30:42pm PST。

另外,使用 DateFormat 类还可以自定义日期时间的格式。要格式化一个当前语言环境下的日期,首先需要创建 DateFormat 类的一个对象,由于它是抽象类,因此可以使用其静态方getDateInstance()进行创建,语法如下:


DateFormat df = DateFormat.getDatelnstance();使用 getDateInstance()方法获取的是所在国家或地区的标准日期格式。另外,DateFormat 类还提供了一些其他静态方法。例如,使用 getTimeInstance()方法可获取所在国家或地区的时间格式,使用getDateTimeInstance()方法可获取日期和时间格式。

DateFormat 类的常用方法及其说明如表 11.16 所示:

 例如,将当前日期按照DateFormat类默认格式输出:
 


DateFormat df = DateFormat.getlnstance();
System.out.println(df.format(new Date()));
结果如下:
2021/2/19上午9:59
输出长类型格式的当前时间:
DateFormat df = DateFormat.getTimelnstance(DateFormat.LONG);
System.out.println(df.format(new Date()));
结果如下:
CST 上午10:00:33
输出长类型格式的当前日期:
DateFormat df = DateFormat.getDatelnstance(DateFormat.LONG);
System.out.println(df.format(new Date()));
结果如下:
2021年2月19日
输出长类型格式的当前日期和时间:
DateFormat df = DateFormatgetDate Timelnstance(DateFormat.LONG,DateFormat.LONG);
System.out.println(df.format(new Date()));
结果如下:2021年2月19日CST 上午10:01:12

.


SimpleDateFormat 类提供了 19 个格式化字符,可以让开发者随意编写日期格式,这19 个格式化字符如表 11.17 所示。 

 

通常表 11.17 中的字符出现的数量会影响数字的格式。例如,yyyy 表示 4 位年份,这样输入会示2021;yy 表示两位,这样输入就会显示为21;只有一个y的话,会按照 yyyy 显示;如果超过4个y,如yyyyyy,会在4位年份左侧补0,结果为02021。一些常用的日期时间格式如下表:

代码如下: 

运行结果如下:

 DateFormat 类提供的 Date parse(String source)方法可以将字符串转为其字面日期对应的 Date对象,整个过程相当于日期格式化的逆操作。例如,将“2021-02-19”这个字符串转成 Date 对象,可以使用如下代码:

DateFormat sdf = new SimpleDateFormat(\"yyyy-MM-dd);.\n\nDate date = sdf.parse(\"2021-02-19\");

11.5.3 Calendar类

Calendar 类是一个抽象类,它为特定瞬间与一组诸如 YEAR、MONTH、DAY OF_MONTH、HOUR等日历字段之间的转换提供了一些方法,并为操作日历字段(如获得下星期的日期)提供了一些方法。另外,该类还为实现包范围外的具体日历系统提供了其他字段和方法,这些字段和方法被定义为 protected。

Calendar 提供了一个类方法 getInstance(),以获得此类型的一个通用的对象。Calendar 类的getInstance()方法返回一个 Calendar 对象,其日历字段已由当前日期和时间初始化,其使用方法如下:

Calendar rightNow = Calendar.getlnstance();

 

 从表 11.20可以看到,add()方法和 roll()方法都用来为给定的日历字段添加或减去指定的时间量,它们的主要区别在于:使用 add()方法时会影响大的字段,像数学里加法的进位或错位,而使用 roll()方法设置的日期字段只是进行增加或减少,不会改变更大的字段。

代码如下

 运行结果:

  最后对 Calendar 类的使用做出几点总结:c.set(CalendarDAY_OF_MONTH,0)获取的是上个月的最后一天,所以调用前需要将月份往后加一个月。
Calendar.MONTH的第一个月是使用0记录的,所以在获得月份数字后要加1。年和日是从1开始记录的,不需要加 1。
Calendar.DAY OF WEEK 的第一天是周日,周一是第二天,周六是最后一天。

11.6 Runtime类
Runtime 类是 JDK 供的运行时类,该类为 Java程序提供了与当前运行环境相连接的一个通道,Runtime 类不能使用 new 关键字创建实例,只能通过 Runtime. getRuntime()方法获取实例。
Runtime 类的常用方法如下表:

 11.6.1 执行本地命令
本地命令指的是操作系统的命令。例如,在 Linux 系统下就表示 shell 命令,在 Windows 系统下
表示 cmd 命令。
Runtime 类提供 exec()方法让 Java 代码可以执行系统的命令,exec()方法有很多重载的形式,例如:

Process exec(String command)
Process exec(Stringl cmdarray)

 

代码如下:

 

运行结果如下:

 

 

 command:要执行的系统命令,字符串类型。
cmdarray:要执行的命令和相应的命令参数,字符串数组类型。其实这两个重载方式很类似,如执行“javac hello.java”这行命令,使用第一种重载方式的代码如下:

Runtime.getRuntime().exec(\"javac hello.java\");

 使用第二种重载方式的代码如下:

String command] =  {"javac", "hello,java" };

Runtime.getRuntime().exec(command);

 Process类的常用方法如表 11.22 所示,开发可以使用 getInputStream()方法获取进程返回的信息。

 代码如下:

 运行结果:

11.6.2 查看内存
Runtime类可以通过 freeMemory()方法查看当前Java 虚拟机可用内存的剩余量。如果程序能够实时监控内存剩余量,就可以尽量控制程序对内存的占用,从而避免出现“内存溢出”的情况。同样,也可以用来对测试程序性能,检验程序算法是否导致内存紧张。 

执行本地命令
本地命令指的是操作系统的命令。例如,在 Linux 系统下就表示 shell 命令,在 Windows 系统下表示 cmd 命令。
Runtime 类提供 exec()方法让 Java 代码可以执行系统的命令,exec()方法有很多重载的形式。 

 代码如下:

 运行结果如下:

Runtime类可以通过 freeMemory()方法查看当前Java虚拟机可用内存的剩余量。如果程序能够实时监控内存剩余量,就可以尽量控制程序对内存的占用,从而避免出现“内存溢出”的情况。同样,也可以用来对测试程序性能,检验程序算法是否导致内存紧张。
 

 代码如下:

 运行结果:

 总结
在本章中,通过学习大量的AIP(Application Programming Interface)的使用,在程序中合理的运行这些API的话,能使得程序的编写变得越来越好写代码,但是大量的API的学习,不一定学完就记住了,所以还是得经常敲代码,熟悉以及理解。

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值