Comment jette-t-on un doubleà decimalqui est utilisé lors du développement de devises. Où Mva-t-il?
decimal dtot = (decimal)(doubleTotal);
Réponses:
Vous n'utilisez le que Mpour un littéral numérique, lorsque vous castez simplement:
decimal dtot = (decimal)doubleTotal;
Notez qu'un nombre à virgule flottante n'est pas adapté pour conserver une valeur exacte, donc si vous ajoutez d'abord des nombres ensemble, puis convertissez en, Decimalvous pouvez obtenir des erreurs d'arrondi. Vous souhaiterez peut-être convertir les nombres en Decimalavant de les additionner, ou vous assurer que les nombres ne sont pas des nombres à virgule flottante en premier lieu.
Vous pouvez convertir un double en décimal comme ceci, sans avoir besoin du Msuffixe littéral:
double dbl = 1.2345D;
decimal dec = (decimal) dbl;
Vous devez utiliser le Mlors de la déclaration d'une nouvelle valeur décimale littérale:
decimal dec = 123.45M;
(Sans le M, 123.45 est traité comme un double et ne sera pas compilé.)
utiliser la classe de conversion par défaut: Convert.ToDecimal(Double)
Convert.ToDecimal(the double you are trying to convert);
doublevers decimal, étant donné que pour une doublevaleur comme (1000000.0 / 3.0) on le ferait dans certains cas veulent couper une précision "excessive" donnant 333333,333333333D, mais dans d'autres cas, on voudrait la conserver, donnant 333333,333333333313931D. Plutôt que de simplement dire «convertir en décimal», le code doit spécifier comment cette conversion doit être effectuée.
Convert.ToDecimal(double)est la même que (decimal)doubleTotal, sauf si elle est doubleTotalmodifiée pour un type différent, vous éviterez probablement une erreur de compilation et introduiriez une erreur d'exécution plus difficile à trouver car un ToDecimal différent le remplacement peut être appelé. L'opérateur de distribution est beaucoup plus explicite ...
Eh bien, c'est une vieille question et j'ai effectivement utilisé certaines des réponses présentées ici. Néanmoins, dans mon scénario particulier, il était possible que la doublevaleur vers laquelle je voulais convertir decimalsoit souvent supérieure à decimal.MaxValue. Donc, au lieu de gérer les exceptions, j'ai écrit cette méthode d'extension:
public static decimal ToDecimal(this double @double) =>
@double > (double) decimal.MaxValue ? decimal.MaxValue : (decimal) @double;
L'approche ci-dessus fonctionne si vous ne voulez pas vous soucier de la gestion des exceptions de débordement et si une telle chose se produit, vous voulez simplement garder la valeur maximale possible (mon cas), mais je suis conscient que pour de nombreux autres scénarios, ce ne serait pas le comportement attendu et peut être la gestion des exceptions sera nécessaire.