Это решает проблему того, что подкласс забывает вызвать метод finalize
суперкласса. Этот шаблон работает, присоединяя дополнительный экземпляр с переопределенным finalize
к вашему суперклассу. Таким образом, если суперкласс выйдет из области видимости, присоединенный экземпляр также выйдет из области видимости, что вызовет выполнение его finalize
, что, в свою очередь, вызовет finalize
включающего класса.
Вот небольшой фрагмент кода, демонстрирующий образец стража в действии:
public class Parent {
public static void main(final String[] args) throws Exception {
doIt();
System.gc();
Thread.sleep(5000); // 5 sec sleep
}
@SuppressWarnings("unused")
private final Object guardian = new Object() {
@Override protected void finalize() {
doFinalize();
}
};
private void doFinalize() {
System.out.println("Finalize of class Parent");
}
public static void doIt() {
Child c = new Child();
System.out.println(c);
}
}
class Child extends Parent {
// Note, Child class does not call super.finalize() but the resources held by the
// parent class will still get cleaned up, thanks to the guardian pattern
@Override protected void finalize() {
System.out.println("Finalize of class Child");
}
}