本文主要是介绍d11(113-120)-勇敢开始Java,咖啡拯救人生,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
目录
枚举
抽象枚举
应用
泛型
自己定义泛型类
自己定义泛型接口
自己定义泛型方法
注意事项
常用API应用程序编程接口
克隆
objects类
包装类
StringBuilder
StringBuffer
StringJoiner
Math类
System
Runtime
BigDecimal
枚举
是一种特殊的类
修饰符 enum 枚举类名{
名称1,名称2..[枚举类对象的名字]
其他
}
枚举类地第一行只能写一些合法的标识符(名称),多个名称用逗号分开
这些名称,本质是常量,每个常量都会记住枚举类的一个对象
和interface一样,创建时要在class里选enum
枚举类的而构造器都是私有的,因此枚举类对外不能创造对象
枚举都是最终类,不可以被继承
枚举类中从第二行开始,可以定义类的其它各种成员
编译器为,枚举类新增了几个方法,并且枚举类都是继承 java.lang.Enum类的,从enum类也会继承到一些方法
抽象枚举
第一行构建对象时,要重写,
x(){
@Override
public void 方法名(){
}
};
枚举类中只有一个对象 -> 单例设计模式
应用
用来表示一组信息,然后作为参数进行传输
泛型
在定义类、接口、方法时,同时声明了一个或多个类型变量(如<E>),称为泛型类、泛型接口、泛型方法、统称为泛型。
比如ArrayList list = new ArrayList();
此时向ArrayList中可以添加任何类型内容
但ArrayList<String> list = new ArrayList<>();
此时就只能加入字符串
作用:泛型提供了在编译阶段约束所能操作的数据类型,并自动进行检查的能力,这样可以避免强制类型转换,及其可能出现的异常。
泛型的本质:把具体的数据类型作为参数传给类型变量。
[也可以限定数据类型 例如 E extends A,则此时传输的数据类型必须时A类本身或者继承了A类的类,再填String之类的是不行的]
自己定义泛型类
修饰符 class 类名<类型变量,类型变量...>{}
自己定义泛型接口
修饰符 interface 接口名<类型变量,类型变量...>{}
自己定义泛型方法
修饰符 <类型变量,类型变量...> 返回值类型 方法名(形参列表){}
?可以在使用泛型时,代表一切类型;ETKV时在定义泛型的时候使用
泛型上限:? extends A 能接受A及A的子类
泛型下限:? super A 能接受A及A的父类
注意事项
泛型时工作在编译阶段的,一旦程序编译成class文件,其中就不存在泛型了,这就是泛型擦除
泛型不支持基本数据类型,只能支持对象类型(引用数据类型
常用API应用程序编程接口
object类 所有类的祖宗啊
克隆
浅克隆
深克隆
objects类
equals 比object类的更安全哦
能处理null
包装类
把基本类型的数据包装成对象
基本数据类型(byte,short,int,long,char,float,double,boolean)不是对象
其他操作:
不太好记哦
xxx.valueOf(A) 用于转换比较好用,把A转换为xxx类型
StringBuilder
StringBuilder代表可变字符串对象,相当于是一个容器。它里面装的字符串是可以改变的,就是用来操作字符串的。
好处:StringBuilder比String更适合做字符串的修改操作,效率会更高,代码更简洁
对字符串频繁修改、拼接的话StringBuilder效果很高哦
StringBuffer
和StringBuilder差不多一样
但StringBuilder是线程不安全的,StringBuffer是线程安全的
StringJoiner
跟StringBuilder一样,操作字符串的,可以看作是容器,创建之后里面的内容可变
好处:能提高字符串的操作效率,并且在有些场景中使用,会更简洁
Math类
工具类,提供对数据进行操作的静态方法
System
代表程序所在的系统,是一个工具类
System.exit(0);
System.currentTimeMillis(); // 从1970-1-1 0:0:0 开始走到此刻的总的毫秒值
可用来总性能分析,程序开始前和结束时的毫秒值做差
Runtime
代表程序所在的运行环境,Runtime是一个单例类
BigDecimal
用于解决浮点型运算时,出现结果失真的问题
这篇关于d11(113-120)-勇敢开始Java,咖啡拯救人生的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!