0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Java常用时间类介绍

Android编程精选 来源:CSDN 作者:WenTaoTao 2022-08-22 10:24 次阅读

常用类概述

内部类

内部类的分类:

1.成员内部类(非静态内部类)

2.局部内部类

4.匿名内部类

Object类

Object类常用方法:

1.equals方法

2.hashCode方法

3.toString方法

4.finzlize方法

包装类

1.基本数据类型以及对应的包装类:

2.包装类的意义

3.包装类常用方法:

数学类

时间类

Java常用时间类:

1.Date 日期

2.Calendar 日历

3.SimpleDateFormat格式化时间

4.计算时间差

String类

字符串类常用方法

String Builder和StringBuffer

DecimalFormat

总结

常用类概述

内部类

Object类

包装类

数学类

时间类

字符串

String Builder和StringBuffer

DecimalFormat

内部类

「概念」 :在一个类内部再定义一个完整的类。

一般情况下类与类之间是相互独立的,内部类的意思就是打破这种独立思想,让一个类成为另一个类的内部信息,和成员变量、成员方法同等级别。

「内部类的好处:」

把一个类写在外面和写在里面最终达到的结果都一样,那我们为什么还要使用内部类,岂不是多此一举吗?

「采用内部类这种技术,可以隐藏细节和内部结构,封装性更好,让程序的结构更加合理!如果类很多且都暴露在外面,那么类与类之间的调用就会十分繁琐!」

内部类的分类:

1.成员内部类(非静态内部类)

参考代码如下:

packageNeiBuLei;
publicclassOuterClass{
//成员变量
privateStringOuterName;
//成员方法
publicvoiddisplay(){
System.out.println("这是外部类方法!");
System.out.println(OuterName);
}
//内部类
publicclassInnerClass{
//成员变量
privateStringInnerNme;
//构造方法
publicInnerClass(){
InnerNme="InnerClass";
}
//成员方法
publicvoiddisplay(){
System.out.println("这是内部类方法!");
System.out.println(InnerNme);
}
}
//主方法
publicstaticvoidmain(String[]args){
OuterClassouterClass=newOuterClass();
 outerClass.display();//这是外部类方法!null

//这个类是内部类,已经不是独立的类了,因此不能像外部类一样直接创建!
//InnerClassinnerClass=newInnerClass();行不通
OuterClass.InnerClassinnerClass=outerClass.newInnerClass();//同成员方法/变量只是加了个前缀
 innerClass.display();//这是内部类方法!
}
}

输出结果:

这是外部类方法!null 这是内部类方法!Inner Class

「总结:成员内部类(非静态内部类)的使用就是将内部类作为外部类的的一个成员变量/成员方法来使用,所以必须依赖于外部类的对象才能调用,用法和成员变量/成员方法一致!」

2.局部内部类

局部内部类:基本的内部类还可以在一个方法体中定义。

packageNeiBuLei;
publicclassOuterClass{
//成员变量
privateStringOuterName;
//成员方法
publicvoiddisplay(){
classInnerClass{
publicvoidprint(){
System.out.println("这是一个局部内部类方法!");
}
}
InnerClassinnerClass=newInnerClass();
innerClass.print();
}

//主方法
publicstaticvoidmain(String[]args){
OuterClassouterClass=newOuterClass();
outerClass.display();
}
}

静态内部类

静态内部类的构造不需要依赖于外部类对象,类中的静态组件都不需要依赖于任何对象,可以直接通过「类本身」 进行构造。

packageNeiBuLei;
publicclassOuterClass{
//成员变量
privateStringOuterName;
//成员方法
publicvoiddisplay(){
System.out.println("这是外部类方法!");
System.out.println(OuterName);
}
//静态内部类
publicstaticclassInnerClass{
privateStringInnerName;
publicInnerClass(){
InnerName="InnerClass";
}

//成员方法
publicvoiddisplay(){
System.out.println("这是静态内部类方法!");
System.out.println(InnerName);
}
}

//主方法
publicstaticvoidmain(String[]args){
OuterClassouterClass=newOuterClass();
outerClass.display();
//静态内部类的构造不依赖与外部类,可以直接通过类本身进行构造!
InnerClassinnerClass=newInnerClass();
innerClass.display();
}
}

输出结果:

这是外部类方法!null 这是静态内部类方法!Inner Class

4.匿名内部类

