time 
设为首页】【收藏本站

白小姐39开奖结果: 白小姐彩图

当前位置: 白小姐彩图 > JAVA > Java高级 > 设计模式 > Java设计模式分析之单例(Singleton)

Java设计模式分析之单例(Singleton)

时间:2014-06-18 11:17 点击:4768次 字体:[ ]




白小姐彩图 www.5vq5o.cn 写软件的时候经常需要用到打印日志功能,可以帮助你调试和定位问题,项目上线后还可以帮助你分析数据。但是Java原生带有的System.out.println()方法却很少在真正的项目开发中使用,甚至像findbugs等代码检查工具还会认为使用System.out.println()是一个bug。

为什么作为Java新手神器的System.out.println(),到了真正项目开发当中会被唾弃呢?其实只要细细分析,你就会发现它的很多弊端。比如不可控制,所有的日志都会在项目上线后照常打印,从而降低运行效率;又或者不能将日志记录到本地文件,一旦打印被清除,日志将再也找不回来;再或者打印的内容没有Tag区分,你将很难辨别这一行日志是在哪个类里打印的。

你的leader也不是傻瓜,用System.out.println()的各项弊端他也清清楚楚,因此他今天给你的任务就是制作一个日志工具类,来提供更好的日志功能。不过你的leader人还不错,并没让你一开始就实现一个具备各项功能的牛逼日志工具类,只需要一个能够控制打印级别的日志工具就好。

这个需求对你来说并不难,你立刻就开始动手编写了,并很快完成了第一个版本:

  1. public class LogUtil {  
  2.  
  3.     public final int DEGUB = 0;  
  4.  
  5.     public final int INFO = 1;  
  6.  
  7.     public final int ERROR = 2;  
  8.  
  9.     public final int NOTHING = 3;  
  10.  
  11.     public int level = DEGUB;  
  12.  
  13.     public void debug(String msg) {  
  14.         if (DEGUB >= level) {  
  15.             System.out.println(msg);  
  16.         }  
  17.     }  
  18.  
  19.     public void info(String msg) {  
  20.         if (INFO >= level) {  
  21.             System.out.println(msg);  
  22.         }  
  23.     }  
  24.  
  25.     public void error(String msg) {  
  26.         if (ERROR >= level) {  
  27.             System.out.println(msg);  
  28.         }  
  29.     }  
  30.  
  31. }  

通过这个类来打印日志,只需要控制level的级别,就可以自由地控制打印的内容。比如现在项目处于开发阶段,就将level设置为DEBUG,这样所有的日志信息都会被打印。而项目如果上线了,可以把level设置为INFO,这样就只能看到INFO及以上级别的日志打印。如果你只想看到错误日志,就可以把level设置为ERROR。而如果你开发的项目是客户端版本,不想让任何日志打印出来,可以将level设置为NOTHING。打印的时候只需要调用:

 

  1. new LogUtil().debug("Hello World"); 

你迫不及待地将这个工具介绍给你的leader,你的leader听完你的介绍后说:“好样的,今后大伙都用你写的这个工具来打印日志了!”

可是没过多久,你的leader找到你来反馈问题了。他说虽然这个工具好用,可是打印这种事情是不区分对象的,这里每次需要打印日志的时候都需要new出一个新的LogUtil,太占用内存了,希望你可以将这个工具改成用单例模式实现。

你认为你的leader说的很有道理,而且你也正想趁这个机会练习使用一下设计模式,于是你写出了如下的代码:

  1. public class LogUtil {  
  2.  
  3.     private static LogUtil sLogUtil;  
  4.  
  5.     public final int DEGUB = 0;  
  6.  
  7.     public final int INFO = 1;  
  8.  
  9.     public final int ERROR = 2;  
  10.  
  11.     public final int NOTHING = 3;  
  12.  
  13.     public int level = DEGUB;  
  14.  
  15.     private LogUtil() {  
  16.     }  
  17.  
  18.     public static LogUtil getInstance() {  
  19.         if (sLogUtil == null) {  
  20.             sLogUtil = new LogUtil();  
  21.         }  
  22.         return sLogUtil;  
  23.     }  
  24.  
  25.     public void debug(String msg) {  
  26.         if (DEGUB >= level) {  
  27.             System.out.println(msg);  
  28.         }  
  29.     }  
  30.  
  31.     public void info(String msg) {  
  32.         if (INFO >= level) {  
  33.             System.out.println(msg);  
  34.         }  
  35.     }  
  36.  
  37.     public void error(String msg) {  
  38.         if (ERROR >= level) {  
  39.             System.out.println(msg);  
  40.         }  
  41.     }  
  42.  
  43. }  



本文地址 : //www.5vq5o.cn/plus/view-215088-1.html
标签: java 设计模式 Singleton 单例
------分隔线----------------------------
最新评论 查看所有评论
发表评论 查看所有评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
验证码:

  • 您要明白的是,如果按照上海市的人口基数2500万计算的话,就算有100万的服务人员,平均每人也要保障25个人的预约服务.人要理性 2019-04-06
  • 回复@海之宁:你的卡点就在于不知道分配既涉及消费资料有涉及生产资料。 2019-04-06
  • 赵雅芝联合“我·爱我 女性健康工程”为乳腺健康共发声 2019-04-03
  • 合肥市庐阳中学启动“教师成长工程” 2019-04-01
  • 中年不发福!51岁景岗山紧身衣秀健硕身材 2019-04-01
  • 炒房炒房,炒了北京炒西安,炒了天堂炒人间,何时休?限价现价叫人害怕。 2019-03-27
  • “5·15”全国公安机关打击和防范经济犯罪宣传日 2019-03-27
  • 穿拖鞋开车酿成追尾事故 2019-03-20
  • 重庆市永川区:“1+8+X”模式探索基层人民调解新路子 2019-03-20
  • 巢湖市第三届少儿器乐比赛圆满落幕 2019-02-15
  • Valentino 2017秋冬高级定制大秀 2018-09-08
  • 中国经济充当了世界经济发展的火车头。但是,作为世界经济火车头的中国,在世界主要经济体股市都走牛的情况下,为何熊途漫漫?这种不正常的现象,背后是我们资本市场的投融 2018-07-14
  • 别空谈,说说看,这个“简单的逻辑关系”是什么关系? 2018-07-13
  • “讲课带着泥土味,我们都爱听” 2018-07-13
  • 习近平:绿水青山就是金山银山 2018-07-12
  • 174| 634| 791| 207| 294| 554| 563| 652| 11| 795|