Risoluzione di un errore Sono venuto a qualche scoperta interessante.C# Errore nell'operatore di modulo%
Il risultato di questa procedura
static void Main(string[] args)
{
int i4 = 4;
Console.WriteLine("int i4 = 4;");
Console.WriteLine("i4 % 1 = {0}", i4 % 1);
double d4 = 4.0;
Console.WriteLine("double d4 = 4.0;");
Console.WriteLine("d4 % 1 = {0}", d4 % 1);
Console.WriteLine("-----------------------------------------------------------");
int i64 = 64;
double dCubeRootOf64 = Math.Pow(i64, 1.0/3.0);
Console.WriteLine("int i64 = 64;");
Console.WriteLine("double dCubeRootOf64 = Math.Pow(i64, 1.0/3.0) = {0}", dCubeRootOf64);
Console.WriteLine("dCubeRootOf64 = {0}", dCubeRootOf64);
Console.WriteLine("dCubeRootOf64 % 1 = {0} ?????????????? Why 1. ??????????", dCubeRootOf64 % 1);
Console.ReadLine();
}
è
int i4 = 4;
i4 % 1 = 0
double d4 = 4.0;
d4 % 1 = 0
-----------------------------------------------------------
int i64 = 64;
double dCubeRootOf64 = Math.Pow(i64, 1.0/3.0) = 4
dCubeRootOf64 = 4
dCubeRootOf64 % 1 = 1 ?????????????? Why 1. ??????????
int 4 % 1 = 0
- corretta
double 4.0 % 1 = 0
- corretta
Ma bug è in:
01.235.Math.pow (64, 1.0/3.0)% 1 = 1
radice cubica da 64 è 4. Perché in quel caso 4 % 1 = 1
?
Partenza Google: (64^(1/3)) mod 1 – SQLMason
Se si vuole fare in modo che è un numero intero per cui stai ricevendo il modulo, prova a lanciarlo. – SQLMason
Siete alla ricerca di questo penso http://stackoverflow.com/questions/618535/what-is-the-difference-between-decimal-float-and-double-in-c – Nevyn