匿名内部类:没有名字的内部类。

匿名内部类「主要应用与接口的实现!」

接口:

packageNeiBuLei;
publicinterfaceMyInterface{
publicvoidtest();
}

实现类:

packageNeiBuLei;
publicclassMyImplementimplementsMyInterface{
@Override
publicvoidtest(){
System.out.println("test");
}
}

匿名内部类的使用:

packageNeiBuLei;
publicclassMyImplementimplementsMyInterface{
@Override
publicvoidtest(){
System.out.println("test");
}
}

「匿名内部类的好处:」

我们定义接口之后,「它的实现类不需要去单独创建一个文件去写它的实现」 ,我们可以把这个实现类的操作写到我们调用的地方就可以了!写起来更加简洁、方便。

「匿名内部类的缺点:」

耦合度太高了!

Object类

a6e0d9ce-20d9-11ed-ba43-dac502259ad0.png

匿名内部类的缺点

Object类常用方法:

1.equals方法

==与equals的对比【面试题】+ jdk查看原码」

==是一个比较运算符

==:既可以判断基本类型,又可以判断引用类型

==:如果判断的是「基本类型」「判断的是值是否相等」

//==:如果判断的是基本类型,判断的是值是否相等
intx1=10;
intx2=10;
doublex3=10.0;
System.out.println(x1==x2);//true
System.out.println(x1==x3);//true

==:如果判断的是「引用类型」「判断的是地址是否相等,即判断是不是同一个对象」

packageEquals;
publicclassTest01{
publicstaticvoidmain(String[]args){
//==:如果判断的是引用类型,判断的是地址是否相等,即判断是不是同一个对象
Aa=newA();
Ab=a;
Ac=b;
System.out.println(a==c);//?true
System.out.println(b==c);//true
Bobj=a;
System.out.println(obj==c);//true
}
}

classB{}
classAextendsB{}
a6fff37c-20d9-11ed-ba43-dac502259ad0.png

equals方法是Object类中的方法,「只能判断引用类型」

idea查看Jdk原码:鼠标光标放在要查看的方法上,直接输入ctrl + b

查看某个类所有方法:ctrl + F12

默认判断的是地址是否相等,「子类(Object类是所有类的父类)往往重写该方法,用于判断内容是否相等」

/*
Object类equals()方法原码

//默认判断地址是否一样
publicbooleanequals(Objectobj){
return(this==obj);
}

子类往往重写该方法,用于判断内容是否相等String类中的equals()方法原码(重写了父类equals()方法)

publicbooleanequals(ObjectanObject){
if(this==anObject){//如果是同一个对象(地址相同)
returntrue;//返回true
}
if(anObjectinstanceofString){//判断类型
StringanotherString=(String)anObject;//向下转型
intn=value.length;
if(n==anotherString.value.length){//如果长度相同
charv1[]=value;
charv2[]=anotherString.value;
inti=0;
while(n--!=0){//比较每一个字符
if(v1[i]!=v2[i])
returnfalse;
i++;
}
returntrue;//如果两个字符串每一个字符都相同,则返回true
}
}
returnfalse;
}
*/

在看个例子

a713968e-20d9-11ed-ba43-dac502259ad0.png

【小练习】

写出输出结果:

packageEquals;
publicclassEqualsTest01{
publicstaticvoidmain(String[]args){
Personp1=newPerson();
p1.name="tom";
Personp2=newPerson();
p2.name="tom";
System.out.println(p1==p2);//引用类型——判断是否为同一个对象(地址)
System.out.println(p1.name.equals(p2.name));//p.name是String类型,重写了equals()方法——判断内容是否一样
System.out.println(p1.equals(p2));//p1,p2属于Person类,该类并没有重写equals()方法(继承父类equals()方法,即判断地址)

Strings1=newString("abc");
Strings2=newString("abc");

System.out.println(s1.equals(s2));
System.out.println(s1==s2);
}
}

classPerson{
publicStringname;
}

输出结果:

false true false true false

2.hashCode方法

a7287bb2-20d9-11ed-ba43-dac502259ad0.png

小结:(可以当作地址来看但它本质上不是地址)

提高具有哈希结构的容器的效率

两个引用,如果指向的是同一个对象,则哈希值肯定一样

两个引用,如果指向的是不同对象,则哈希值是不一样的

哈希值主要根据地址号来!不能将哈希值完全等价于地址

