|
|
|
|
|
by jandrese
2386 days ago
|
|
That seems a bit confusing given how the loop works. 999,999 shouldn't be big enough to be affected by floating point rounding. If the comment is correct then Java will evaluate ( 999999 >= 1000000 ) as true, which simply cannot be correct. |
|
In the end, the number will be displayed to one decimal place, eg. "1.1 MB" or similar due to the "%.1f" format specifier.
If the input is 999999 bytes, the loop will see that it is less than 1 MB and so will format the number 999.999 into "%.1f kB". When this number is rounded to one decimal place as part of that formatting, it rounds up to "1000.0 kB". This is the wrong output.
There's a bit of a catch 22 because ideally, you would be able to do the rounding first, and then see what units need applying, but you can't do the rounding until you know what the divisor will be.
The article solves this by first manually determining what the cut-off should be (it will be some number like "...999500...") but personally I'd probably just decide to round to significant figures instead so that you can cleanly separate the "rounding" and "unit selection" steps.