RFR: 8271599: Javadoc of floorDiv() and floorMod() families is inaccurate in some places [v3]

Brian Burkhalter bpb at openjdk.java.net
Tue Aug 3 22:40:53 UTC 2021


On Tue, 3 Aug 2021 22:37:12 GMT, Raffaello Giulietti <github.com+70726043+rgiulietti at openjdk.org> wrote:

>> Hello,
>> 
>> please review the changes in documentation of floorDiv() and floorMod() in all their variants. Some are clarifications, some are corrections.
>> 
>> Here's an example of a confusing formulation in the current doc
>>> "the / operator returns the integer closest to zero"
>> 
>> Literally, the integer closest to zero is zero!
>> 
>> 
>> The doc of floorMod(int, int) also states:
>>> "If the signs of arguments are unknown and a positive modulus
>>> is needed it can be computed as (floorMod(x, y) + abs(y)) % abs(y)."
>> 
>> That's a questionable advice, as the sum in parentheses can lead to irrecoverable overflow (beside requiring two divisions instead of one).
>> E.g., setting x = Integer.MAX_VALUE - 1, y = Integer.MAX_VALUE leads to the quite incorrect result -3, which is not even positive!
>> 
>> 
>> Greetings
>> Raffaello
>
> Raffaello Giulietti has updated the pull request incrementally with one additional commit since the last revision:
> 
>   8271599: Javadoc of floorDiv() and floorMod() families is inaccurate in some places

src/java.base/share/classes/java/lang/Math.java line 1250:

> 1248:      * Returns the largest (closest to positive infinity)
> 1249:      * {@code int} value that is less than or equal to the algebraic quotient.
> 1250:      * There is one special case: if the dividend is the

I think the "the" at the end of line 1250 can be deleted.

src/java.base/share/classes/java/lang/Math.java line 1268:

> 1266:      *       while the {@code /} operator returns the smallest integer greater
> 1267:      *       than or equal to the quotient.
> 1268:      *       There's a difference if and only if the quotient is not an integer.<br>

Maybe "There's a difference" -> "They differ" ?

src/java.base/share/classes/java/lang/Math.java line 1295:

> 1293:      * Returns the largest (closest to positive infinity)
> 1294:      * {@code long} value that is less than or equal to the algebraic quotient.
> 1295:      * There is one special case: if the dividend is the

Again, "the" can go away.

src/java.base/share/classes/java/lang/Math.java line 1324:

> 1322:      * Returns the largest (closest to positive infinity)
> 1323:      * {@code long} value that is less than or equal to the algebraic quotient.
> 1324:      * There is one special case: if the dividend is the

Delete "the" again.

src/java.base/share/classes/java/lang/StrictMath.java line 1054:

> 1052:      * Returns the largest (closest to positive infinity)
> 1053:      * {@code int} value that is less than or equal to the algebraic quotient.
> 1054:      * There is one special case: if the dividend is the

"the"

src/java.base/share/classes/java/lang/StrictMath.java line 1078:

> 1076:      * Returns the largest (closest to positive infinity)
> 1077:      * {@code long} value that is less than or equal to the algebraic quotient.
> 1078:      * There is one special case: if the dividend is the

"the"

src/java.base/share/classes/java/lang/StrictMath.java line 1102:

> 1100:      * Returns the largest (closest to positive infinity)
> 1101:      * {@code long} value that is less than or equal to the algebraic quotient.
> 1102:      * There is one special case: if the dividend is the

"the"

-------------

PR: https://git.openjdk.java.net/jdk/pull/4963


More information about the core-libs-dev mailing list