java常用类库 源码_Java核心常用类库

一、泛型

概念:

泛型,即“参数化类型”。就是将类型由原来的具体的类型参数化,类似于方法中的变量参数,此时类型也定 义成参数形式(可以称之为类型形参),然后在使用/调用时传入具体的类型(类型实参)。

定义泛型所使用的字母有一些是特定的,比如E是element元素的意思,用来表示容积,后续会学习其他的特定字母。

应用:泛型接口(实现接口时,可以选择指定泛型类型,也可以选择不指定)、泛型类(使用情况最多)、泛型方法

作用:

1、 提高代码复用率 2、 泛型中的类型在使用时指定,不需要强制类型转换(类型安全,编译器会检查类型)

// 右侧尖括号内正常情况下也应该写上String类型,但是在jdk1.7版本之后,可以省略

Person p = new Person();

1

2

可以同时指定多个泛型,

注意:

在编译之后程序会采取去泛型化的措施。

也就是说Java中的泛型,只在编译阶段有效。 在编译过程中,正确检验泛型结果后,会将泛型的相关信息擦出,并且在对象进入和离开方法的边界处添加 类型检查和类型转换的方法。

也就是说,泛型信息不会进入到运行时阶段。

类型受限:

在使用泛型时, 可以指定泛型的限定区域。例如: 必须是某某类的子类或 某某接口的实现类,格式:

通配符?:

1 extends Parent> 指定了泛型类型的上届

2 super Child> 指定了泛型类型的下届

3 > 指定了没有限制的泛型类型

二、java.util.objects

equals:相对于普通对象的equals方法,能够对某一比较对象为null的情况进行比较

isNull:判断对象是否为空 nonNull:判断对象是否不为空

requireNonNull:如果是空直接抛异常,为了限制传过来的对象必须不为空,可以选择不处理直接抛异常

三、java.lang.Math

abs: 求绝对值(double、float、int、long)

min: 比较两个数的最小值(double、float、int、long)

max: 比较两个数的最大值(double、float、int、long)

round:(double、float)

floor: 返回小于等于参数的最大整数,如果参数值已经等于整数,则结果与参数相同。如果参数为NaN或无穷大或正零或负零,则结果与参数相同。

ceil: 返回大于等于参数的最小整数,如果参数值已经等于整数,则结果与参数相同。如果参数为NaN或无穷大或正零或负零,则结果与参数相同。

如果参数值小于零但大于-1.0,则结果为负零。

public class Demo {

public static void main(String[] args) {

System.out.println(Math.abs(-100));

System.out.println(Math.min(100,200));

System.out.println(Math.max(100,200));

// 四舍五入

System.out.println(Math.round(100.5));

System.out.println(Math.round(-100.5));

// 返回小于等于参数的最大整数

System.out.println(Math.floor(3.5));

System.out.println(Math.floor(-3.5));

// 返回大于等于参数的最小整数

System.out.println(Math.ceil(3.5));

System.out.println(Math.ceil(-3.5));

}

}

// 输出结果为

// 100 100 200 101 -100 3.0 -4.0 4.0 -3.0

四、java.util.Arrays

toString(): 用于输出数组的内容,输出格式[8, 1, 2, 3, 4, 5, 6, 7]

sort(): 排序

binarySearch: 二分查找(byte、char、double、float、int、long)

binarySearch(long[] a, int fromIndex, int toIndex, long key)

可以指定排序范围

返回索引值

copyOf(array,newlength): 用来给数组扩容,方法返回值为原扩容后的新数组

import java.util.Arrays;

public class Demo {

public static void main(String[] args) {

int[] arr = {8,1,2,3,4,5,6,7};

System.out.println(arr);

System.out.println(Arrays.toString(arr));

Arrays.sort(arr);

System.out.println(Arrays.toString(arr));

System.out.println(Arrays.binarySearch(arr,6));

System.out.println(arr.length);

arr = Arrays.copyOf(arr,15);

System.out.println(arr.length);

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

System.out.print(arr[i]+",");

}

}

}

五、java.math.BigDecimal

概念:

通过在控制台运行0.1+0.2,会发现float和double的运算误差,由于float类型和double类型在运算时可能会有误差,为了实现精确运算需要借助类加以描述

常用构造方法

public BigDecimal(String val){}

常用方法

package java_math_BigDecimal;

import java.math.BigDecimal;

/**

* 使用BigDecimal只需要new出来

*/

