summaryrefslogtreecommitdiff
path: root/tests/030-bad-finalizer/src/BadFinalizer.java
blob: 3ff422b3d2e0cec98a46043ee1b64a773b0494d2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
// Copyright 2007 The Android Open Source Project

/**
 * Class with a bad finalizer.
 */
public class BadFinalizer {
    public static void snooze(int ms) {
        try {
            Thread.sleep(ms);
        } catch (InterruptedException ie) {
            System.out.println("Snooze: " + ie.getMessage());
        }
    }

    protected void finalize() {
        System.out.println("Finalizer started and spinning...");
        int j = 0;

        /* spin for a bit */
        long start, end;
        start = System.nanoTime();
        for (int i = 0; i < 1000000; i++)
            j++;
        end = System.nanoTime();
        System.out.println("Finalizer done spinning.");

        System.out.println("Finalizer sleeping forever now.");
        while (true) {
            snooze(10000);
        }
    }
}