JVM tarafından finalize () yönteminin çağrılmasında bir belirsizlik olduğundan (geçersiz kılınan finalize () yürütülüp yürütülmeyeceğinden emin değilim), çalışma amacıyla finalize () çağrıldığında ne olacağını gözlemlemenin daha iyi yolu JVM'yi komutla çöp toplama işlemini çağırmaya zorlayın System.gc()
.
Özellikle, bir nesne artık kullanılmadığında finalize () çağrılır. Ancak yeni nesneler yaratarak onu çağırmaya çalıştığımızda çağrısının kesinliği yoktur. Bu yüzden kesin olarak gelecekteki bir kullanımı olmayan bir null
nesne yaratıyoruz c
, dolayısıyla nesnenin c
son çağrısını görüyoruz .
Misal
class Car {
int maxspeed;
Car() {
maxspeed = 70;
}
protected void finalize() {
// Originally finalize method does nothing, but here we override finalize() saying it to print some stmt
// Calling of finalize is uncertain. Difficult to observe so we force JVM to call it by System.gc(); GarbageCollection
System.out.println("Called finalize method in class Car...");
}
}
class Bike {
int maxspeed;
Bike() {
maxspeed = 50;
}
protected void finalize() {
System.out.println("Called finalize method in class Bike...");
}
}
class Example {
public static void main(String args[]) {
Car c = new Car();
c = null; // if c weren`t null JVM wouldn't be certain it's cleared or not, null means has no future use or no longer in use hence clears it
Bike b = new Bike();
System.gc(); // should clear c, but not b
for (b.maxspeed = 1; b.maxspeed <= 70; b.maxspeed++) {
System.out.print("\t" + b.maxspeed);
if (b.maxspeed > 50) {
System.out.println("Over Speed. Pls slow down.");
}
}
}
}
Çıktı
Called finalize method in class Car...
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 33 34 35 36 37 38 39
40 41 42 43 44 45 46 47 48 49
50 51Over Speed. Pls slow down.
52Over Speed. Pls slow down.
53Over Speed. Pls slow down.
54Over Speed. Pls slow down.
55Over Speed. Pls slow down.
56Over Speed. Pls slow down.
57Over Speed. Pls slow down.
58Over Speed. Pls slow down.
59Over Speed. Pls slow down.
60Over Speed. Pls slow down.
61Over Speed. Pls slow down.
62Over Speed. Pls slow down.
63Over Speed. Pls slow down.
64Over Speed. Pls slow down.
65Over Speed. Pls slow down.
66Over Speed. Pls slow down.
67Over Speed. Pls slow down.
68Over Speed. Pls slow down.
69Over Speed. Pls slow down.
70Over Speed. Pls slow down.
Not - 70'e kadar yazdırdıktan sonra ve daha sonra programda b nesnesi kullanılmadığında bile, b'nin JVM tarafından silinip temizlenmediğine dair bir belirsizlik vardır, çünkü "Bike sınıfında sonlandırma yöntemi ..." yazdırılmaz.