在后面的集合中hashCode如果需要的话,也会重写

packagehashCode;
publicclassHashCode{
publicstaticvoidmain(String[]args){
AAaa=newAA();
AAaa2=newAA();
AAaa3=aa;
System.out.println("aa.hashCode()="+aa.hashCode());
System.out.println("aa2.hashCode()="+aa2.hashCode());
System.out.println("aa3.hashCode()="+aa3.hashCode());
}
}

classAA{}

输出结果:

aa.hashCode()=460141958 aa2.hashCode()=1163157884 aa3.hashCode()=460141958

3.toString方法

a73a7b1e-20d9-11ed-ba43-dac502259ad0.png

toString方法

基本介绍:

默认返回:全类名 + @ + 哈希值的十六进制

/*
ObjecttoString()原码
//(1)getClass().getName()类的全类名(包名+类名)
//(2)Integer.toHexString(hashCode())将hashCode的值转成16进制字符串
publicStringtoString(){
returngetClass().getName()+"@"+Integer.toHexString(hashCode());
}
*/
a74d72fa-20d9-11ed-ba43-dac502259ad0.png 图片

「子类往往重写toString方法,用于返回对象的属性信息(快捷键:alt + insert),当然我们也可以自己定制。」

a760b2ac-20d9-11ed-ba43-dac502259ad0.png 图片

当我们输出一个对象时,toString()方法会被默认调用

a7760c56-20d9-11ed-ba43-dac502259ad0.png 图片

4.finzlize方法

a78b6344-20d9-11ed-ba43-dac502259ad0.png

finzlize方法:当垃圾收集确定不再有对该对象的引用时,垃圾收集器在对象上调用该对象。

当对象被回收时,系统自动调用该对象的finzlize方法。子类可以重写该方法,做一些释放资源的操作

什么时候被回收:当某个对象没有任何引用时,则jvm就认为这个对象是一个垃圾对象,就会时候垃圾回收机制来销毁该对象,在销毁该对象前,会先调用finzlize方法。

a7a08df0-20d9-11ed-ba43-dac502259ad0.png

垃圾回收机制的调用,是由系统来决定(即有自己的GC算法),也可以通过System.gc()主动触发垃圾回收机制。

注:在实际开发中,几乎不会用finzlize方法,更多的是为了应付面试

包装类

「1.基本数据类型以及对应的包装类:」

byte->Byte
short->Short
int->Integer
long->Long
float->Float
double->Double
char->Character
boolean->Boolean

这些类都在java.lang包

「2.包装类的意义:」

让基本数据类型有面向对象的特征

「封装了字符串转化成基本数据类型的方法(重点)」

3.包装类常用方法:

Integer.parseInt()

Long.paseLong()

Double.parseDouble()

【参考代码】

publicclassTest{
publicstaticvoidmain(String[]args){

//Integeri=newInteger(10);//创建包装类对象
//Integerii=10;//自动打包
//System.out.println(i+10);//在使用上,int和Integer其实没有区别,可以互相使用
//System.out.println(ii+10);
//intj=ii;//自动解包
//System.out.println(j+100);

Stringa="12";
Stringb="34";
System.out.println(a+b);//1234
//转型:
//字符串转成int的唯一方案
intc=Integer.parseInt(a);
intd=Integer.parseInt(b);
System.out.println(c+d);//46

//字符串转成double类型
Stringe="1.25";
doublef=Double.parseDouble(e);
System.out.println(f*6);//7.5

//转成long类型
longl=Long.parseLong("1234567");
System.out.println(l);
}
}

数学类

数学类的方法都是静态方法,可以直接引用——Math.方法();

「常用数学类方法:」

abs():获取绝对值

max():求最大值

min():求最小值

pow():求次幂

round():四舍五入

sqrt():求平方根

时间类

Java常用时间类:

Date 日期类

Calendar 日历类

SimpleDateFormat 格式化时间类

Date和Calendar类 在java.util包中, SimpleDateFormat类 在java.text包

1.Date 日期

【1】new Date() 可以获取到系统时间

【2】getTime() 能获取到时间的long形式,可以用来计算时间差

getTime()——获取计算机底层存储的数字,返回一个数字用来表示时间,这个数字的类型long,单位为毫秒。

【参考代码】

