Updated ARM Spec
Paul Benedict
pbenedict at apache.org
Fri Aug 20 13:45:41 PDT 2010
I still think Errors should not be swallowed. They indicate major
problems and should terminate the use case.
On Fri, Aug 20, 2010 at 3:45 PM, Joe Darcy <joe.darcy at oracle.com> wrote:
> Rémi Forax wrote:
>> Le 13/08/2010 05:28, Neal Gafter a écrit :
>>
>>> When a stack overflow exception suppresses another exception, I assume
>>> it's suppressed exception list will be set. But since there is only
>>> one such exception allocated by the VM, this will overwrite any data
>>> previously stored there. Will the VM be modified to comply with this
>>> specification by allocating a new stack-overflow exception each time?
>>> Same question for out-of-memory error.
>>>
>>>
>>
>> This problem already exists with jdk6.
>> This code change the stack trace of permanently allocated OutOfMerroryError.
>>
>> public static void main(String[] args) {
>> Error last = null;
>>
>> for(int i=0; i<100; i++) {
>> try {
>> Object o = new int[Integer.MAX_VALUE];
>> } catch (Error e) {
>> StackTraceElement[] stackTrace = e.getStackTrace();
>> if (stackTrace != null && stackTrace.length>0 &&
>> stackTrace[0].getLineNumber() == -3) {
>> e.printStackTrace();
>> return;
>> }
>>
>> if (last == e) {
>> StackTraceElement element = new StackTraceElement("Foo",
>> "foo", null, -3);
>> e.setStackTrace(new StackTraceElement[]{element});
>> }
>> last = e;
>> }
>> }
>> }
>>
>>
>>
>> To avoid that the VM has to clear the stacktrace when using the default
>> error:
>> in universe.cpp, in Universe::gen_out_of_memory_error:
>>
>> if (next < 0) {
>> // all preallocated errors have been used.
>> // return default
>> + java_lang_Throwable::clear_stacktrace(default_err);
>> return default_err;
>> } else {
>>
>>
>> And we should do the same for the field suppressed exceptions.
>>
>> Rémi
>>
>>
>
> Thanks for the suggestion Rémi; I'm also checking with the HotSpot folks
> to see if any other kinds of exceptions need to be handled specially.
>
> -Joe
>
>
More information about the coin-dev
mailing list