天天看点

加载、实例化-单例/单体模式(Singleton)-by小雨

/ 这个单例类在自身被加载时instance会被实例化,即便加载器是静态的。因此,对于资源密集,配置开销较大的单体更合理的做法是将实例化(new)推迟到使用它的时候。即惰性加载(Lazy

在改章节中,我们主要介绍加载、实例化-的内容,自我感觉有个不错的建议和大家分享下

    首先,单例式模是象对的创立式模之一,此外还括包厂工式模。单例式模的三个特色:

1,该类只有一个实例

2,该类自行创立该实例(在该类部内创立自身的实例象对)

3,向全部统系公然这个实例接口

Java中大概是这个子样

?

1

2

3

4

5

6

7

8

9

10

11

12

13

<code>class</code> 

<code>Singleton {</code>

<code>    </code> 

<code>    </code>

<code>//私有,静态的类自身实例</code>

<code>private</code> 

<code>static</code> 

<code>Singleton instance =</code>

<code>new</code> 

<code>Singleton();</code>

<code>//私有的造构子(造构器,造构函数,造构法方)</code>

<code>Singleton(){}</code>

<code>//公然,静态的厂工法方</code>

<code>public</code> 

<code>Singleton getInstance() {</code>

<code>        </code>

<code>return</code> 

<code>instance;</code>

<code>}</code>

    应用时

<code>Singleton obj = Singleton.getInstance();</code>

这个单例类在自身被加载时instance会被实例化,即便加载器是静态的。因此,对于资源麋集,置配开销大较的单体更理合的做法是将实例化(new)推迟到应用它的时候。即惰性加载(Lazy loading),它常用于那些必须加载大批数据的单体。改修下

14

15

<code>LazySingleton {</code>

<code>//初始为null,暂不实例化</code>

<code>LazySingleton instance =</code>

<code>null</code>

<code>;</code>

<code>LazySingleton(){}</code>

<code>//公然,静态的厂工法方,须要应用时才去创立该单体</code>

<code>LazySingleton getInstance() {</code>

<code>if</code>

<code>( instance ==</code>

<code>null</code> 

<code>) {</code>

<code>            </code>

<code>instance =</code>

<code>LazySingleton();</code>

<code>}  </code>

    应用式方同上。

单例式模是Javascript最基本,最用有的式模之一。它供提了一种将码代组织为一个逻辑单元的手腕,这个逻辑单元中的码代通过单一的变量停止问访。

单体在Javascipt中有多许用途,可以用来分别命名空间,以增加全局变量的泛滥。还可以用在分支术技顶用来处置各浏览器的差异。

Javascript中单例式模的实现式方有多种,每一种都有自身的点优或缺陷。

    1,象对直接量实现最基本,最单简的单体

<code>var</code> 

<code>Singleton = {</code>

<code>attr1 : 1,</code>

<code>attr2 :</code>

<code>'hello'</code>

<code>,</code>

<code>method1 :</code>

<code>function</code>

<code>(){alert(</code>

<code>this</code>

<code>.attr2);},</code>

<code>method2 :</code>

<code>(arg){}</code>

    种这式方中,象对有所成员都通过Singleton加点号问访。有所成员是公然的,没有私有的。在执行到变量Singleton时,会加载(实例化)自身,即非惰性加载。

此外method1用this问访单体的其它成员会存在一些险风,因为method1的上下文不是老是指向Singleton象对。

比如当把method1作为事件监听器时,this可能指向的是dom素元,这时可能会提示undefined。

    2,闭包实现私有成员的单体

<code>Singleton =</code>

<code>(){</code>

<code>attr = 1, fn =</code>

<code>(){};</code>

<code>{</code>

<code>method :</code>

<code>(){ fn(); },</code>

<code>getAttr :</code>

<code>attr; }       </code>

<code>}; </code>

<code>}();</code>

    种这式方中var定义私有的成员属性attr,法方fn,然后返回一个公然的接口method和getAttr。后今改修实现时,接口法方method和getAttr变不,只要改修私有的attr和fn的体具实现。应用如下

<code>Singleton.method();</code>

<code>Singleton.getAttr();</code>

    3,闭包实现私有成员的惰性实例化单体

<code>LazySingleton =</code>

<code>obj = {</code>

<code>attr; }</code>

<code>};</code>

<code>function</code> 

<code>init(){</code>

<code>obj;</code>

<code>{getInstace: init};</code>

    实用合场下面已提到:对于那些必须加载大批数据的单体直到须要应用它的时候才实例化。应用式方是这样的

<code>LazySingleton.getInstance().method();</code>

<code>LazySingleton.getInstance().getAttr();</code>

    4,又现发另一种

<code>singleton() {</code>

<code>obj =</code>

<code>Object();</code>

<code>singleton =</code>

<code>() {</code>

    仅在第一次时会new,这个Object泛指自定义的有所类。

文章结束给大家分享下程序员的一些笑话语录:

面试官:熟悉哪种语言

应聘者:JAVA

面试官:知道什么叫类么

应聘者:我这人实在,工作努力,不知道什么叫累

面试官:知道什么是包?

应聘者:我这人实在 平常不带包 也不用公司准备了

面试官:知道什么是接口吗?

应聘者:我这个人工作认真。从来不找借口偷懒

面试官:知道什么是继承么

应聘者:我是孤儿没什么可以继承的

面试官:知道什么叫对象么?

应聘者:知道,不过我工作努力,上进心强,暂时还没有打算找对象。

面试官:知道多态么?

应聘者:知道,我很保守的。我认为让心爱的女人为了自已一时的快乐去堕胎是不道德的行为!请问这和C#有什么关系??