importjava.util.Date;
publicclassTest{
publicstaticvoidmain(String[]args){
Dated=newDate();
System.out.println(d);//系统时间
//get...()——获取年月日.....
System.out.println(d.getYear()+1900);//从1900年开始算的
System.out.println(d.getMonth()+1);//月份从0开始计算
System.out.println(d.getDate());//天数
System.out.println(d.getHours());//小时

//getTime()——获取到时间的毫秒形式返回的是long
System.out.println(d.getTime());
}
}

2.Calendar 日历

【1】get() 获取到时间的某一部分

【2】set() 设置时间 - -> 计算时间:系统已经帮我们设置好了,不用担心二月有多少天等问题,计算时间十分方便

注:Calendar 日历类是抽象类,因此不可以去new对象。虽然抽象类不能创建对象,但是jdk官方提供了一个实例对象的操作:

Calendar rightNow = Calendar.getInstance();

我们通过这条代码就是直接造了一个Calender的对象

【参考代码】:get() 获取到时间的某一部分:

packagedate;
importjava.util.Calendar;
publicclassTestCalendar{
publicstaticvoidmain(String[]args){
Calendarcal=Calendar.getInstance();
//System.out.println(cal);

/*
假设当天:
2021
8
10
*/
cal.set(Calendar.DATE,cal.get(Calendar.DATE)+31);//计算时间(这里用天数计算的)

//获取Calendar创建的对象里的所有内容
System.out.println(cal.get(Calendar.YEAR));//2021年
 System.out.println(cal.get(Calendar.MONTH)+1);//月份:从0开始的结果:为10月
System.out.println(cal.get(Calendar.DATE));//日
System.out.println(cal.get(Calendar.HOUR_OF_DAY));//小时
System.out.println(cal.get(Calendar.MINUTE));
System.out.println(cal.get(Calendar.SECOND));
}
}

【参考代码】:set() 设置时间 - -> 计算时间:

注:cal.setTime(d); 把Date转化成Calendar

packagedate;
importjava.util.Calendar;
importjava.util.Date;
publicclassTestCalendar{
publicstaticvoidmain(String[]args){
Dated=newDate();
Calendarcal=Calendar.getInstance();
cal.setTime(d);//把Date转化成Calendar
System.out.println(cal);
System.out.println(cal.get(Calendar.YEAR));//年
 System.out.println(cal.get(Calendar.MONTH)+1);//月份:从0开始的
System.out.println(cal.get(Calendar.DATE));//日
}
}

3.SimpleDateFormat格式化时间

Date,Calendar通过引用也可以进行时间的格式化,但比较繁琐,而SimpleDateFormat类是专门帮我们格式化时间的工具类,它在java.text包中。

【时间格式】:yyyy-MM-dd HHss

SimpleDateFormat类有两大常用方法:

【1】format(Date):

format(Date) 帮我们把时间转成字符串,字符串的格式为SimpleDateFormat类定义对象时设置的时间格式

【参考代码】

packageSimple;
importjava.text.SimpleDateFormat;
importjava.util.Date;
importjava.util.logging.SimpleFormatter;
publicclassTest{
publicstaticvoidmain(String[]args){
Dated=newDate();
System.out.println(d);//ThuAug120808CST2021不美观

//设置格式化时间的模式,我们常用yyyy-MM-ddHHss这个模式
SimpleDateFormatsdf=newSimpleDateFormat("yyyy-MM-ddHHss");//时间格式
Strings=sdf.format(d);//格式化时间
System.out.println(s);//2021-08-120809
}
}

【2】parse(String):

parse(String) 帮我们把字符串转化成时间

【参考代码】

packageSimple;
importjava.text.ParseException;
importjava.text.SimpleDateFormat;
importjava.util.Date;
importjava.util.Scanner;

publicclassTest2{
publicstaticvoidmain(String[]args)throwsParseException{
Scannersc=newScanner(System.in);
System.out.println("请输入一个时间(yyyy-MM-dd HHss):");
Strings=sc.nextLine();
SimpleDateFormatsdf=newSimpleDateFormat("yyyy-MM-ddHHss");
Dated=sdf.parse(s);//把字符串转成时间
System.out.println(d);
/*
请输入一个时间(yyyy-MM-dd HHss):
2021-08-121221
ThuAug121221CST2021
*/
}
}

注:由于用户输入的字符串不一定是我们要求的格式,可能是任何东西,想把它们转成时间是不可能的,你不可能把一个人转成时间 对吧,因此存在着很大的风险未处理(异常: java.text.ParseException),为此我们需要处理异常。

