当前位置:   article > 正文

Arith.java

arith.java
  1. import java.math.BigDecimal;
  2. /**
  3. * 由於Java的簡單類型不能夠精確的對浮點數進行運算,這個工具類提供精 確的浮點數運算,包括加減乘除和四捨五入。
  4. */
  5. public class Arith {
  6. // 默認除法運算精度
  7. private static final int DEF_DIV_SCALE = 10;
  8. // 這個類不能實例化
  9. private Arith() {
  10. }
  11. /**
  12. * 提供精確的加法運算。
  13. *
  14. * @param v1
  15. * 被加數
  16. * @param v2
  17. * 加數
  18. * @return 兩個參數的和
  19. */
  20. public static double add(double v1, double v2) {
  21. BigDecimal b1 = new BigDecimal(Double.toString(v1));
  22. BigDecimal b2 = new BigDecimal(Double.toString(v2));
  23. return b1.add(b2).doubleValue();
  24. }
  25. /**
  26. * 提供精確的減法運算。
  27. *
  28. * @param v1
  29. * 被減數
  30. * @param v2
  31. * 減數
  32. * @return 兩個參數的差
  33. */
  34. public static double sub(double v1, double v2) {
  35. BigDecimal b1 = new BigDecimal(Double.toString(v1));
  36. BigDecimal b2 = new BigDecimal(Double.toString(v2));
  37. return b1.subtract(b2).doubleValue();
  38. }
  39. /**
  40. * 提供精確的乘法運算。
  41. *
  42. * @param v1
  43. * 被乘數
  44. * @param v2
  45. * 乘數
  46. * @return 兩個參數的積
  47. */
  48. public static double mul(double v1, double v2) {
  49. BigDecimal b1 = new BigDecimal(Double.toString(v1));
  50. BigDecimal b2 = new BigDecimal(Double.toString(v2));
  51. return b1.multiply(b2).doubleValue();
  52. }
  53. /**
  54. * 提供(相對)精確的除法運算,當發生除不盡的情況時,精確到 小數點以後10位元,以後的數字四捨五入。
  55. *
  56. * @param v1
  57. * 被除數
  58. * @param v2
  59. * 除數
  60. * @return 兩個參數的商
  61. */
  62. public static double div(double v1, double v2) {
  63. return div(v1, v2, DEF_DIV_SCALE);
  64. }
  65. /**
  66. * 提供(相對)精確的除法運算。當發生除不盡的情況時,由scale參數指 定精度,以後的數字四捨五入。
  67. *
  68. * @param v1
  69. * 被除數
  70. * @param v2
  71. * 除數
  72. * @param scale
  73. * 表示表示需要精確到小數點以後幾位。
  74. * @return 兩個參數的商
  75. */
  76. public static double div(double v1, double v2, int scale) {
  77. if (scale < 0) {
  78. throw new IllegalArgumentException(
  79. "The scale must be a positive integer or zero");
  80. }
  81. BigDecimal b1 = new BigDecimal(Double.toString(v1));
  82. BigDecimal b2 = new BigDecimal(Double.toString(v2));
  83. return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
  84. }
  85. /**
  86. * 提供精確的小數位四捨五入處理。
  87. *
  88. * @param v
  89. * 需要四捨五入的數位
  90. * @param scale
  91. * 小數點後保留幾位
  92. * @return 四捨五入後的結果
  93. */
  94. public static double round(double v, int scale) {
  95. if (scale < 0) {
  96. throw new IllegalArgumentException(
  97. "The scale must be a positive integer or zero");
  98. }
  99. BigDecimal b = new BigDecimal(Double.toString(v));
  100. BigDecimal one = new BigDecimal("1");
  101. return b.divide(one, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
  102. }
  103. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/319819
推荐阅读
相关标签
  

闽ICP备14008679号