更新时间:2022-08-14 19:29:30
前言:写公号差不多也有一个月了,没有做到每天坚持(真的太难了),但是养成了会有新知识就会记录下来的习惯,感谢读者(你们),也欣赏一下我自己。
总是觉得自己Java基础还是不行,需要恶补。今天偶然mark了一本《Java解惑》,其中以端程序的方式罗列了95个即常见又不常见的xian(坑)jing(儿),拿来瞻仰一下。
判断一个数是否为奇数
public class SolutionOne{ /** * 判断下列方法是否能够很好的运转? * * 不能 * 因为int整型中有一半是负数,也就是说 * i 为负数,那么返回值永远为false */ public static boolean isOdd(int i){ return i % 2 == 1; } /** * 这个方法能够很好的运转, * 因为不管对正数和负数来说,余数为0 -- 偶数 * 不为0 -- 奇数 */ public static boolean isNew(int i){ return i % 2 != 0; } /** * 使用位操作符 来替代取余操作符,能够改善性能 * note: * 5转换为二进制:0000 0000 0000 0000 0000 0000 0000 0101 * 3转换为二进制:0000 0000 0000 0000 0000 0000 0000 0011 * ------------------------------------------------------------------------------------- * 1转换为二进制:0000 0000 0000 0000 0000 0000 0000 0001 * 位与:第一个操作数的的第n位于第二个操作数的第n位如果都是1,那么结果的第n为也为1,否则为0 */ public static boolean isChange(int i){ return(i & 1) != 0; } public static void main(String[] args) { System.out.println(isOdd(3)); System.out.println(isOdd(-1)); System.out.println(isOdd(-2)); System.out.println("------------------"); System.out.println(isNew(3)); System.out.println(isNew(-1)); System.out.println(isNew(-2)); System.out.println("------------------"); System.out.println(isNew(3)); System.out.println(isNew(-1)); System.out.println(isNew(-2)); } }
试问:能否用2.00美元买到1.10美元的热狗?
public class SolutionTwo{ public static void main(String[] args) { // 请验证一下以下输出 输出 0.8999999999999999 System.out.println(2.00-1.10); // 解决办法一、输出 0.90 System.out.printf("%.2f%n ",2.00-1.10); // 解决办法二、使用正数类型,int or long 输出 0.90 System.out.println((200-110) +" cents"); // 解决办法三、使用更精确精度的BigDecimal,一定要用BigDecimal(String) 而不要用BigDecimal(Double) System.out.println(new BigDecimal("2.00").subtract(new BigDecimal("1.10"))); } }
public class SolutionThree{ public static void main(String[] args) { // 打印输出以下语句,会输出什么呢? // 并不是你预料的1000, 而是 5 final long MICROS_PER_DAY=24*60*60*1000*1000; final long MILLIS_PER_DAY=24*60*60*1000; System.out.println(MICROS_PER_DAY/MILLIS_PER_DAY); /** * 发生了什么呢? 为什么差着1000倍两个常量的数值相除会得到 5? * * 因为上述常数MICROS_PER_DAY的计算发生溢出,虽然计算的结果适合 * 放入long中,并且其空间还有富余,但是这个结果并不适合放入int中, * 所以计算的结果是按着int来执行的。运算完成之后,转换为long类型 * 但此时已经太迟,计算已经溢出,它返回了一个小于200倍的数值。从 * int提升为long是一种拓宽原生类型转换,它保留了不正确的计算数值 * 于是整除的结果为5 * */ // 下面的结果是正确的结果 final long MICROS_PER_DAYS=24L*60*60*1000*1000; final long MILLIS_PER_DAYS=24L*60*60*1000; System.out.println(MICROS_PER_DAYS/MILLIS_PER_DAYS); } }
public class SolutionFour{ public static void main(String[] args) { /** * 下面的问题简直太简单了,打印出来肯定是66666, * 但是是吗?输出的结果确实17777,你会感到惊讶, * 为什么是17777呢?请注意 + 号右面的数字,是5432 l 而不是1 * 注意到差别了吗? 所以以后为了产生这种微小的误差 * 建议把l -> L */ System.out.println(12345+5432l); /** * 此外,还要避免使用 l 作为对象 */ List<String> l = new ArrayList<>(); l.add("Foo"); System.out.println(l); } }