本文是根据JAVA解惑这本书,做的笔记。
电子书见:http://download.csdn.net/detail/u010378705/7527721
谜题56
BigInteger、BigDecimal以及包装类型的实例是不可改变。
BigInteger five = new BigInteger("5"); BigInteger total = BigInteger.ZERO; total.add(five); //这并不会改变total的值,调用该方法的返回值,才是加法得到的结果。 total = total.add(five); // 才是希望得到的结果
谜题57
HashSet中的元素,首先计算hashCode,然后在调用equals()方法。一个类如果重写了equals()方法,而没有重写hashCode()方法,对HashSet会有影响。因此两个方法尽量一起重写。
谜题58
本来应该重写equals(Object o),但是重载了,写成了:equals(Class class)因此在重写的时候尽量使用:@Override
谜题59
主要讲述了:在数字前面加个0就是八进制的数了。
谜题60
一行编码解决问题,主要讲述是四个知识点。
1. LinkedHashSet:维持来的顺序,且没有重复的。2. 正则表达式在split中的应用。3. Arrays.deepToString的使用4. 包装类的位操作:Integer.bitCount();
谜题61
主要讲了Calendar和Data使用的问题。使用时候要注意查API文档。
谜题62
HashMap存储String时候的问题。HashMap比较键时,使用的是引用等价性而不是值等价性。语言规范字符串是内存限定的,相等的String常量也是相同的。
谜题63
不要将构造器声明变成方法声明:添加返回值。
谜题64
整数边界的问题Math.abs(Integer.MIN_VALUE) 仍是其本身PS:负数取余的问题
谜题65
整数相减越界的问题。两个整数相减会导致越界,compare时最好不要使用两数相减,改为public int compare(Integer i1, integer i2) { return (i2 < i1 ? -1 : (i2 == i1) ? 0 : 1); }