zoukankan      html  css  js  c++  java
  • 表达式之谜

    一、判断奇数

      说到判断奇数,第一反应就是  i % 2 == 1;然而这个是有很大问题的;

      对负数的判断而言,其语句是错误的!!因为  负数%2 == -1

      所以可以改进为   i % 2 != 0;

      还可以进一步优化,众所周知,位运算是特别快的,所以有:   i & 1 != 0; ==> 最优方案!!!

    二、找零时刻

      找零钱:2-1.1 = ?

      直接输出:System.out.println(2-1.1);  ==>  0.8999999999999999

        这是因为在计算机中并不是所有的小数都可以用二进制精确表示,

        若要精确表示可因使用BigDecimal ,且,一定要用BigDecimal(String) 

      改进:使用printf进行输出可以实现该功能!!

          System.out.printf("%.2f",2-1.1);

      优化:使用BigDecimal实现:

        System.out.println(new BigDecimal("2.00").subtract(new BigDecimal("1.10")));

     三、长整除

      long / long

      一天中的毫秒数 / 一天中的微秒数

    final long weimiao = 24 * 60 * 60 * 1000 * 1000;
    final long haomiao = 24 * 60 * 60 * 1000;
            
    System.out.println(weimiao / haomiao);  //5

      这是由于weimiao溢出造成的,虽然计算完成的结果不溢出,但是由于在运算过程中是以int类型计算的,weimiao产生溢出,使结果出错!!!

     解决方法很简单,通过long常量代替int常量作为每一个乘积的因子:

    1 final long weimiao = 24L * 60 * 60 * 1000 * 1000;
    2 final long haomiao = 24L * 60 * 60 * 1000;
    3         
    4 System.out.println(weimiao / haomiao);  //1000

       结果正确!!

      在操作很大的数字时,千万要注意溢出问题,拿不准时,就用long来计算!!

    四、十六进制

       System.out.println(Long.toHexString(0x100000000L + 0xcafebabe));   ==> cafebabe 

       !如果十六进制或八进制字面常量的最高位被置位了,则,它为负数!!!!

        其中long+int ==> 自动转型为 long+long

        且,第二个数符号扩展:

        

       可将第二个数编程long类型,以避免具有破坏力的符号扩展!!

      System.out.println(Long.toHexString(0x100000000L + 0xcafebabeL)); ==> 1cafebabe

  • 相关阅读:
    学点 C 语言(21): 数据类型 数组与指针
    学点 C 语言(16): 数据类型 关于常量的前缀、后缀
    学点 C 语言(19): 数据类型 数组
    学点 C 语言(15): 数据类型 sizeof(检测类型大小)
    学点 C 语言(18): 数据类型 枚举类型(enum)
    学点 C 语言(20): 数据类型 指针
    重写一个字符串分割函数 回复 "tomzw" 的问题
    学点 C 语言(14): 数据类型 双字节字符类型 wchar_t
    学点 C 语言(22): 数据类型 多维数组与指针
    学点 C 语言(17): 数据类型 因类型引发的问题或错误
  • 原文地址:https://www.cnblogs.com/zhongzhongdebokeyuan/p/5388763.html
Copyright © 2011-2022 走看看