RFR: 8367149: Add ergonomic construction for creating ad-hoc VMErrorCallback [v3]
Albert Mingkun Yang
ayang at openjdk.org
Thu Sep 11 10:49:38 UTC 2025
On Thu, 11 Sep 2025 08:32:46 GMT, Axel Boldt-Christmas <aboldtch at openjdk.org> wrote:
>> Add a class OnVMError which uses the VMErrorCallback mechanism which is an ergonomic construction for creating ad-hoc VMErrorCallback which automatically calls the provided invocable f if a VM crash occurs within its lifetime. Can be used to instrument a build for more detailed contextual information gathering. Especially useful when hunting down intermittent bugs, or issues only reproducible in environments where access to a debugger is not readily available. Example use:
>> ```C++
>> {
>> // Note the lambda is invoked after an error occurs within this thread,
>> // and during on_error's lifetime. If state prior to the crash is required,
>> // capture a copy of it first.
>> auto important_value = get_the_value();
>>
>> OnVMError on_error([&](outputStream* st) {
>> // Dump the important bits.
>> st->print("Prior value: ");
>> important_value.print_on(st);
>> st->print("During crash: ")
>> get_the_value().print_on(st);
>> // Dump whole the whole state.
>> this->print_on(st);
>> });
>>
>> // Sometimes doing a thing will crash the VM.
>> do_a_thing();
>> }
>>
>>
>> C++17 class template argument deduction finally makes these sort of constructions ergonomic to use without the need for auto and helper construction methods.
>
> Axel Boldt-Christmas has updated the pull request incrementally with one additional commit since the last revision:
>
> Replace ergonomic with convenient
Maybe the title can use "convenient" as well.
-------------
Marked as reviewed by ayang (Reviewer).
PR Review: https://git.openjdk.org/jdk/pull/27159#pullrequestreview-3210658042
More information about the hotspot-dev
mailing list