Package javax.swing
Swing's Threading Policy
In general Swing is not thread safe. All Swing components and related classes, unless otherwise documented, must be accessed on the event dispatching thread.
Typical Swing applications do processing in response to an event generated
from a user gesture. For example, clicking on a JButton
notifies all
ActionListeners
added to the JButton
. As all events generated
from a user gesture are dispatched on the event dispatching thread, most
developers are not impacted by the restriction.
Where the impact lies, however, is in constructing and showing a Swing
application. Calls to an application's main
method, or methods in
Applet
, are not invoked on the event dispatching thread. As such,
care must be taken to transfer control to the event dispatching thread when
constructing and showing an application or applet. The preferred way to
transfer control and begin working with Swing is to use invokeLater
.
The invokeLater
method schedules a Runnable
to be processed
on the event dispatching thread. The following two examples work equally well
for transferring control and starting up a Swing application:
import javax.swing.SwingUtilities; public class MyApp implements Runnable { public void run() { // Invoked on the event dispatching thread. // Construct and show GUI. } public static void main(String[] args) { SwingUtilities.invokeLater(new MyApp()); } }Or:
import javax.swing.SwingUtilities; public class MyApp { MyApp(String[] args) { // Invoked on the event dispatching thread. // Do any initialization here. } public void show() { // Show the UI. } public static void main(final String[] args) { // Schedule a job for the event-dispatching thread: // creating and showing this application's GUI. SwingUtilities.invokeLater(new Runnable() { public void run() { new MyApp(args).show(); } }); } }This restriction also applies to models attached to Swing components. For example, if a
TableModel
is attached to a JTable
, the
TableModel
should only be modified on the event dispatching thread.
If you modify the model on a separate thread you run the risk of exceptions
and possible display corruption.
Although it is generally safe to make updates to the UI immediately,
when executing on the event dispatch thread, there is an exception :
if a model listener tries to further change the UI before the UI has been
updated to reflect a pending change then the UI may render incorrectly.
This can happen if an application installed listener needs to update the UI
in response to an event which will cause a change in the model structure.
It is important to first allow component installed listeners to process this
change, since there is no guarantee of the order in which listeners may be
called.
The solution is for the application listener to make the change using
SwingUtilities.invokeLater(Runnable)
so that any changes
to UI rendering will be done post processing all the model listeners
installed by the component.
As all events are delivered on the event dispatching thread, care must be
taken in event processing. In particular, a long running task, such as
network io or computational intensive processing, executed on the event
dispatching thread blocks the event dispatching thread from dispatching any
other events. While the event dispatching thread is blocked the application
is completely unresponsive to user input. Refer to
SwingWorker
for the preferred way to do such processing
when working with Swing.
More information on this topic can be found in the Swing tutorial, in particular the section on Concurrency in Swing.
Swing's Serialization policy
Warning: Serialized objects of any Swing class will not be compatible with future Swing releases. The current serialization support is appropriate for short term storage or RMI between applications running the same version of Swing. As of 1.4, support for long term storage of all JavaBeans has been added to thejava.beans
package.
Related Documentation
For overviews, tutorials, examples, guides, and other documentation, please see:- Since:
- 1.2
-
ClassDescriptionThis class provides default implementations for the JFC
Action
interface.Defines common behaviors for buttons and menu items.A base class forCellEditors
, providing default implementations for the methods in theCellEditor
interface exceptgetCellEditorValue()
.The abstract definition for the data model that provides aList
with its contents.This class provides the ChangeListener part of the SpinnerModel interface that should be suitable for most concrete SpinnerModel implementations.TheAction
interface provides a useful extension to theActionListener
interface in cases where the same functionality may be accessed by several controls.ActionMap
provides mappings fromObject
s (called keys orAction
names) toAction
s.Factory class for vending standardBorder
objects.Defines the data model used by components likeSlider
s andProgressBar
s.A lightweight container that uses a BoxLayout object as its layout manager.An implementation of a lightweight component that participates in layout but has no view.A layout manager that allows multiple components to be laid out either vertically or horizontally.This class is used to create a multiple-exclusion scope for a set of buttons.State model for buttons.This interface defines the methods any general editor should be able to implement.This class is inserted in between cell renderers and the components that use them.The editor component used for JComboBox components.A data model for a combo box.AComponentInputMap
is anInputMap
associated with a particularJComponent
.Graphics subclass supporting graphics debugging.A generic implementation of BoundedRangeModel.The default implementation of aButton
component's data model.The default editor for table and tree cells.The default model for combo boxes.This is an implementation of theDesktopManager
.This class has been obsoleted by the 1.4 focus APIs.Renders an item in a list.A subclass of DefaultListCellRenderer that implements UIResource.This class loosely implements thejava.util.Vector
API, in that it implements the 1.1.x version ofjava.util.Vector
, has no collection class support, and notifies theListDataListener
s when changes occur.Default data model for list selections.DefaultRowSorter<M,I> An implementation ofRowSorter
that provides sorting and filtering around a grid-based data model.DefaultRowSorter.ModelWrapper
is responsible for providing the data that gets sorted byDefaultRowSorter
.A generic implementation of SingleSelectionModel.DesktopManager objects are owned by a JDesktopPane object.Drop modes, used to determine the method by which a component tracks and indicates a drop location during drag and drop.This class has been obsoleted by the 1.4 focus APIs.An image filter that "disables" an image by turning it into a grayscale image, and brightening the pixels in the image.GroupLayout
is aLayoutManager
that hierarchically groups components in order to position them in aContainer
.Enumeration of the possible waysParallelGroup
can align its children.A small fixed size picture, typically used to decorate components.An implementation of the Icon interface that paints Icons from Images.InputMap
provides a binding between an input event (currently onlyKeyStroke
s are used) and anObject
.This class provides the validation mechanism for Swing components.A FocusTraversalPolicy which can optionally provide an algorithm for determining a JInternalFrame's initial Component.Deprecated, for removal: This API element is subject to removal in a future version.The Applet API is deprecated, no replacement.An implementation of a "push" button.An implementation of a check box -- an item that can be selected or deselected, and which displays its state to the user.A menu item that can be selected or deselected.JColorChooser
provides a pane of controls designed to allow a user to manipulate and select a color.JComboBox<E>A component that combines a button or editable field and a drop-down list.The interface that defines aKeySelectionManager
.The base class for all Swing components except top-level containers.A container used to create a multiple-document interface or a virtual desktop.The main class for creating a dialog window.A text component to edit various kinds of content.JFileChooser
provides a simple mechanism for the user to choose a file.JFormattedTextField
extendsJTextField
adding support for formatting arbitrary values, as well as retrieving a particular object once the user has edited the text.Instances ofAbstractFormatter
are used byJFormattedTextField
to handle the conversion both from an Object to a String, and back from a String to an Object.Instances ofAbstractFormatterFactory
are used byJFormattedTextField
to obtain instances ofAbstractFormatter
which in turn are used to format values.An extended version ofjava.awt.Frame
that adds support for the JFC/Swing component architecture.A lightweight object that provides many of the features of a native frame, including dragging, closing, becoming an icon, resizing, title display, and support for a menu bar.This component represents an iconified version of aJInternalFrame
.A display area for a short text string or an image, or both.JLayer
is a universal decorator for Swing components which enables you to implement various advanced painting effects as well as receive notifications of allAWTEvent
s generated within its borders.JLayeredPane
adds depth to a JFC/Swing container, allowing components to overlap each other when needed.JList<E>A component that displays a list of objects and allows the user to select one or more items.A subclass ofTransferHandler.DropLocation
representing a drop location for aJList
.An implementation of a menu -- a popup window containingJMenuItem
s that is displayed when the user selects an item on theJMenuBar
.An implementation of a menu bar.An implementation of an item in a menu.JOptionPane
makes it easy to pop up a standard dialog box that prompts users for a value or informs them of something.JPanel
is a generic lightweight container.JPasswordField
is a lightweight component that allows the editing of a single line of text where the view indicates something was typed, but does not show the original characters.An implementation of a popup menu -- a small window that pops up and displays a series of choices.A popup menu-specific separator.A component that visually displays the progress of some task.An implementation of a radio button -- an item that can be selected or deselected, and which displays its state to the user.An implementation of a radio button menu item.A lightweight container used behind the scenes byJFrame
,JDialog
,JWindow
,JApplet
, andJInternalFrame
.An implementation of a scrollbar.Provides a scrollable view of a lightweight component.JSeparator
provides a general purpose component for implementing divider lines - most commonly used as a divider between menu items that breaks them up into logical groupings.A component that lets the user graphically select a value by sliding a knob within a bounded interval.A single line input field that lets the user select a number or an object value from an ordered sequence.An editor for aJSpinner
whose model is aSpinnerDateModel
.A simple base class for more specialized editors that displays a read-only view of the model's current value with aJFormattedTextField
.An editor for aJSpinner
whose model is aSpinnerListModel
.An editor for aJSpinner
whose model is aSpinnerNumberModel
.JSplitPane
is used to divide two (and only two)Component
s.A component that lets the user switch between a group of components by clicking on a tab with a given title and/or icon.TheJTable
is used to display and edit regular two-dimensional tables of cells.A subclass ofTransferHandler.DropLocation
representing a drop location for aJTable
.Printing modes, used in printingJTable
s.AJTextArea
is a multi-line area that displays plain text.JTextField
is a lightweight component that allows the editing of a single line of text.A text component that can be marked up with attributes that are represented graphically.An implementation of a two-state button.The ToggleButton modelJToolBar
provides a component that is useful for displaying commonly usedAction
s or controls.A toolbar-specific separator.Used to display a "Tip" for a Component.A control that displays a set of hierarchical data as an outline.A subclass ofTransferHandler.DropLocation
representing a drop location for aJTree
.DynamicUtilTreeNode
can wrap vectors/hashtables/arrays/strings and create the appropriate children tree nodes as necessary.EmptySelectionModel
is aTreeSelectionModel
that does not allow anything to be selected.The "viewport" or "porthole" through which you see the underlying information.AJWindow
is a container that can be displayed anywhere on the user's desktop.A KeyStroke represents a key action on the keyboard, or equivalent input device.A SortingFocusTraversalPolicy which sorts Components based on their size, position, and orientation.LayoutStyle
provides information about how to position components.ComponentPlacement
is an enumeration of the possible ways two components can be placed relative to each other.Identifies components that can be used as "rubber stamps" to paint the cells in a JList.ListModel<E>This interface defines the methods components like JList use to get the value of each cell in a list and the length of the list.This interface represents the current state of the selection for any of the components that display a list of values with stable indices.LookAndFeel
, as the name implies, encapsulates a look and feel.Any component that can be placed into a menu should implement this interface.A MenuSelectionManager owns the selection in menu hierarchy.A mutable version ofComboBoxModel
.A layout manager to arrange components over the top of each other.Painter<T>A painting delegate.Popups are used to display aComponent
to the user, typically on top of all the otherComponent
s in a particular containment hierarchy.PopupFactory
, as the name implies, is used to obtain instances ofPopup
s.A class to monitor the progress of some operation.Monitors the progress of reading from some InputStream.Defines the requirements for an object responsible for "rendering" (displaying) a value.This class manages repaint requests, allowing the number of repaints to be minimized, for example by collapsing multiple requests into a single repaint for members of a component tree.This interface is implemented by components that have a single JRootPane child: JDialog, JFrame, JWindow, JApplet, JInternalFrame.RowFilter<M,I> RowFilter
is used to filter out entries from the model so that they are not shown in the view.Enumeration of the possible comparison values supported by some of the defaultRowFilter
s.RowFilter.Entry<M,I> AnEntry
object is passed to instances ofRowFilter
, allowing the filter to get the value of the entry's data, and thus to determine whether the entry should be shown.RowSorter<M>RowSorter
provides the basis for sorting and filtering.SortKey describes the sort order for a particular column.An interface that provides information to a scrolling container like JScrollPane.Constants used with the JScrollPane component.The layout manager used byJScrollPane
.The UI resource version ofScrollPaneLayout
.A model that supports at most one indexed selection.For the convenience of layout managers, calculates information about the size and position of components.ASizeSequence
object efficiently maintains an ordered list of sizes and corresponding positions.A FocusTraversalPolicy that determines traversal order by sorting the Components of a focus traversal cycle based on a given Comparator.SortOrder is an enumeration of the possible sort orderings.ASpinnerModel
for sequences ofDate
s.A simple implementation ofSpinnerModel
whose values are defined by an array or aList
.A model for a potentially unbounded sequence of object values.ASpinnerModel
for sequences of numbers.An instance of theSpring
class holds three properties that characterize its behavior: the minimum, preferred, and maximum values.ASpringLayout
lays out the children of its associated container according to a set of constraints.AConstraints
object holds the constraints that govern the way a component's size and position change in a container controlled by aSpringLayout
.A collection of constants generally used for positioning and orienting components on the screen.An annotation used to specify some swing-related information for the automatically generatedBeanInfo
classes.A collection of utility methods for Swing.SwingWorker<T,V> An abstract class to perform lengthy GUI-interaction tasks in a background thread.Values for thestate
bound property.Fires one or moreActionEvent
s at specified intervals.Manages all theToolTips
in the system.This class is used to handle the transfer of aTransferable
to and from Swing components.Represents a location where dropped data should be inserted.This class encapsulates all relevant details of a clipboard or drag and drop transfer, and also allows for customizing aspects of the drag and drop experience.This interface is used only for tagging keys for client properties forJComponent
set by UI which needs to be cleared on L&F change and serialization.A table of defaults for Swing components.This class enables one to store an entry in the defaults table that's constructed each time it's looked up with one of thegetXXX(key)
methods.LazyInputMap
will create aInputMap
in itscreateValue
method.This class enables one to store an entry in the defaults table that isn't constructed until the first time it's looked up with one of thegetXXX(key)
methods.This class provides an implementation ofLazyValue
which can be used to delay loading of the Class for the instance to be created.UIManager
manages the current look and feel, the set of available look and feels,PropertyChangeListeners
that are notified when the look and feel changes, look and feel defaults, and convenience methods for obtaining various default values.Provides a little information about an installedLookAndFeel
for the sake of configuring a menu or for initial application set up.An exception that indicates the requested look & feel management classes are not present on the user's system.The default layout manager forJViewport
.Constants used to control the window-closing operation.