一、引用thinkinjava
1、
2、BigInteger与BigDecimal都是不可变的(immutable)的,在进行每一步运算时,都会产生一个新的对象,由于创建对象会引起开销,因此它们不适合于大量的数学运算,应尽量使用long、float、double等基本类型做科学计算或者工程计算。设计BigInteger与BigDecimal的目的是用来精确地表示大整数和小数,常用于商业计算中
3、优先使用泛型方法;对于static的方法,是无法访问泛型类的类型参数的,所以static要使用泛型,必须是泛型方法;
有泛型的成员变量,就必须是泛型类;
泛型在运行时擦除成相同的类型,编译期是区分成不同的类型;即 List<String> 和 List<Integer>,运行时全部擦除成List<E>;
使用类型标签Class<T> t,解决 传递类型的类型判断和创建类型实例;
二、Java老A
1、== 是比较地址即引用,地址值不等同于hashcode值;
2、equals 默认Object实现就是==
3、hashcode 在对象的内存地址基础上经过特定算法返回一个hash码;提高元素插入比较的效率;
A.hashcode = B.hashcode 相等 是 A.equals(B)的必要条件;
4、关于这两个方法的重要规范:
规范1:若重写equals(Object obj)方法,有必要重写hashcode()方法,确保通过equals(Object obj)方法判断结果为true的两个对象具备相等的hashcode()返回值。说得简单点就是:“如果两个对象相同,那么他们的hashcode应该相等”。不过请注意:这个只是规范,如果你非要写一个类让equals(Object obj)返回true而hashcode()返回两个不相等的值,编译和运行都是不会报错的。不过这样违反了Java规范,程序也就埋下了BUG。
规范2:如果equals(Object obj)返回false,即两个对象“不相同”,并不要求对这两个对象调用hashcode()方法得到两个不相同的数。说的简单点就是:“如果两个对象不相同,他们的hashcode可能相同”。
5、总结
5.1、equals方法用于比较对象的内容是否相等(覆盖以后)
5.2、hashcode方法只有在集合中用到
5.3、当覆盖了equals方法时,比较对象是否相等将通过覆盖后的equals方法进行比较(判断对象的内容是否相等)。
5.4、将对象放入到集合中时,首先判断要放入对象的hashcode值与集合中的任意一个元素的hashcode值是否相等,如果不相等直接将该对象放入集合中。如果hashcode值相等,然后再通过equals方法判断要放入对象与集合中的任意一个对象是否相等,如果equals判断不相等,直接将该元素放入到集合中,否则不放入。
详见 https://www.cnblogs.com/kexianting/p/8508207.html
PECS原则:
List<? extends Dog> animals 方法内只能获取元素,不能新增和删除;
List<? super Dog> dogs 方法内只能新增和删除元素,不能获取元素,且方法内添加的元素是Dog的子类;传入 的实参类型的元素必须是Dog的父类或者是Dog;