4.计算时间差

计算思路:

格式化时间

先将字符串转化成long类型时间

计算毫秒级别时间差,取绝对值

毫秒级别时间差转成秒级别

秒级别时间差转成分钟级别

分钟级别时间差转化显示成xx小时xx分钟

【参考代码】

packageSimple;
importjava.text.ParseException;
importjava.text.SimpleDateFormat;
importjava.util.Date;
publicclassTestDiff{
publicstaticvoidmain(String[]args)throwsParseException{
Strings1="2021-08-121200";//开始时间
Strings2="2021-08-121400";//结束时间
//格式化时间
SimpleDateFormatsdf=newSimpleDateFormat("YYYY-MM-ddHHss");
//将字符串转成时间形式
Dated1=sdf.parse(s1);
Dated2=sdf.parse(s2);

//计算时间差:先要获取时间毫秒形式(long类型)再做差
longlong1=d1.getTime();
longlong2=d2.getTime();
longdiffTime=Math.abs(long1-long2);

//秒级别时间差
longdiffSec=diffTime/1000;

//分级别时间差
longdiffMin=diffSec/60;

//显示xx小时xx分钟
longdisplayHours=diffMin/60;//小时
longdisplayMin=diffMin%60;//分钟
System.out.println("您学习的时长为:"+displayHours+"小时"+displayMin+"分钟");
}
}

String类

字符串类常用方法

「方法汇总:」

a7bb9f8c-20d9-11ed-ba43-dac502259ad0.png

「注:字符串是一个不可变的类型(final类),几乎所有的字符串操作都会返回一个新字符串而不是在原有基础上进行修改。」

【示例代码】

publicclassTest{
publicstaticvoidmain(String[]args){
Strings="我的名字叫李华";
s.concat("hhh");//在字符串s上拼接,拼接hhh
System.out.println(s);//我的名字叫李华
//字符串是不可变的数据类型
//几乎所有的字符串操作都会返回一个新字符串
Strings1=s.concat("hhh");//在字符串s上拼接,拼接hhh
System.out.println(s1);//我的名字叫李华hhh

Stringstr1="李华喜欢看罗老师的视频";
str1.replace("李华","张三");
System.out.println(str3);//李华喜欢看罗老师的视频并没有替换字符串是不变的str1还是str1

Stringstr2=str1.replace("李华","张三");//几乎所有的字符串操作都会返回一个新字符串新串要用新变量接
System.out.println(str2);//张三喜欢看罗老师的视频
}
}
packageString;
importjava.util.Scanner;
publicclassTest{
publicstaticvoidmain(String[]args){
Strings="我的名字叫李华";
System.out.println(s.charAt(0));//获取第0个位置的字符
s.concat("hhh");
System.out.println(s);//我的名字叫李华
//字符串是不可变的数据类型
//几乎所有的字符串操作都会返回一个新字符串
Strings1=s.concat("hhh");//在字符串s上拼接,拼接hhh
System.out.println(s1);//我的名字叫李华hhh
System.out.println(s.contains("李华"));//true
System.out.println(s.contains("牛津"));//false
System.out.println("邀请李华来参加英语沙龙活动".endsWith("活动"));//true判断是否以xxx为结尾
System.out.println("邀请李华来参加英语沙龙活动".startsWith("李华"));//false判断是否以xxx开头

//equals字符串内容是否相同

//接受邀请参加活动的李华到现场后要输入验证码
//StringyanZhengMa="AAkm";
//
//Scannersc=newScanner(System.in);
//
//System.out.println("请输入验证码("+yanZhengMa+")");
//
//StringuserInput=sc.nextLine();
//
//if(yanZhengMa.equalsIgnoreCase("aakm")){//忽略大小写判断两边的内容是否一样
//System.out.println("欢迎参加英语沙龙活动!");
//}else{
//System.out.println("您未受到邀请,请现场报名!");
//}

//Stringstr="李华玩得很开心!";
//System.out.println(str.indexOf("开心"));//5计算给出字符串第一个出现的位置

Stringstr2="李华成绩很好";
System.out.println(str2.length());//6计算字符串的长度

Stringstr3="李华喜欢看罗老师的视频";
str3.replace("李华","张三");
System.out.println(str3);//李华喜欢看罗老师的视频并没有替换字符串是不变的str3还是str3

Stringstr4=str3.replace("李华","张三");//几乎所有的字符串操作都会返回一个新字符串新串要用新变量接
System.out.println(str4);//张三喜欢看罗老师的视频
Stringstr5="哈哈_呵呵_嘻嘻_噢no";
String[]ss=str5.split("_");//切割
System.out.println(ss[0]);//哈哈
System.out.println(ss[1]);//哈哈
System.out.println(ss[2]);//嘻嘻
System.out.println(ss[3]);//噢no

Stringstr6="今天天气不错";
System.out.println(str6.substring(2,4));//天气字符串截取[)左闭右开,右边取不到

Stringstr7="哈哈";
System.out.println(str7.trim());//去掉左右两边的空格
inti=10;
System.out.println(String.valueOf(i));//基本数据类型转为字符串
System.out.println(i+"");//野路子
}
}

