-
public interface SecondaryLoop
A helper interface to run the nested event loop.Objects that implement this interface are created with the
EventQueue.createSecondaryLoop()
method. The interface provides two methods,enter()
andexit()
, which can be used to start and stop the event loop.When the
enter()
method is called, the current thread is blocked until the loop is terminated by theexit()
method. Also, a new event loop is started on the event dispatch thread, which may or may not be the current thread. The loop can be terminated on any thread by calling itsexit()
method. After the loop is terminated, theSecondaryLoop
object can be reused to run a new nested event loop.A typical use case of applying this interface is AWT and Swing modal dialogs. When a modal dialog is shown on the event dispatch thread, it enters a new secondary loop. Later, when the dialog is hidden or disposed, it exits the loop, and the thread continues its execution.
The following example illustrates a simple use case of secondary loops:
SecondaryLoop loop; JButton jButton = new JButton("Button"); jButton.addActionListener(new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) { Toolkit tk = Toolkit.getDefaultToolkit(); EventQueue eq = tk.getSystemEventQueue(); loop = eq.createSecondaryLoop(); // Spawn a new thread to do the work Thread worker = new WorkerThread(); worker.start(); // Enter the loop to block the current event // handler, but leave UI responsive if (!loop.enter()) { // Report an error } } }); class WorkerThread extends Thread {@Override
public void run() { // Perform calculations doSomethingUseful(); // Exit the loop loop.exit(); } }- Since:
- 1.7
- See Also:
Dialog.show()
,EventQueue.createSecondaryLoop()
,Toolkit.getSystemEventQueue()
-
-
Method Summary
Methods Modifier and Type Method and Description boolean
enter()
Blocks the execution of the current thread and enters a new secondary event loop on the event dispatch thread.boolean
exit()
Unblocks the execution of the thread blocked by theenter()
method and exits the secondary loop.
-
-
-
Method Detail
-
enter
boolean enter()
Blocks the execution of the current thread and enters a new secondary event loop on the event dispatch thread.This method can be called by any thread including the event dispatch thread. This thread will be blocked until the
exit()
method is called or the loop is terminated. A new secondary loop will be created on the event dispatch thread for dispatching events in either case.This method can only start one new event loop at a time per object. If a secondary event loop has already been started by this object and is currently still running, this method returns
false
to indicate that it was not successful in starting a new event loop. Otherwise, this method blocks the calling thread and later returnstrue
when the new event loop is terminated. At such time, this object can again be used to start another new event loop.- Returns:
true
after termination of the secondary loop, if the secondary loop was started by this call,false
otherwise
-
exit
boolean exit()
Unblocks the execution of the thread blocked by theenter()
method and exits the secondary loop.This method resumes the thread that called the
enter()
method and exits the secondary loop that was created when theenter()
method was invoked.Note that if any other secondary loop is started while this loop is running, the blocked thread will not resume execution until the nested loop is terminated.
If this secondary loop has not been started with the
enter()
method, or this secondary loop has already finished with theexit()
method, this method returnsfalse
, otherwisetrue
is returned.- Returns:
true
if this loop was previously started and has not yet been finished with theexit()
method,false
otherwise
-
-
Nederlandse vertaling
U hebt gevraagd om deze site in het Nederlands te bezoeken. Voor nu wordt alleen de interface vertaald, maar nog niet alle inhoud.Als je me wilt helpen met vertalingen, is je bijdrage welkom. Het enige dat u hoeft te doen, is u op de site registreren en mij een bericht sturen waarin u wordt gevraagd om u toe te voegen aan de groep vertalers, zodat u de gewenste pagina's kunt vertalen. Een link onderaan elke vertaalde pagina geeft aan dat u de vertaler bent en heeft een link naar uw profiel.
Bij voorbaat dank.
Document heeft de 11/06/2005 gemaakt, de laatste keer de 04/03/2020 gewijzigd
Bron van het afgedrukte document:https://www.gaudry.be/nl/java-api-rf-java/awt/secondaryloop.html
De infobrol is een persoonlijke site waarvan de inhoud uitsluitend mijn verantwoordelijkheid is. De tekst is beschikbaar onder CreativeCommons-licentie (BY-NC-SA). Meer info op de gebruiksvoorwaarden en de auteur.
Referenties
Deze verwijzingen en links verwijzen naar documenten die geraadpleegd zijn tijdens het schrijven van deze pagina, of die aanvullende informatie kunnen geven, maar de auteurs van deze bronnen kunnen niet verantwoordelijk worden gehouden voor de inhoud van deze pagina.
De auteur Deze site is als enige verantwoordelijk voor de manier waarop de verschillende concepten, en de vrijheden die met de referentiewerken worden genomen, hier worden gepresenteerd. Vergeet niet dat u meerdere broninformatie moet doorgeven om het risico op fouten te verkleinen.