zoukankan      html  css  js  c++  java
  • 单例模式:Instance

    前言:
      学习面向对象程序设计的朋友应该知道,我们大多数情况下通过 new 操作来实例化对象的。对于一些仅需要一次初始化的对象来说,频繁的new操作无疑会过多浪费内存空间。基于此,单例模式便应运而生了。所谓单例,即"一次初始化,多次操作"。那么本文就介绍一下自己封装一个支持单例的类的主要步骤。

    实现单例的3个要点:

    ·静态化实例;
    ·将构造方法封装为private;
    ·对外提供一个公开的getInstance()方法。

    代码实现:

    package com.modelDesign.instance;
    
    public class Person {
        private String name;
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
        
        private Person(){
        }
        
        private static Person pp=new Person();
        public static Person getInstance(){
            return pp;
        }
        
    }

    客户端测试程序:

    package com.modelDesign.instance;
    
    public class TestPerson {
        public static void main(String[] args) {
            
            Person p1 = Person.getInstance();
            p1.setName("Jack");
            Person p2 = Person.getInstance();
            System.out.println("是否单例:"+(p1==p2));
            System.out.println(p2.getName());
            
        }
    }

    测试结果:

    补充:

      当你设计的应用涉及到多线程时,上面的代码还是有瑕疵的。由于线程与线程之间的冲突,很可能会造成多次初始化。由此,我们引入多线程的锁——Lock加以解决。
    适应多线程的单例实现:

    package com.modelDesign.instance;
    
    import java.util.concurrent.locks.Lock;
    import java.util.concurrent.locks.ReentrantLock;
    
    public class InstanceSuper {
    
        private static InstanceSuper instance;
        private static Lock lock=new ReentrantLock();
        private InstanceSuper() {
        }
        public static InstanceSuper getInstance(){
            if(instance==null){
                lock.lock();
                if(instance==null){
                    instance = new InstanceSuper();
                }
                lock.unlock();
            }
            return instance;
        }
        
    }

    注意:测试类不要包含在单例类中,因为同一个类中私有的构造方法同样可以被其他方法调用,也就是说在main()函数进行new操作时不会报错!!

  • 相关阅读:
    android.database.CursorIndexOutOfBoundsException: Index -1 requested, with a size of 3
    display:inline-block的运用
    图解单片机8位PWM、16位PWM中“位”的含义!
    UVA10006
    [置顶] CF 86D Powerful array 分块算法入门,n*sqrt(n)
    俗人解释 三维渲染 在工作过程
    HDU 4414 Finding crosses(dfs)
    Codeforces 35E Parade 扫描线 + list
    hdu 4374 单调队列
    LeetCode OJ平台Sort Colors讨论主题算法
  • 原文地址:https://www.cnblogs.com/SeaSky0606/p/4719087.html
Copyright © 2011-2022 走看看