Главное не ждать потоков даже после использования Thread.join() в Java

Функция join() заставляет функцию main ждать, пока все потоки не завершат выполнение, но main печатает completed до Thread-1 а также Thread-2 завершает выполнение. Я не могу найти ошибку в коде. где ошибка?

class ThreadDemo extends Thread {
    private Thread t;
    private String threadName;

    ThreadDemo(String name) {
        threadName = name;
    }
    public void run() {
        System.out.println("Thread " + threadName + " exiting.");
    }
    public void start() {
        if (t == null) {
            t = new Thread (this, threadName);
            t.start();
        }
    }
}
public class Problem2 {
    public static void main(String[] args) {
        ThreadDemo T1 = new ThreadDemo("Thread-1");
        ThreadDemo T2 = new ThreadDemo("Thread-2");
        T1.start();
        T2.start();
        try {
            T1.join();
            T2.join();
        } catch (InterruptedException e) {
            System.out.println("ERROR!");
        }
        System.out.println("completed");
    }
}

Выход

completed
Thread Thread-2 exiting.
Thread Thread-1 exiting.

1 ответ

Решение

Вы присоединяетесь к экземплярам ThreadDemo. Но вы не запускаете эти экземпляры как потоки. Ваш переопределен start Метод создает и запускает другой поток.

Ваш код очень запутанный. Вы используете наследование и делегирование, переопределяете методы и нарушаете их контракт: start() должен начинаться this как поток, а не создавать и запускать другой поток.

Вот как это должно выглядеть:

class ThreadDemo implements Runnable {
    private String threadName;

    ThreadDemo(String name) {
        this.threadName = name;
    }

    @Override
    public void run() {
        System.out.println("Thread " + threadName + " exiting.");
    }

}
public class Problem2 {
    public static void main(String[] args) {
        ThreadDemo runnable1 = new ThreadDemo("Thread-1");
        ThreadDemo runnable2 = new ThreadDemo("Thread-2");

        Thread t1 = new Thread(runnable1);
        Thread t2 = new Thread(runnable2);

        t1.start();
        t2.start();
        try {
            t1.join();
            t2.join();
        } catch (InterruptedException e) {
            System.out.println("ERROR!");
        }
        System.out.println("completed");
    }
}
Другие вопросы по тегам