分分5分快3APP下载_在面试通过通过单例模式来展示实例

  • 时间:
  • 浏览:1

    在面试初级和高级开发时,一般会问设计模式的什么的什么的问题。通常会让写下单例模式的实现措施 ,肯能让结合项目,说下用过的设计模式,在本文里,就将讲述单例模式的多种写法,以此告诉大伙儿如可在面试中展示实力。

    肯能在项目里,多个运行实例回会从同有一一八个配置文件里读取发送邮件的列表,那末 大伙儿就都能够用单例模式来创建本身读配置文件的类。大伙儿先来看下单多应用程序 请况下单例模式的写法。

1	public class MailListReader {
2	    private static MailListReader reader = null;
3	    private MailListReader(){}//构造函数私有
4	    //向内部开放有一一八个公有的静态函数来提供对象
5	    public static MailListReader getInstance() {
6	        if(reader == null)
7	           reader = new MailListReader();
8	        return reader;
9	    } 
10	    //提供邮件列表的措施

11	     List<String> provideList()
12	     { 省略提供邮件列表的代码 }
13	}

    在上述的代码里,大伙儿都能够看了实现单例模式的两大每种,第一,第3行提供的构造函数是私有的,那我内部代码就无法通过调用构造函数来创建MailListReader对象。第二,会通过诸如第5行的代码向外界提供read实例,但会 在本身措施 里,那末 当read对象为null时,才创建并返回该对象。

    肯能多多应用程序 是运行在单多应用程序 环境下,那末 上述实现措施 实在能满足单例的需求,但在多多应用程序 的请况下,时不时跳出多个多应用程序 同时调用getInstance措施 ,那末 就无法保证单例了。

    实在,大伙儿都能够通过加synchronized来保证多多应用程序 场景里那末 有一一八个MailListReader对象被创建,代码改写如下。      

1	public class MailListReader {
2	    private static MailListReader reader = null;
3	    private MailListReader(){}//构造函数私有
4	     public static MailListReader getInstance() {
5	        Synchronized(MailListReader.class){
6	            if(reader == null)
7	               reader = new MailListReader();
8	        } 
9	        return reader;
10	    } 
11	    //省略提供邮件列表的措施

 
12	}

    大伙儿把第7行的new的动作包含在第5行的Synchronized代码块里,那我本身new代码在同有一一八个时间段里那末 被有一一八个多应用程序 调用,多个多应用程序 同时到来回会时不时跳出排队的请况,那我时延但会 低下。但会 但会 ,大伙儿还都能够通过如下的“双重检查”的措施 来兼顾多应用程序 安全和性能。      

1	public class MailListReader {
2	    private static MailListReader reader = null;
3	    private MailListReader(){}//构造函数私有
4	     public static MailListReader getInstance() {
5	        if(reader== null){
6	           synchronized (MailListReader.class){
7	             if(reader == null){
8	                 reader = new MailListReader ();
9	              }
10	            }
11	         }
12	         return reader;
13	    } 
14	    //省略提供邮件列表的措施

 
15	}

    大伙儿在getInstance措施 里的第5和第7行有一一八个地方通过有一一八个if来检查,这要是“双重检查”。这里大伙儿在加锁前做了有一一八个是否为空的判断。通过本身判断大伙儿能看了了是否有其它多应用程序 得到reader对象,那我就都能够避免第6行的锁对象的操作,从而能避免多多应用程序 排队的请况。

    大伙儿完整版都能够通过你在项目中的实际案例,用单例模式来说明个人对设计模式的理解,但会 都能够由浅到深地时不时讲到“双重检查”措施 ,那我面试官就能知道,你不仅知道本身模式最基本的写法,还知道掌握如可在多多应用程序 中应用的高级技能,更为重要的是,大伙儿能通过实际案例,向面试官说明你不仅知道理论,而会应用。  

    此外,在讲完上述回答后,大伙儿都能够再往如下有一一八个方向扩展,第一都能够继续说,除了单例模式外,在大伙儿项目里,还用到其它设计模式,但会 再结合案例说明,肯能再围绕刚才单例模式里提到的多应用程序 安全,再扩展出去说,除了在单例模式外,在大伙儿项目里回会考虑其它的多应用程序 并发因素,比如对但会 多多应用程序 间都时要用的键值对缓存,大伙儿是装在ConcurrentHashMap,(肯能引出Lock,ThreadLocal等多应用程序 相关话题),但会 再展开,那我就都能够继续在个人熟悉的范围内回答什么的什么的问题。

    大伙儿都能够想象下,肯能初级开发一方面照此说辞,很好地证明了设计模式方面的能力,个人面再通过准备加引导技术,不仅都能够展示基础技能 ,更能有效地展示诸如底层代码等技能,这对成功通过面试大有好处。