[c#] Double 변수를 십진수로 캐스트

어떻게 캐스트 a를 수행 doubledecimal통화 개발을 할 때 어떤 사용된다. 어디로 M갑니까?

decimal dtot = (decimal)(doubleTotal);



답변

M캐스트 할 때는 숫자 리터럴 에만 사용합니다 .

decimal dtot = (decimal)doubleTotal;

부동 소수점 숫자는 정확한 값을 유지하는 데 적합하지 않으므로 먼저 숫자를 더한 다음로 변환 Decimal하면 반올림 오류가 발생할 수 있습니다. 숫자를 Decimal더하기 전에 숫자를로 변환 하거나 처음에 숫자가 부동 소수점 숫자가 아닌지 확인할 수 있습니다.


답변

다음과 같이 M리터럴 접미사 없이 double을 십진수로 캐스트 할 수 있습니다 .

double dbl = 1.2345D;
decimal dec = (decimal) dbl;

M새 리터럴 10 진수 값을 선언 할 때 다음을 사용해야합니다 .

decimal dec = 123.45M;

(이 없으면 M123.45는 double로 처리되고 컴파일되지 않습니다.)


답변

기본 변환 클래스 사용 : Convert.ToDecimal(Double)


답변

Convert.ToDecimal(the double you are trying to convert);


답변

음 이것은 오래된 질문이며 실제로 여기에 표시된 답변 중 일부를 사용했습니다. 그럼에도 불구하고 내 특정 시나리오에서는 double변환하려는 값 decimaldecimal.MaxValue. 그래서 예외를 처리하는 대신이 확장 메서드를 작성했습니다.

    public static decimal ToDecimal(this double @double) =>
        @double > (double) decimal.MaxValue ? decimal.MaxValue : (decimal) @double;

위의 접근 방식은 오버플로 예외 처리를 방해하지 않고 그러한 일이 발생하면 가능한 최대 값 (내 경우)을 유지하려는 경우에 작동하지만 다른 많은 시나리오에서는 이것이 예상되는 동작이 아님을 알고 있습니다. 예외 처리가 필요할 수 있습니다.


답변