Question

In C# if I want to convert a double (1.71472) to an int then I get the answer 2. If I do this in Java using intValue() method, I get 1 as the answer.

Does Java round down on conversions?

Why do the Java API docs have such scant information about their classes i.e.

Returns the value of the specified number as an int. This may involve rounding or truncation.

A bit more info about the rounding would have been helpful!

Was it helpful?

Solution

Java rounds toward zero when narrowing from a floating point to an integer type—and so does C#, when you use the casting conversion. It's Convert.ToInt32 that rounds:

double d = 1.71472;
int x = (int) d; // x = 1
int y = Convert.ToInt32(d); // y = 2

Details can be found in the Java Language Specification. Note that while the documentation cited in Number leaves options open for subclasses, the documentation on the concrete boxing types, like Double, is explicit about the implementation:

Returns the value of this Double as an int (by casting to type int).

When using BigDecimal, you can specify one of eight different rounding policies.

OTHER TIPS

Java rounds toward zero when narrowing from a floating point to an integer type.

There's more documentation about the general rules in the Java Language Specification. Note that while the documentation in Number leaves options open for subclasses, the documentation on the concrete boxing types is more explicit:

Returns the value of this Double as an int (by casting to type int).

When using BigDecimal, you can specify one of eight different rounding policies.

Jon Skeet is correct, but something else to watch for is that .NET uses Banker's Rounding as its rounding algorithm. When you're halfway between round towards the even integer.

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top