public class Demo {

public static void main(String[] args) {

System.out.println(0.1+0.2);

BigDecimal b1 = new BigDecimal("0.1");

BigDecimal b2 = new BigDecimal("0.2");

// 下述所有的运算方法,不会影响参与运算的数据本身,运算的结果会被封装为一个新的BigDecimal对象,这个对象会通过return返回出去。

// 1.public BigDecimal add(BigDecimal augend);加法运算。

// 2.public BigDecimal subtract(BigDecimal augend);减法运算

// 3.public BigDecimal multiply(BigDecimal augend);乘法运算。

// 4.public BigDecimal divide(BigDecimal augend);除法运算。

BigDecimal b3 = b1.add(b2);// 并不是将b2加到了b1上面,而是通过方法将结果返回了

int b4 = b3.intValue();

// BigDecimal的对象有很多value对象,可以通过这些方法转换值的类型

System.out.println(b1);

System.out.println(b2);

System.out.println(b3);

System.out.println(b4);

}

}

六、java.util.Date

Date类表示 特定的时刻,精度为毫秒。

大多数方法已过时,从JDK 1.1开始, Calendar类应该用于在日期和时间字段之间进行转换,而DateFormat类应该用于格式化和解析日期字符串。 不推荐使用Date中的相应方法。

long getTime() 返回自此Date对象表示的1970年1月1日东八区的早上八点以来的毫秒数。

Date() 分配 Date对象并对其进行初始化,使其表示分配时间,测量 Date到毫秒。 (表示此时此刻的时间)

package java_util_Date;

import java.util.Date;

public class Demo {

public static void main(String[] args) {

// 创建一个当前时间的Date

Date date = new Date();

// 通过源码可以知道,println打印的是toString

// date已经重写了toString方法

System.out.println(date.toString());

// 获取当前的毫秒数

System.out.println(date.getTime());

// 往前推24小时

long time = date.getTime()-(24*60*60*1000);

Date date1 = new Date(time);

System.out.println(date);

System.out.println(date1);

}

}

七、java.text.DateFormat

import java.text.ParseException;

import java.text.SimpleDateFormat;

import java.util.Date;

/**

* DateFormat这个类就是用来修改Date这个类输出的日期格式的

*/

public class Demo {

public static void main(String[] args) {

// DateFormat是一个抽象的类,没有办法直接使用,需要使用他的子类

/**

* y : 年

* M : 月

* d : 日

* H : 小时

* m : 分

* s : 秒

* 2020年12月12日 12:12 50

*/

// format方法:将Date转换为指定类型的字符串

SimpleDateFormat format0 = new SimpleDateFormat("yyyy年MM月dd日 HH:mm ss");

// 格式化为一个字符串

String text = format0.format(new Date());

System.out.println(text);

// parse:将一段日期字符串转换为Date对象

/* parse()无参,将特定的字符串转换成Date类

* 使用无参的parse()时,要解析的String表示一定是按照“年-月-日(一定有一个空格)上午 /下午小时:分钟”

* 如:2011-11-21 上午23:12 11-10-2 下午01:34

* 转换成的Date类也是系统的格式,可读性很差

* 如果在SimpleDateFormat()定义了格式,那么转换的字符串格式要和定义的相同

* */

Date date = new Date();

try {

date = format0.parse("2021-12-12 12:12 12");

} catch (ParseException e) {

// e.printStackTrace();

}

//

Date date3 = new Date();

long m = date3.getTime();

System.out.println(m);

// 计算活了多少年

Calendar calendar = Calendar.getInstance();

calendar.set(1998,5,8);

long time = calendar.getTimeInMillis();

System.out.println((m - time) / 1000 / 60 / 60 / 24 / 365);

Date date = null;

String s = "2012-01-29 上午12:03";

SimpleDateFormat sdf = new SimpleDateFormat();

try {

date = sdf.parse(s);

} catch (ParseException e) {

}

System.out.println("------系统默认无参数Date的parse------");

// 输出null

System.out.println(" " + date);

/*使用自定义格式SimpleDateFormat(String pattern)利用parse()将字符串转换成Date类

* Date类也是系统的格式,可读性很差*/

Date date1 = null;

String s1 = "2012-01-29-22-26-23";

String pattern = "yyyy-MM-dd-HH-mm-ss";

SimpleDateFormat sdf1 = new SimpleDateFormat(pattern);

try {

date1 = sdf1.parse(s1);

} catch (ParseException e) {

}

System.out.println("------自定义格式Date的parse------");

// 输出Sun Jan 29 22:26:23 CST 2012

System.out.println(" " + date1);

}

}

八、java.util.Calendar

import java.util.Calendar;

/**

* Calendar是一个抽象类,需要通过Calendar.getInstance()获取Calendar类的对象

* getTime:获取日历时间表示的Date对象

* getActualMaximum:获取某字段的最大值

* set()设置当前时间的年、月、日

* add():可以增加特定时间

* long getTimeInMillis():以毫秒为单位返回此Calendar的时间值

*/

