En Java, nous pouvons convertir implicitement un int pour le faire flotter, ce qui peut entraîner une perte de précision, comme indiqué dans l'exemple de code ci-dessous.Java autorise la conversion implicite de int en float. Pourquoi?
public class Test {
public static void main(String [] args) {
int intVal = 2147483647;
System.out.println("integer value is " + intVal);
double doubleVal = intVal;
System.out.println("double value is " + doubleVal);
float floatVal = intVal;
System.out.println("float value is " + floatVal);
}
}
La sortie est
integer value is 2147483647
double value is 2.147483647E9
float value is 2.14748365E9
Quelle est la raison qui permet la conversion implicite de int flotter, quand il y a une perte de précision?
en double de http://stackoverflow.com/questions/11183980/why-does-c-sharp-allow-an-implicit-conversion-from-long-to-float-when-this-co –
@ AaronKurtzhals: Cette question concerne une langue différente. – Wug