// Copyright 2008 The Android Open Source Project import java.util.Timer; import java.util.TimerTask; /* * Throw an exception from a finalizer and make sure it's harmless. Under * Dalvik this may also generate a warning in the log file. */ public class Main { static Object waiter = new Object(); static volatile boolean didFinal = false; static void createAndForget() { Main main = new Main(); } public static void main(String[] args) { // Start RoboVM changes. In RoboVM we need to repeat this a couple of times to cause // GC+finalization for (int i = 0; i < 10; i++) { createAndForget(); System.gc(); System.runFinalization(); if (didFinal) { break; } } // End RoboVM changes new Timer(true).schedule(new TimerTask() { public void run() { System.out.println("Timed out, exiting"); System.exit(1); } }, 30000); while (!didFinal) { try { Thread.sleep(500); } catch (InterruptedException ie) { System.err.println(ie); } } /* give it a chance to cause mayhem */ try { Thread.sleep(750); } catch (InterruptedException ie) { System.err.println(ie); } System.out.println("done"); } protected void finalize() throws Throwable { // RoboVM note: Only do this for the first finalized object if (!didFinal) { System.out.println("In finalizer"); didFinal = true; throw new InterruptedException("whee"); } } }