String Builder和StringBuffer

「String类的缺点:」

String 是一个不可变的数据类型,每每拼接都会产生一个新的字符串,那么内存迟早会被这些拼接的字符串塞满。

「String类和StringBuilder和StringBuffer类的区别:」

StringBuilder和StringBuffer:「可变的字符串,不产生新对象,比较省内存」 ,当进行大量的字符串拼接时建议使用StringBuffer和StringBuilder,但它们两个一些方法的实现几乎跟String一样。

「StringBuffer和StringBuilder类:」

【相似点】

两者用法一模一样,可以认为是一个类

【区别】

StringBuffer线程安全,StringBuilder非线程安全。

StringBuilder相比于StringBuffer有速度优势,「多数情况下建议使用StringBuilder类,但当被要求线程安全时必须使用StringBuilder类」

字符串拼接方法:append()方法

StringBuffer和StringBuilder 转成String类 :

StringBuilder sb = new StringBuilder("猫喜欢吃鱼"); String s = sb.toString();

【参考代码】

packageString;
publicclassTestStringBuilder{
publicstaticvoidmain(String[]args){
StringBuildersb=newStringBuilder();//一个空的字符串""
StringBuildersb2=newStringBuilder("猫喜欢吃鱼");
System.out.println(sb2);//猫喜欢吃鱼

sb2.append(",狗也喜欢吃鱼");
System.out.println(sb2);//追加猫喜欢吃鱼,狗也喜欢吃鱼

sb2.insert(1,"哈哈哈");
System.out.println(sb2);//猫哈哈哈喜欢吃鱼,狗也喜欢吃鱼

//上述的操作huan'c
//把StringBuilder转化成String
Strings=sb2.toString();
System.out.println(s);//猫哈哈哈喜欢吃鱼,狗也喜欢吃鱼
//上述操作都可以将StringBuilder换成StringBuffer,结果一样
}
}

DecimalFormat

DecimalFormat:对小数进行格式化,保留几位小数。与格式化时间联想记。

. 表示小数点

0和# 表示数位,保留几位就几个0或者#

【参考代码】

importjava.text.DecimalFormat;
importjava.util.Scanner;
publicclassTest{
publicstaticvoidmain(String[]args){
doubled=10/3.0;
System.out.println(d);//3.3333333333333335

//.表示小数点
//0和#表示数字

//保留两位小数格式
DecimalFormatdf=newDecimalFormat(".00");//或者.##
Strings=df.format(d);//把d转成上面设置的格式
System.out.println(s);//3.33
}
}



审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 接口
    +关注

    关注

    33

    文章

    8620

    浏览量

    151320
  • JAVA
    +关注

    关注

    19

    文章

    2970

    浏览量

    104830
  • 字符串
    +关注

    关注

    1

    文章

    579

    浏览量

    20546

原文标题:Java常用类:7000+字一次性帮你总结好啦!

