RFR: 8324433: Introduce a way to determine if an expression is evaluated as a constant by the Jit compiler [v3]
Aleksey Shipilev
shade at openjdk.org
Tue Jan 23 17:50:33 UTC 2024
On Tue, 23 Jan 2024 16:01:05 GMT, Aleksey Shipilev <shade at openjdk.org> wrote:
>> Would it be possible to list further examples where this might be used? Asking because I'm wondering about the usability and maintainability of if-then-else code.
>
>> Would it be possible to list further examples where this might be used? Asking because I'm wondering about the usability and maintainability of if-then-else code.
>
> A similar thing is already used in JDK: https://github.com/openjdk/jdk/blob/2a01c798d346656a0ee3553c0964feab75b5dfb6/src/java.base/share/classes/java/lang/invoke/Invokers.java#L622-L624
>
> Extending this for more common use allows doing things like optimizing `Integer.toString(int)`:
>
>
> @Stable
> static final String[] CONST_STRINGS = {"-1", "0", "1"};
>
> @IntrinsicCandidate
> public static String toString(int i) {
> if (isCompileConstant(i) && (i >= -1) && (i <= 1)) {
> return CONST_STRINGS[i + 1];
> }
> ...
>
>
> Note how this code would fold away to one of the paths, depending on whether the compiler knows it is a constant or not. Generated-code-wise it is a zero-cost thing :)
> @shipilev Thanks a lot for the detailed reviews and suggestions, I hope I have addressed all of them.
Sure thing, I just effectively merged my draft implementation into yours :)
-------------
PR Comment: https://git.openjdk.org/jdk/pull/17527#issuecomment-1906602556
More information about the hotspot-compiler-dev
mailing list