2011-03-02 17 views
11

¿Hay algún oyente en Java que maneje que algún hilo se haya terminado? Algo como esto:Oyente de extremo de subproceso. Java

Future<String> test = workerPool.submit(new TestCalalble()); 
test.addActionListener(new ActionListener()    
    {               
    public void actionEnd(ActionEvent e)    
    {               
     txt1.setText("Button1 clicked");       
    }               
    }); 

que sé, que es imposible tratar como esto, pero quiero ser notificado cuando terminó un poco de hilo.

Normalmente utilicé esta clase de temporizador con el estado de comprobación de cada futuro. pero no es linda manera. Gracias

Respuesta

11

Hay CompletionService que puede usar.

CompletionService<Result> ecs 
     = new ExecutorCompletionService<Result>(e); 
ecs.submit(new TestCallable()); 
if (ecs.take().get() != null) { 
    // on finish 
} 

Otra alternativa es usar ListenableFuture de Guava.

ejemplo Código:

ListenableFuture future = Futures.makeListenable(test); 
future.addListener(new Runnable() { 
public void run() { 
    System.out.println("Operation Complete."); 
    try { 
    System.out.println("Result: " + future.get()); 
    } catch (Exception e) { 
    System.out.println("Error: " + e.message()); 
    } 
} 
}, exec); 

Personalmente, me gusta guayaba solución mejor.

+1

bueno saberlo. No estoy usando guayaba, pero parece que debería hacerlo. – AlexR

+0

bien ... cómo decirlo. Debieras. De Verdad. :) – nanda

+0

"take() - Recupera y quita el futuro que representa la siguiente tarea completada, esperando si aún no está presente. @" Pero quiero trabajar asincrónicamente, por lo que no cabe – Denis

1

No. Ese oyente no existe. Pero tiene 2 soluciones.

  1. código Add que le notifica que el hilo se hace en el final de run() método
  2. Uso Callable interfaz que devuelve un resultado de tipo Future. Puede preguntarle a Future cuál es el estado y usar el método bloqueado get() para recuperar el resultado
+0

También puedo anular el método afterExecute() de la clase ThreadPoolExecutor. – Denis

1

Tiene un método join() definido por la clase Thread para eso. Sin embargo, no tiene visibilidad directa de un subproceso que ejecuta su Callable en el caso de API de concurrencia.

+1

esta es una respuesta muy decente – bestsss

+0

He intentado responder la pregunta tal como está: "¿Hay algún oyente en ** Java ** para manejar que se haya terminado ** un hilo **?" sin entrar en j.u.c. o Guava o cualquier otra cosa construida en la parte superior del idioma principal. – mazaneicha

2

Aquí hay geekish oyente. Altamente unadvisible de usar, pero, divertido e inteligente

Thread t = ... 
t.setUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler(){ 
    @Override 
    public void uncaughtException(Thread t, Throwable e) { 
     t.getThreadGroup().uncaughtException(t, e);//this is the default behaviour 
    }  
    protected void finalize() throws Throwable{ 
     //cool, we go notified 
     //handle the notification, but be worried, it's the finalizer thread w/ max priority 
    } 
}); 

El efecto puede ser a través de achived PhantomRefernce mejor

esperamos que tenga una sonrisa :)


Nota al margen: lo que se pide es NO thread end, pero el evento de finalización de tarea y el mejor está anulando decorateTask o afterExecute

3

Puede implementar el patrón Observer para informar la finalización.

public interface IRunComplete { 
    public void reportCompletion(String message); 
} 

Let the Thread caller implementar esta interfaz.

y en el método run() llama a este método al final. Así que ahora sabes exactamente cuándo terminará este hilo.

Pruébalo. De hecho, estoy usando esto y está funcionando bien.

2

Sin la adición de una gran cantidad de código extra que puede hacer que un oyente rápida hilo a sí mismo de la siguiente manera:

//worker thread for doings 
Thread worker = new Thread(new Runnable(){ 
    public void run(){/*work thread stuff here*/} 
}); 
worker.start(); 
//observer thread for notifications 
new Thread(new Runnable(){ 
    public void run(){ 
    try{worker.join();} 
    catch(Exception e){;} 
    finally{ /*worker is dead, do notifications.*/} 
}).start(); 
Cuestiones relacionadas