본문 바로가기

Dev. Java

정확한 숫자 계산을 위한 BigDecimal

실수 연산의 경우 float , double 타입의 사용에 주의해야 한다.


System.out.println(2.0 - 1.1); 를 해보면 그 이유를 알 수 있다.  


이에 대한 결과는 0.9가 아니라 0.8999999999  결과가 출력 된다.  이는 컴퓨터가 숫자1.1 double로 


정확하게 표현 할 수 없어 근사치를 출력하기 때문이다.  이에 대한 해결책으로 정확한 소수 연산을 수행하는


BigDecimal타입이 있다.  , 주의할 점은 항상 BigDecimal(double)이 아닌 BigDecimal(String) 생성자를 사용해


야 한다.   이유는 BigDecimal(double)을 사용하는 순간, double 자체가 정확하게 수를 표현 못하기 때문에 생성 

자체부터 부정확한 값이 기억되기 때문이.


 1) 

import java.math.*;

~

BigDecimal s1 = new BigDecimal("2.0");

BigDecimal s2 = new BigDecimal("1.1");

out.println(s1.subtract(s2)); 

 

 

 

BigDecimal타입의 사칙연산


매우 큰 숫자형의 연산은 BigDecimal 형으로 변경 후 계산을 하면 효과적이다.


 2)

import! java.math.*;

public class Test {

 public static void main(String[] args) {
  
        BigDecimal su1 = new BigDecimal("12345678901234567899");
  
        BigDecimal su2 = new BigDecimal("12345678901234567890");
           BigDecimal p_add = su1.add(su2);   // 더하기  

BigDecimal p_sub = su1.subtract(su2);   // 빼기  

BigDecimal p_mul = su1.multiply(su2);   // 곱하기  

BigDecimal p_div1 = su1.divide(su2, BigDecimal.ROUND_UP);   // 나누기 - 무조건 반올림  

BigDecimal p_div2 = su1.divide(su2, 4, BigDecimal.ROUND_UP);  // 나누기 - 소수점 4번째 자리에서 반올림.
              System.out.println("덧셈 : " + p_add);

System.out.println("뺄셈 : " + p_sub);

System.out.println("곱셈 : " + p_mul);

System.out.println("나눗셈1 : " + p_div1);

System.out.println("나눗셈2 : " + p_div2);

 }

}


[출처] http://blog.daum.net/feelsogreat/71