Skip to main content

How to create instances of static nested classes and inner classes?

The semantics for creating instances of static nested classes/inner classes can be confusing.
  • creating an instance of the inner class requires a reference to an instance of the enclosing class
  • creating an instance of the static nested class does not require an instance of the enclosing class
Here is an example which is a simple class that defines a static nested class and an inner class:

public class EnclosingClass {
    private String name = "instance name";
    private static String staticName = "static name";

    public static void main(String[] args) {
       EnclosingClass enclosingClass = new  EnclosingClass();
       EnclosingClass.InnerClass innerClass = enclosingClass.new InnerClass();
       EnclosingClass.StaticNestedClass staticNestedClass 
            = new EnclosingClass.StaticNestedClass();
    }
    
    class InnerClass {
       InnerClass() {
          System.out.println(name);
          System.out.println(staticName);
       }
    }
    static class StaticNestedClass {
       StaticNestedClass() {
          System.out.println(staticName);
       }
    }
}
Nested classes can be confusing, but once you understand their purpose and get used to the semantics, there isn't a lot to them.

Click below links to know more

Comments

Popular posts from this blog

WebSphere MQ Interview Questions

What is MQ and what does it do? Ans. MQ stands for MESSAGE QUEUEING. WebSphere MQ allows application programs to use message queuing to participate in message-driven processing. Application programs can communicate across different platforms by using the appropriate message queuing software products. What is Message driven process? Ans . When messages arrive on a queue, they can automatically start an application using triggering. If necessary, the applications can be stopped when the message (or messages) have been processed. What are advantages of the MQ? Ans. 1. Integration. 2. Asynchrony 3. Assured Delivery 4. Scalability. How does it support the Integration? Ans. Because the MQ is independent of the Operating System you use i.e. it may be Windows, Solaris,AIX.It is independent of the protocol (i.e. TCP/IP, LU6.2, SNA, NetBIOS, UDP).It is not required that both the sender and receiver should be running on the same platform What is Asynchrony? Ans. With messag...

Asynchronous Vs. Synchronous Communications

Synchronous (One thread):   1 thread -> |<---A---->||<----B---------->||<------C----->| Synchronous (multi-threaded):   thread A -> |<---A---->| \ thread B ------------> ->|<----B---------->| \ thread C ----------------------------------> ->|<------C----->|

Advantages & Disadvantages of Synchronous / Asynchronous Communications?

  Asynchronous Communication Advantages: Requests need not be targeted to specific server. Service need not be available when request is made. No blocking, so resources could be freed.  Could use connectionless protocol Disadvantages: Response times are unpredictable. Error handling usually more complex.  Usually requires connection-oriented protocol.  Harder to design apps Synchronous Communication Advantages: Easy to program Outcome is known immediately  Error recovery easier (usually)  Better real-time response (usually) Disadvantages: Service must be up and ready. Requestor blocks, held resources are “tied up”.  Usually requires connection-oriented protocol