转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/8868758
此为Java设计模式透析的拷贝版,专门为Ruby爱好者提供的,不熟悉Ruby语法的朋友请转阅 :
Java设计模式透析之 —— 单例(Singleton)
写软件的时候经常需要用到打印日志功能,可以帮助你调试和定位问题,项目上线后还可以帮助你分析数据,但是Ruby原生带有的puts方法却很少在真正的项目开发中使用。
为什么作为Ruby新手神器的puts,到了真正项目开发当中会被唾弃呢?其实只要细细分析,你就会发现它的很多弊端。比如不可控制,所有的日志都会在项目上线后照常打印,从而降低运行效率;又或者不能将日志记录到本地文件,一旦打印被清除,日志将再也找不回来;再或者打印的内容没有Tag区分,你将很难辨别这一行日志是在哪个类里打印的。
你的leader也不是傻瓜,用puts的各项弊端他也清清楚楚,因此他今天给你的任务就是制作一个日志工具类,来提供更好的日志功能。不过你的leader人还不错,并没让你一开始就实现一个具备各项功能的牛逼日志工具类,只需要一个能够控制打印级别的日志工具就好。
这个需求对你来说并不难,你立刻就开始动手编写了,并很快完成了第一个版本:
class Logger
DEBUG = 0
INFO = 1
ERROR = 2
NOTHING = 3
LEVEL = DEBUG
def debug msg
puts msg if DEBUG >= LEVEL
end
def info msg
puts msg if INFO >= LEVEL
end
def error msg
puts msg if ERROR >= LEVEL
end
end
通过这个类来打印日志,只需要控制LEVEL的级别,就可以自由地控制打印的内容。比如现在项目处于开发阶段,就将LEVEL设置为DEBUG,这样所有的日志信息都会被打印。而项目如果上线了,可以把LEVEL设置为INFO,这样就只能看到INFO及以上级别的日志打印。如果你只想看到错误日志,就可以把LEVEL设置为ERROR。而如果你开发的项目是客户端版本,不想让任何日志打印出来,可以将LEVEL设置为NOTHING。打印的时候只需要调用:
logger = Logger.new
logger.debug("Hello World")
你迫不及待地将这个工具介绍给你的leader,你的leader听完你的介绍后说:“好样的,今后大伙都用你写的这个工具来打印日志了!”
可是没过多久,你的leader找到你来反馈问题了。他说虽然这个工具好用,可是打印这种事情是不区分对象的,这里每次需要打印日志的时候都需要new出一个新的Logger,太占用内存了,希望你可以将这个工具改成用单例模式实现。
你认为你的leader说的很有道理,而且你也正想趁这个机会练习使用一下设计模式,于是你写出了如下的代码:
class Logger
private_class_method :new
DEBUG = 0
INFO = 1
ERROR = 2
NOTHING = 3
LEVEL = DEBUG
@@instance = nil
def debug msg
puts msg if DEBUG >= LEVEL
end
def info msg
puts msg if INFO >= LEVEL
end
def error msg
puts msg if ERROR >= LEVEL
end
def self.instance
@@instance = new unless @@instance
end
end
首先使用
private_class_method将Logger的
new方法私有化,这样就无法通过
new方法创建
Logger的实例了。然后使用一个静态变量
@@instance来保存实例,并提供一个公有的instance方法用于获取
Logger的实例,在这个方法里面判断如果
@@instance为nil,就new出一个新的Logger实例,否则就直接返回@@instance。这样就可以保证内存当中只会存在一个Logger的实例了。单例模式完工!这时打印日志的代码需要改成如下方式:logger = Logger.instance
logger.debug("Hello World")
你将这个版本展示给你的leader瞧,他看后笑了笑,说:“恩,不错,功能是实现了。不过在ruby上还有更简单的实现方式哦。”
只见他熟练地敲起了键盘,来向你展示更简单的单例实现方式(在最初代码基础上修改)。
require 'singleton'
class Logger
include Singleton
#省略剩余代码
end
首先从系统配置路径中引入singleton.rb这个文件,然后在Logger类里引入Singleton这个模块。OK,一切完工了!
“什么?!” 你简直不相信自己的眼睛,仅仅加入了两行代码就完成了单例模式。“可是instance方法从哪里来的呢?”
你的leader告诉你,ruby有一个模块(module)机制,在类里引入模块后,该类可以访问模块中的定义的方法。instance方法就是定义在Singleton这个模块里面的,然后在运行时将这个模块引入,Logger类就可以访问Singleton中的instance方法了。
单例:保证一个类仅有一个实例,并提供一个访问它的全局访问点。
分享到:
相关推荐
设计模式C++学习之单例模式(Singleton)
单例模式是设计模式中最常见也最简单的一种设计模式,保证了在程序中只有一个实例存在并且能全局的访问到。比如在Android实际APP 开发中用到的 账号信息对象管理, 数据库对象(SQLiteOpenHelper)等都会用到单例...
设计模式总结-模板设计模式,单例模式(singleTon)
主要介绍了Ruby设计模式编程中对单例模式的运用,讲到了包括对Singleton模块的使用,需要的朋友可以参考下
深入浅出Singleton,详细掌握单例模式
在Java应用中,单例对象能保证在一个...3、有些像交易所的核心交易引擎,控制着交易流程,如果该类可以创建多个的话,系统完全乱了,只有使用单例模式,才能保证核心交易服务器独立控制整个流程。 CSDN代码的详细解释。
设计模式系列之01-单例模式(Singleton模式),很好的资源,理论实践结合讲述,逐步更新
NULL 博文链接:https://wy649898543.iteye.com/blog/1431908
简单的单例模式举例Singleton 分为恶汉式 懒汉式
java Singleton单例模式 java Singleton单例模式
此示例展示了Qml 的单例模式(类似全局对象,只生成一次实例,可全局使用) surfsky.cnblogs.com
如:IO处理,数据库操作等,由于这些对象都要占用重要的系统资源,所以我们必须限制这些实例的创建或始终使用一个公用的实例,这就是我们今天要介绍的——单例模式(Singleton)。 使用频率高 单件模式(Singleton...
单例设计模式Singleton1
单例模式(Singleton Pattern)是 Java 中最简单的设计模式之一。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。 这种模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单个...
NULL 博文链接:https://linxingliang.iteye.com/blog/1217811
本文实例讲述了JS 设计模式之:单例模式定义与实现方法。分享给大家供大家参考,具体如下: 良好的设计模式可以显著提高代码的可读性,降低复杂度和维护成本。笔者打算通过几篇文章通俗地讲一讲常见的或者实用的设计...
4、单例模式(Singleton Pattern) 用意:仅允许生成一个对象时
本文实例讲述了JS基于设计模式中的单例模式(Singleton)实现封装对数据增删改查功能。分享给大家供大家参考,具体如下: 单例模式 单例模式的核心结构中只包含一个被称为单例的特殊类。通过单例模式可以保证系统中...
Java面向对象(高级)-- 单例(Singleton)设计模式
singleton 单例 java 详细介绍了单例模式的使用,很不错的单例模式的介绍