Are there any practical uses of anonymous code blocks in Java?
public static void main(String[] args) {     // in     {         // out     } } Please note that this is not about named blocks, i.e.
name: {       if ( /* something */ )           break name; } .
A code block is a grouping of two or more statements. This is done by enclosing the statements between opening and closing curly braces. Once a block of code has been created, it becomes a logical unit that can be used any place that a single statement can.
Anonymous object. Anonymous simply means nameless. An object which has no reference is known as an anonymous object. It can be used at the time of object creation only. If you have to use an object only once, an anonymous object is a good approach.
Object = new Example() { public void display() { System. out. println("Anonymous class overrides the method display()."); } }; Here, an object of the anonymous class is created dynamically when we need to override the display() method.
Java try block is used to enclose the code that might throw an exception. It must be used within the method. If an exception occurs at the particular statement in the try block, the rest of the block code will not execute. So, it is recommended not to keep the code in try block that will not throw an exception.
They restrict variable scope.
public void foo() {     {         int i = 10;     }     System.out.println(i); // Won't compile. } In practice, though, if you find yourself using such a code block that's probably a sign that you want to refactor that block out to a method.
@David Seiler's answer is right, but I would contend that code blocks are very useful and should be used frequently and don't necessarily indicate the need to factor out into a method. I find they are particularly useful for constructing Swing Component trees, e.g:
JPanel mainPanel = new JPanel(new BorderLayout()); {     JLabel centerLabel = new JLabel();     centerLabel.setText("Hello World");     mainPanel.add(centerLabel, BorderLayout.CENTER); } {     JPanel southPanel = new JPanel(new FlowLayout(FlowLayout.LEFT, 0,0));     {         JLabel label1 = new JLabel();         label1.setText("Hello");         southPanel.add(label1);     }     {         JLabel label2 = new JLabel();         label2.setText("World");         southPanel.add(label2);     }     mainPanel.add(southPanel, BorderLayout.SOUTH); } Not only do the code blocks limit the scope of variables as tightly as possible (which is always good, especially when dealing with mutable state and non-final variables), but they also illustrate the component hierarchy much in the way as XML / HTML making the code easier to read, write and maintain.
My issue with factoring out each component instantiation into a method is that
In this Swing example, I find that when complexity really does grow beyond manageability it indicates that it's time to factor out a branch of the tree into a new class rather than a bunch of small methods.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With