文章出处:【微信号:AndroidPush,微信公众号:Android编程精选】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    SSM框架在Java开发中的应用 如何使用SSM进行web开发

    SSM框架,即Spring、SpringMVC和MyBatis的整合,是Java Web开发中常用的技术栈。它通过分层架构,实现了视图、控制、业务逻辑和数据访问的分离,提高了代码的可维护性和可扩展性
    的头像 发表于 12-16 17:28 508次阅读

    Java 23功能介绍

    功能。 跟上 Java 新版本的发布节奏可能很难,这意味着要解决一连串的问题——更改是什么、为什么要更改以及如何使用全新和更新的功能。 在这篇博文中,我将介绍 Java 23 的一些全新和更新
    的头像 发表于 12-04 10:02 242次阅读
    <b class='flag-5'>Java</b> 23功能<b class='flag-5'>介绍</b>

    Java集合API的改进介绍

    简介 本文我们将探讨不同 jdk 版本中各类的起源,以及新引入的和接口背后的目的。我们将分析之前版本存在的问题,以及为何需要引入新的或接口。此外,我们还将介绍集合和接口中的新特性
    的头像 发表于 11-22 11:12 215次阅读
    <b class='flag-5'>Java</b>集合API的改进<b class='flag-5'>介绍</b>

    Java 枚举与策略模式、函数式接口的结合:实现高内聚低耦合的设计

    作者:京东物流 杨唯一 一、Java 枚举 Java 枚举是一个特殊的,一般表示一组常量,比如一年的 4 个季节,一年的 12 个月份,一个星期的 7 天,方向有东南西北等。 我们
    的头像 发表于 11-21 14:06 230次阅读

    Java时间戳的使用

    Java时间戳的使用
    的头像 发表于 11-06 16:04 226次阅读
    <b class='flag-5'>Java</b>中<b class='flag-5'>时间</b>戳的使用

    常用的D功放多少瓦的功率才需要接散热器?

    我们常用的D功放多少瓦的功率才需要接散热器?
    发表于 11-01 06:45

    介绍一款Java开发的开源MES系统

    介绍一款Java开发的开源MES系统,万界星空科技开源的MES系统。该系统基于Java开发,具有广泛的适用性和高度的可定制性,能够满足不同行业、不同规模企业的智能制造需求。
    的头像 发表于 09-05 17:39 676次阅读
    ​<b class='flag-5'>介绍</b>一款<b class='flag-5'>Java</b>开发的开源MES系统

    java子类可以继承父的什么

    Java是一种面向对象的编程语言,它支持继承的概念。继承是面向对象编程的三大特性之一,它允许一个(称为子类或派生)继承另一个(称为父
    的头像 发表于 08-20 11:02 1281次阅读

    shell基本介绍常用命令之shell介绍

    是“$”,在命令提示符后边输入命令即可和系统进行交互操作。Ubuntu默认的Shell是Bash(Bourne Again Shell)。Linux命令有很多,功能比较强大,下节我们简单介绍一些常用
    发表于 08-15 09:28

    华纳云:java web和java有什么区别java web和java有什么区别

    Java Web和Java是两个不同的概念,它们在功能、用途和实现方式上存在一些区别,下面将详细介绍它们之间的区别。 1. 功能和用途: – Java是一种编程语言,它提供了一种用于开
    的头像 发表于 07-16 13:35 828次阅读
    华纳云:<b class='flag-5'>java</b> web和<b class='flag-5'>java</b>有什么区别<b class='flag-5'>java</b> web和<b class='flag-5'>java</b>有什么区别

    java实现多线程的几种方式

    了多种实现多线程的方式,本文将详细介绍以下几种方式: 1.继承Thread 2.实现Runnable接口 3.Callable和Future 4.线程池 5.Java 8中
    的头像 发表于 03-14 16:55 726次阅读

    常用封装尺寸资料介绍

    电子发烧友网站提供《常用封装尺寸资料介绍.zip》资料免费下载
    发表于 02-29 09:23 0次下载

    苹果“屏幕使用时间”相关设置失效问题仍未解决

    尽管iOS平台的屏幕使用时间限制机制和家长监控功能颇有效果,但却常常无法正常发挥作用。特别地,相关设置很容易自动关闭,使得直到数小时乃至数日内使用者方能觉察出其实效已失效。
    的头像 发表于 02-02 10:52 1408次阅读

    Oracle 2024年Java发展蓝图分析

    Oracle 的 Java 开发者布道师 Nicolai Parlog 于近日发布一段视频,介绍了 2024 年的 Java 工作规划。
    的头像 发表于 01-26 14:27 1351次阅读

    介绍一款基于java的渗透测试神器-CobaltStrike

    Cobalt Strike是一款基于java的渗透测试神器,常被业界人称为CS神器。
    的头像 发表于 01-16 09:16 1008次阅读
    <b class='flag-5'>介绍</b>一款基于<b class='flag-5'>java</b>的渗透测试神器-CobaltStrike