How to make sure that there is just one instance of class in JVM?

后端 未结 9 1541
离开以前
离开以前 2021-02-01 05:48

I am developing a design pattern, and I want to make sure that here is just one instance of a class in Java Virtual Machine, to funnel all requests for some resource through a s

相关标签:
9条回答
  • 2021-02-01 06:16

    I can only think of a way to count instances of a class and destroy all instance after first is created. Is this a right approach ? If not, is there any other way ?

    The correct technical approach is to declare all of the constructors for the class as private so that instances of the class can only be created by the class itself. Then you code the class only ever create one instance.

    Other Answers show some of the ways to implement this, according to the "Singleton" design pattern. However, implementing a singleton like this has some drawbacks, including making it significantly harder to write unit tests.

    0 讨论(0)
  • 2021-02-01 06:19

    Use the singleton pattern. The easiest implementation consists of a private constructor and a field to hold its result, and a static accessor method with a name like getInstance().

    The private field can be assigned from within a static initializer block or, more simply, using an initializer. The getInstance() method (which must be public) then simply returns this instance,

    public class Singleton {
        private static Singleton instance;
    
        /**
         * A private Constructor prevents any other class from
         * instantiating.
         */
        private Singleton() {
            // nothing to do this time
        }
    
        /**
         * The Static initializer constructs the instance at class
         * loading time; this is to simulate a more involved
         * construction process (it it were really simple, you'd just
         * use an initializer)
         */
        static {
            instance = new Singleton();
        }
    
        /** Static 'instance' method */
        public static Singleton getInstance() {
            return instance;
        }
    
        // other methods protected by singleton-ness would be here...
        /** A simple demo method */
        public String demoMethod() {
            return "demo";
        }
    }
    

    Note that the method of using “lazy evaluation” in the getInstance() method (which is advocated in Design Patterns), is not necessary in Java because Java already uses “lazy loading.” Your singleton class will probably not get loaded unless its getInstance() is called, so there is no point in trying to defer the singleton construction until it’s needed by having getInstance() test the singleton variable for null and creating the singleton there.

    Using this class is equally simple: simply get and retain the reference, and invoke methods on it:

    public class SingletonDemo {
        public static void main(String[] args) {
            Singleton tmp = Singleton.getInstance();
            tmp.demoMethod();
        }
    }
    

    Some commentators believe that a singleton should also provide a public final clone() method that just throws an exception, to avoid subclasses that “cheat” and clone() the singleton. However, it is clear that a class with only a private constructor cannot be subclassed, so this paranoia does not appear to be necessary.

    0 讨论(0)
  • 2021-02-01 06:23

    For that you need to use singleton pattern, I am just posting a demo code for that that may useful for your understanding.

    E.g: If I want only one object for this Connect class:

    public final class Connect {
    
        private Connect() {}
    
        private volatile static Connect connect = null;
    
        public static Connect getinstance() {
            if(connect == null) {
                synchronized (Connect.class) {
                    connect = new Connect();
                }
            }
            return connect;
        }
    }
    

    Here the constructor is private, so no one can use new keyword to make a new instance.

    0 讨论(0)
  • 2021-02-01 06:24
    class A{
        private A(){
    
        }
        public static A creator(A obj){
            A ob=new A();
            return ob;
        }
        void test(){
            System.out.println("The method is called");
        }
    }
    
    class Demo{
        public static void main(String[] args){
            A ob=null;
            ob=A.creator(ob);
            ob.test();
        }
    }
    
    0 讨论(0)
  • 2021-02-01 06:25

    You want the Singleton pattern. There is an excellent discussion of how to implement this properly. If you do this right, there will only ever be one instance of the class.

    Essentially what you are going to do is create a class, hold a single instantiated object of that class at the static level, and provide a static accessor to get it (getInstance() or similar). Make the constructor final so people can't create their own instances out of the blue. That link above has plenty of great advice on how to do this.

    0 讨论(0)
  • 2021-02-01 06:25

    I prefer lazy singleton class, which overrides readResolve method.

    For Serializable and Externalizable classes, the readResolve method allows a class to replace/resolve the object read from the stream before it is returned to the caller. By implementing the readResolve method, a class can directly control the types and instances of its own instances being deserialized.

    Lazy singleton using /Initialization-on-demand_holder_idiom:

    public final class  LazySingleton {
        private LazySingleton() {}
        public static LazySingleton getInstance() {
            return LazyHolder.INSTANCE;
        }
        private static class LazyHolder {
            private static final LazySingleton INSTANCE = new LazySingleton();
        }
        private Object readResolve()  {
            return LazyHolder.INSTANCE;
        }
    }
    

    Key notes:

    1. final keyword prohibits extension of this class by sub-classing
    2. private constructor prohibits direct object creation with new operator in caller classes
    3. readResolve prohibits creation of multiple instances of class during object de-serialization
    0 讨论(0)
提交回复
热议问题