public class Demo {

public static void main(String[] args) {

// 通过Calendar.getInstance()获取Calendar类的对象

Calendar c1 = Calendar.getInstance();

// 不知道什么原因,我这里需要清除一下当前时间的一些设置才能正确运行

c1.clear();

c1.set(Calendar.MONTH,1);

// 可以通过这种方式获取一月有多少天、一年有多少周等等

int m = c1.getActualMaximum(Calendar.DATE);

int n = c1.getActualMaximum(Calendar.DAY_OF_MONTH);

System.out.println(m);

System.out.println(n);

c1.set(Calendar.YEAR,2021);

c1.add(Calendar.YEAR,1);

int year = c1.get(Calendar.YEAR);

int day = c1.get(Calendar.DAY_OF_WEEK);

System.out.println(year);

System.out.println(day);

}

}

九、java.lang.System

package java_lang_System;

import java.util.Arrays;

/**

* arraycopy(Object src, int srcPos, Object dest, int destPos, int length)

* 将指定源数组中的数组从指定位置开始复制到目标数组的指定位置。

* 原数组 原数组起始位置 目标数组 目标数组起始位置 要赋值的长度

* currentTimeMillis() 以毫秒为单位返回当前时间。

* exit(int status) 终止当前运行的Java虚拟机。0:正常退出,其他:非正常退出

* gc() 运行垃圾收集器。

*/

public class Demo {

public static void main(String[] args) {

int[] array1 = {6,7,8,9,0};

int[] array2 = {1,2,3,4,5};

// 注意这不是动态扩容,需要注意,不要超出数组下标

System.arraycopy(array1,1,array2,0,3);

// 输出:[7, 8, 9, 4, 5]

System.out.println(Arrays.toString(array2));

// 输出:1609466880620

System.out.println(System.currentTimeMillis());

System.gc();

System.exit(0);

}

}

十、String

// 通过new产生的对象,不管内容是否相同,也是两个对象

// s1和s2因为内容相同,引用的是同一块内存地址

String s1 = "123123";

String s2 = "123123";

String s3 = new String("123123");

字符串常量池

方法区,又称永久代,常称为PermGen,位于非堆空间,又称非堆区

方法区是被所有线程共享。

所有字段和方法字节码以及一些特殊方法如构造方法,接口代码也在此定义。

简单说,所有定义的方法的信息都保存在该区域,此区属于共享区间

这些区域存储的是:静态变量+常量+类信息(构造方法/接口定义)+运行时常量池

但是,实例变量存在堆内存中,和方法区无关。

以上,只是逻辑的定义,在HotSpot中,方法区仅仅只是逻辑上的独立,实

际上还是包含在Java堆中,也就是说,方法区在物理上属于Java堆区中的

一部分,而永久区就是方法区的实现。

2.堆

一个JVM实例只存在一个堆内存中,堆内存的大小是可以调节的。类加载器

读取了类文件后,需要把类、方法、常变量放到堆内存中,保留所有引用

类型的真实信息,以方便执行器执行

堆 在逻辑上分为三部分

新生代,常称为YoungGen

老年代,常称为oldGen

永久代,常称为PermGen

2.1 新生区

位于堆空间,又分为Eder区和Survior(幸存区)

Eder:新创建的对象

Survior:经过垃圾回收,但是垃圾回收次数小于15次的对象

2.2 老年代

位于堆空间,垃圾回收次数大于15次,依然存活的对象

2.3 永久区

位于非堆空间

永久区是一个常驻内存区域,用于存放JDK自身所携带的Class,Interface的

元数组,也就是说它存储的是运行环境必须的类信息,被装载进此区域的

数据是不会被垃圾回收器回收掉的,关闭JVM才会释放此区域所占用的内存

charAt(int index):返回索引index处的字符

toCharArray():将字符串转换为新的字符数组

String substring(int beginIndex):返回从开始索引值下标到字符串结尾

String substring(int beginIndex,int endIndex):左闭右开,返回从开始到endIndex-1的子字符串

int lastIndexOf(int ch):ch是Unicode编码,返回指定字符串最后一次出现的字符串中的索引

public int lastIndexOf​(int ch, int fromIndex):返回指定字符最后一次出现的字符串中的索引,从指定的索引开始向后搜索。

public int lastIndexOf​(String str):返回指定子字符串最后一次出现的字符串中的索引。 最后一次出现空字符串“”被认为发生在索引值this.length() 。

public int lastIndexOf​(String str, int fromIndex):返回指定子字符串最后一次出现的字符串中的索引,从指定索引开始向后搜索。

转自:https://blog.csdn.net/qq_38679239/article/details/111991601?utm_medium=distribute.pc_category.none-task-blog-hot-9.nonecase&depth_1-utm_source=distribute.pc_category.none-task-blog-hot-9.nonecase

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值