类,超类和子类
- super和this看似有相似的概念, 但实际没有可比性,this持有对象本身的引用, 可以赋值给另一个变量,super则不具备这样的功能, 它只是一个指示编译器调用超类方法的关键字
- 调用super()构造器的语句必须是子类构造器的第一条语句
Object: 所有类的超类
- 判断两个对象是否相等可以使用Objects.equals()静态方法, a.equals(b)的方式如果a=null时会报异常
equals()方法的最佳实践:
1. 参数命名为otherObject
2. 检测this和otherObject是否引用同一对象, if(this==otherObject) return true;
3. 检测otherObject是否为null,为null则返回false,if(otherObject==null) return false;
4. 比较this和otherObject是否为同一个类,如果equals()的语义在每个子类中有改变, 就使用getClass()检测, if(this.getClass()!=otherObject.getClass()) return false; 如果所有子类都有统一的语义, 就使用instanceOf检测
5. 将otherObject转化为相应的类类型变量,ClassName other = (ClassName)otherObject
6. 对所有的域进行比较,==比较基本类型,equals比较对象,所有均匹配返回true, 如果子类重新定义了equals(),就要在其中包含调用super.equals(other).- 如果不想让子类重新实现equals()方法, 就将其定义为final, 并在其中实现对象的相等比较逻辑
- Objects.hashCode()方法可以进行参数安全检查,如果参数时null该方法返回0,否则对参数调用hashCode()方法
- 使用静态的Double.hashCode()来避免创建Double对象,其他包装类也可以这样使用
- Objects.hashCode()提供了多参数方法,所以可以将多个值传入计算组合的hashcode.
Arrays.toString()可以打印数组,Arrays.deepToString()可以打印多维数组
泛型数组列表
- 可以使用@SuppressWarnings("unchecked")标注来标记变量能够接受类型转换
对象包装器和自动装箱
- Java可以对包装类进行自动装箱和拆箱, 这就导致包装类的行为有点像基本类型,但对于==比较来说不成立,应该使用equals()方法
- 另外,装箱对象可能为null,null做运算会抛出异常(NullPointerException)
- 装箱拆箱时编译器的行为,而不是虚拟机,生成class字节码时由编译器插入必要的方法.
- 包装类时不可变的,也就是作为参数传递的包装类变量不会在方法内改变
参数数量可变的方法
- 允许将数组传递给可变参数方法的最后一个参数
枚举类
- 枚举类比较使用==即可
反射
- 不建议使用反射,因为反射的大多实现都需要进行类型转换,使用直接调用或者lamda更好;另外反射比较脆弱,容易出问题,且出了问题不好查找