Выполнить экземпляр Thread в ExecutorServiceJAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Выполнить экземпляр Thread в ExecutorService

Сообщение Anonymous »

Я знаю, что мы можем выполнить Runnable в ExecutorService, который будет выполняться как отдельные потоки. Но недавно я столкнулся с ситуацией, когда мне нужно знать состояние потока во время его выполнения. Для этого я создал экземпляры Thread (вместо Runnable) и отправил их в ExecutorService. Однако состояние потока осталось в состоянии НОВОЕ. Синтаксически в программе не было ошибок, но я чувствую, что что-то упускаю. Вот пример программы:
public class ThreadStates3 {

public static void main(String[] args) throws InterruptedException {
Thread thread = new Thread(getRunnable());
Thread thread2 = new Thread(getRunnable());

ExecutorService service = Executors.newSingleThreadExecutor();
service.execute(thread);
service.execute(thread2);

while (true) {
System.out.println("Thread 1: " + thread.getState() + ", Thread 2: " + thread2.getState());
Thread.sleep(1000);
boolean taskComplete = thread.getState() == Thread.State.TERMINATED &&
thread2.getState() == Thread.State.TERMINATED;
if (taskComplete) break;
}

System.out.println("Program complete.");
}

static Runnable getRunnable() {
return () -> {
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
};
}
}


Подробнее здесь: https://stackoverflow.com/questions/786 ... torservice
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»