泛型:
泛型是JDK1.5以后才有的, 可以在编译时期进行类型检查,且可以避免频繁类型转化!
泛型擦除
泛型只在编译时期有效,编译后的字节码文件中不存在有泛型信息!
List<String> list1 = new ArrayList<String>(); //创建泛型
List<Integer> list2 = new ArrayList<Integer>();
Class c1 = list1.getClass(); //获取泛型的类型
Class c2 = list2.getClass();
System.out.println(c1 == c2); //输出true
在运行时是没有泛型的说法的,所以List<String>.class 和List<Integer>.class 其实都是List.class
1. 语法糖的东西,经过编译之后会被还原成原始的,帮助开发者写出正确的代码。
2. 虚拟机的向下兼容问题
泛型方法/泛型类/泛型接口
作用:设计公用的类、方法,对公用的业务实现进行抽取!使程序更灵活!
泛型类:不用像泛型方法那样每个方法都要声明。
泛型接口:
public interface IBaseDao<T> {
void save(T t );
void update(T t );
}
泛型接口类型确定: 实现泛型接口的类也是抽象,那么类型在具体的实现中确定或创建泛型类的时候确定
public abstract class BaseDao<T> implements IBaseDao<T> {
}
泛型接口类型确定: 在业务实现类中直接确定接口的类型
public class PersonDao implements IBaseDao<Person> {
}
泛型关键字
泛型中:
? 指定只是接收值
extends 元素的类型必须继承自指定的类
super 元素的类型必须是指定的类的父类
注解:
注解与注释,
注解,告诉编译器如何运行程序!
注释, 给程序员阅读,对编译、运行没有影响;
注解作用
1. 告诉编译器如何运行程序;
2. 简化(取代)配置文件
自定义注解
通过自定义注解,可以给类、字段、方法上添加描述信息!
元注解
元注解,表示注解的注解!
1.指定注解的可用范围:
@Target({
TYPE, 类
FIELD, 字段
METHOD, 方法
PARAMETER, 参数
CONSTRUCTOR, 构造器
LOCAL_VARIABLE 局部变量
})
2. 指定注解的生命周期
@Retention(RetentionPolicy.SOURCE) 注解只在源码级别有效
@Retention(RetentionPolicy.CLASS) 注解在字节码即别有效 默认值
@Retention(RetentionPolicy.RUNTIME) 注解在运行时期有效