해혹2:시간을 찾다

1437 단어
[성명] 모든 코드는 조슈아 블루스와 넬 가프트가 저술한 이라는 책에서 왔습니다. 저는 단지 학습을 위해 베끼기와 주석을 필요로 하기 때문에 두 작가의 지식을 공유해 주셔서 감사합니다.
 
코드:
 
public class Change {
    public static void main(String args[]) {
        System.out.println(2.00 - 1.10);
    }
}

 
결과:
 
0.8999999999999999

 
 
분석:
JAVA에서 2진법 부동점수는 소수를 완전히 정확하게 표시할 수 없다. 우리가 본 부동점수의 실제 값은 글자값에 무한히 가까운 수치이다.
예를 들어 1.10자 액면가는 1.10이지만 이 부동점수가 컴퓨터에서의 실제 값은 1.11111111일 수 있다.
그래서 계산한 결과가 우리의 기대에 미치지 못했을 수도 있다.
따라서 부동점수 연산을 계산할 때 정밀도가 높고 정확한 BigDecimal 클래스를 사용합니다.
 
코드:
 
 
public class Change {
    public static void main(String args[]) {
    	System.out.println(new BigDecimal("2.00").subtract(new BigDecimal("1.10")));
    }
}
 
결과:
 
0.90

 
BigDecimal을 실례화할 때 부동점수를 매개 변수로 실례화하면 부동점수의 실제 값이 예상한 값이 아니기 때문에 정확한 결과를 얻을 수 없습니다.
 
솔루션 코드:
 
public class Change {
    public static void main(String args[]) {
    	System.out.println(new BigDecimal(2.00).subtract(new BigDecimal(1.10)));
    }
}

결과:
 
0.899999999999999911182158029987476766109466552734375
 

좋은 웹페이지 즐겨찾기