枚举类:当确定一个类有几个对象时使用枚举
使用enum关键字创建枚举类
valueof,根据枚举类对象的名称,获得对应枚举类对象
values,获取当前枚举类中所有枚举对象组成的数组
包装类:
装箱:将基本数据类型转换成对应的包装类
1.使用对应包装类的构造器
2.使用对应包装类的静态方法valueof()
拆箱:将包装类转换为对应的基本数据类型
*使用对应包装类提供的xxxValue()方法。xxx:代表对应的基本数据类型
注意:jdk1.5后提供了自动拆装箱
*包装类的缓存:Integer为我们提供了一个小的缓存,用于提高效率,该缓存取值在-128到127之间,若需要装箱的值在该取值范围中,则从缓存中取一个实例,若超出该范围,则需要重新new一个integer实例。(除了float和double都有缓存)
基本数据类型,包装类转string
1. string str=a +"";
2.使用对应包装类的静态方法tostring()
3.使用string类的静态方法valueof()
string转基本数据类型,包装类
1.使用对应包装类的构造器
2.使用对应包装类的静态方法parseXxx()
Xxx表示基本数据类型
3.使用对应包装类的静态方法valueof()
java .lang. String 类:不可变的字符序列
string的底层就是final修饰的字符数组
String str1="abc";
String str2=new String("abc");
二者的区别:
str1:代表一个对象,在方法区的字符串池中开辟一个对象的内存空间
str2:代表在堆内存中开辟了一个字符串,在方法区的字符串池中也开辟了一个字符串
*jdk1.7开始字符串常量池被挪到了堆中
stringbuffer和stringbuilder:可变的字符序列
stringbuffer:是线程安全的,因此效率低
stringbuilder:是线程不安全的,因此效率高
*java.util.Date 类:表示一个特定的时间,精确到毫秒
*date打印的时间日期格式不是我们常用的格式,需要格式化。
*java.text.DateFormat类,用于格式化时间日期,但是是一个抽象类,需要使用他的子类java.text.simpleDateFormat
例:Date date=new Date();
simpleDateFormat sdf=new simpleDateFormat("yyyy年MM月dd日 HH:mm:ss E");
string strDate=sdf.format(date);
System.out.println(strDate);
*jdk1.8提供的格式化日期时间:
DateTimeFormatter dtf=DateTimeFormatter.ofpattern("yyyy年MM月dd日 HH:mm:ss S E");
LocalDateTime ldt=LocalDateTime.now();//获取当前时间
泛型:在java中以<>形式呈现,<>中写引用数据类型,用于限制数据类型
*若集合中不使用泛型,意味着集合中可以添加任意类型的对象,若要具体到某个类型时,需要强制类型转换。可能引发异常。
*编译时不确定的类型用泛型<T>T,不确定的对象用反射。Clasa<T> clazz
return clazz.newInstance();
反射机制:被视为动态语言的关键,可以在运行时创建任意类的对象,操作任意对象的属性,调用任意对象的方法。
栈内存中存对象的引用,也就是局部变量
堆内存中存实例的对象,也就是new出来的
方法区中存class字节码文件
编译后字节码文件会加载到方法区,当一个类加载都方法区后,会有:
this_class, super_class , interface //描述类的层级结构
field_into属性表 ,method_info方法表
constructor,classes内部类,annotation注解
//描述类里面的成员
*java的jvm会自动为每个类,new一个Class实例,并且是单例的。然后获取构造器,重新new一个实例,这就是反射
*获取jvm创建的Class实例的4种方式:(背下来)