《1》eqals:
// 不能使用一个值为null的引用类型变量来调用非静态方法,否则会抛出异常
String str = null;
if (str.equals("SnailClimb")) {
...
} else {
..
}
正确使用
"SnailClimb".equals(str);// false
总结:代码1,会空指针异常,代码2,则不会
《2》BigDecimal
float a = 1.0f - 0.9f;
float b = 0.9f - 0.8f;
System.out.println(a);// 0.100000024
System.out.println(b);// 0.099999964
System.out.println(a == b);// false
正确使用
BigDecimal a = new BigDecimal("1.0");
BigDecimal b = new BigDecimal("0.9");
BigDecimal c = new BigDecimal("0.8");
BigDecimal x = a.subtract(b);
BigDecimal y = b.subtract(c);
System.out.println(x); /* 0.1 */
System.out.println(y); /* 0.1 */
System.out.println(Objects.equals(x, y)); /* true */
总结:代码1,(精度丢失)代码2,使用 BigDecimal 来定义浮点数的值,再进行浮点数的运算操作
《3》BigDecimal 的大小比较
//a.compareTo(b) : 返回 -1 表示 a 小于 b,0 表示 a 等于 b , 1表示 a 大于 b
BigDecimal a = new BigDecimal("1.0");
BigDecimal b = new BigDecimal("0.9");
System.out.println(a.compareTo(b));// 1
《4》BigDecimal 保留几位小数
//通过 setScale方法设置保留几位小数以及保留规则。保留规则有挺多种,不需要记,IDEA会提示。
BigDecimal m = new BigDecimal("1.255433");
BigDecimal n = m.setScale(3,BigDecimal.ROUND_HALF_DOWN);
System.out.println(n);// 1.255
《5》BigDecimal 的使用注意事项
//使用BigDecimal(double);存在精度损失风险,若在精确计算或值比较的场景中可能会导致业务逻辑异常
BigDecimal g=new Bigdecimal(0.1f);//实际存储值为:0.10000000149
正确使用:
//为了防止精度丢失,推荐使用它的 BigDecimal(String) 构造方法来创建对象
BigDecimal g1=new Bigdecimal("0.1");
BigDecimal g2=Bigdecimal.valueOf(0.1);
《6》基本数据类型与包装数据类型的使用标准
- 【强制】所有的 POJO 类属性必须使用包装数据类型。
- 【强制】RPC 方法的返回值和参数必须使用包装数据类型。
- 【推荐】所有的局部变量使用基本数据类型。
比如我们如果自定义了一个Student类,其中有一个属性是成绩score,如果用Integer而不用int定义,一次考试,学生可能没考,值是null,也可能考了,但考了0分,值是0,这两个表达的状态明显不一样.
说明 :POJO 类属性没有初值是提醒使用者在需要使用时,必须自己显式地进行赋值,任何 NPE 问题,或者入库检查,都由使用者来保证。
正例 : 数据库的查询结果可能是 null,因为自动拆箱,用基本数据类型接收有 NPE 风险。
反例 : 比如显示成交总额涨跌情况,即正负 x%,x 为基本数据类型,调用的 RPC 服务,调用不成功时,返回的是默认值,页面显示为 0%,这是不合理的,应该显示成中划线。所以包装数据类型的 null 值,能够表示额外的信息,如:远程调用失败,异常退出。
《7》Arrays.asList()使用常识
//Arrays.asList()在平时开发中还是比较常见的,我们可以使用它将一个数组转换为一个List集合
String[] myArray = {"Apple", "Banana", "Orange"};
List<String> myList = Arrays.asList(myArray);
正确使用array转换list:
//最简单的
List list = new ArrayList<>(Arrays.asList("a", "b", "c"))
// 使用 Java8 的Stream(推荐)
Integer [] myArray = { 1, 2, 3 };
List myList = Arrays.stream(myArray).collect(Collectors.toList());
//基本类型也可以实现转换(依赖boxed的装箱操作)
int [] myArray2 = { 1, 2, 3 };
List myList = Arrays.stream(myArray2).boxed().collect(Collectors.toList());
//使用 Java9 的 List.of()方法
Integer[] array = {1, 2, 3};
List<Integer> list = List.of(array);
System.out.println(list); /* [1, 2, 3] */
/* 不支持基本数据类型 */
总结:虽然已经转换成了List集合,但是后台的数据然然是数组。所以使用集合的修改方法:add()、remove()、clear()会抛出异常。运行时报错:UnsupportedOperationException
《8》不要在 foreach 循环里进行元素的 remove/add 操作
/**如果要进行remove操作,可以调用迭代器的 remove 方法而不是集合类的 remove 方法。
*因为如果*列表在任何时间从结构上修改创建迭代器之后,以任何方式除非通过迭代器自身remove/add方法,
*迭代器都将抛出一个ConcurrentModificationException,这就是单线程状态下产生的 fail-fast 机制。
* */
//Java8开始,可以使用Collection#removeIf()方法删除满足特定条件的元素,如
List<Integer> list = new ArrayList<>();
for (int i = 1; i <= 10; ++i) {
list.add(i);
}
list.removeIf(filter -> filter % 2 == 0); /* 删除list中的所有偶数 */
System.out.println(list); /* [1, 3, 5, 7, 9] */