`
gamix
  • 浏览: 1857 次
  • 来自: ...
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

如此使用单例模式!

阅读更多
最近拿到一个项目,大致扫了一下,发现大多数的代码都是如下的结构:

public class User {
	private String userName;
	
	public String getUserName() {
		return userName;
	}
	
	public void setUserName(String userName) {
		this.userName = userName;
	}
}

public class UserRule { 
	private static UserRule instance = null; 
	
	public static UserRule getInstance() { 
		if (instance == null) { 
			instance = new UserRule(); 
		} 
		return instance; 
	}
	
	public User AddUser(String userName) {
		// add a new user operations
	}
} 


先不说问题,来看看这样做的一些可取之处:
1、设计简单。系统的设计在这样的结构下其实就是贫血类的设计,剩下的就是在Rule类中增加相应的方法。
2、各个模块的开发可以同时进行。各人根据要求定义好模块相应的类,剩下的就是缺啥补啥了。

然后说问题:
1、首先该单例实现就有问题了,这样的实现并不能保证线程安全。不过好在其实这个UserRule本身也没有字段之类的东西,不单例其实也没多大影响。所以我想这个单例丢在这里估计只是为了写代码的时候方便点。
2、这种做法应对需求变化的结果就是不断的在UserRule中添加新的满足需求的方法,最后天知道这个方法到底干嘛的。
3、我想这样的系统应该性能上很差了,可奇怪客户用到现在居然没一点性能上的反馈。不过性能这块只是我的一个感觉,还没有对这样的系统做一个压力测试,无法提供实际情况。

不知道还有没有其他的缺点,欢迎各位来分析分析。
分享到:
评论
28 楼 czqyr 2009-01-22  
这样不是单例吗?那单例应该是什么样子呢?
27 楼 amonlei 2009-01-22  
longtengsoft 写道
如果在多线程的环境中我想会出现性能问题和安全问题.
很容易出现竞争问题,而且如果一旦出现竞争就会出现数据丢失的风险!

数据丢失会有,性能如何有?
26 楼 amonlei 2009-01-22  
luanma 写道
    public static [b]synchronized[/b] UserRule getInstance() {   
        if (instance == null) {   
            instance = new UserRule();   
        }   
        return instance;   
    }  


多线程的情况下,加上synchronized就可以了。


基本,不需要
25 楼 lcllcl987 2009-01-22  
这是单例吗?这能做到单例吗?
我在任何地方如果:
UserRule userRule = new UserRule();
你如何保证UserRule只有一个instance?
连单例都没搞明白, 就别瞎折腾了。
24 楼 LargeBean 2009-01-22  
zlt2000 写道
其实直接这样就可以了
public class UserRule {    
    private static UserRule instance = new UserRule();
       
    public static UserRule getInstance() {    
        return instance;    
    }   
}



需要
     private UserRule(){}
23 楼 阳光雨露 2009-01-22  
单例前面好像加一个子synchronized就行了,这样就线程安全了呀
22 楼 arthurln 2009-01-22  
这年头都有DI了,还有人自己写Singleton
21 楼 zlt2000 2009-01-22  
其实直接这样就可以了
public class UserRule {    
    private static UserRule instance = new UserRule();
       
    public static UserRule getInstance() {    
        return instance;    
    }   
}
20 楼 narry 2009-01-22  
public class User {  
    private String userName;  
      
    public String getUserName() {  
        return userName;  
    }  
      
    public void setUserName(String userName) {  
        this.userName = userName;  
    }  
}  
 
public class UserRule {   
   private UserRule (){}
       
   static class SingletonHolder {
    static volatile UserRule userRule =   new UserRule();
  }

    public static UserRule getInstance() {   
         return SingletonHolder.userRule;
    }  
      
    public User AddUser(String userName) {  
        // add a new user operations  
    }  
}  
19 楼 longtengsoft 2009-01-22  
如果在多线程的环境中我想会出现性能问题和安全问题.
很容易出现竞争问题,而且如果一旦出现竞争就会出现数据丢失的风险!
18 楼 agiha 2009-01-22  
luanma 写道
    public static [b]synchronized[/b] UserRule getInstance() {   
        if (instance == null) {   
            instance = new UserRule();   
        }   
        return instance;   
    }  


多线程的情况下,加上synchronized就可以了。



你这个浪费性能。还是你楼上的实现好。
17 楼 edi 2009-01-22  
skzr.org 写道
评定再次没事找事的帖子,鉴定完毕

,浪费时间,看了这么无聊的帖子。
16 楼 luanma 2009-01-22  
zozoh 写道
#     public static UserRule getIn<script type="text/javascript" src="http://www.iteye.com/javascripts/tinymce/themes/advanced/langs/zh.js"></script>stance() {  
#         if (instance == null) {  
#             instance<script type="text/javascript" src="http://www.iteye.com/javascripts/tinymce/plugins/javaeye/langs/zh.js"></script> = new UserRule();  
#         }  
#         return instance;  
#     }

应该写成
public static UserRule getInstance() {   
	if (instance == null) {
		synchronized(UserRule.class){
			if (instance == null){
				instance = new UserRule();						
			}
		}
	}   
	return instance;   
}

以保证多个线程访问的安全



这个代码看上去也忒复杂了,而且有线程风险,性能上没有提高。
15 楼 luanma 2009-01-22  
    private UserRule() {}
    public static [b]synchronized[/b] UserRule getInstance() {   
        if (instance == null) {   
            instance = new UserRule();   
        }   
        return instance;   
    }  


多线程的情况下,加上synchronized就可以了。

哦,还有就是构造函数一定要定义为 private。
14 楼 skzr.org 2009-01-22  
评定再次没事找事的帖子,鉴定完毕
13 楼 amonlei 2009-01-21  
怎么就看出性能问题了?我还觉得性能提高了捏,虽然只是一点点
12 楼 xmpp 2009-01-21  
除单例实现有点问题,其它很好啊。。简洁到楼上的每个人都能看得懂。
11 楼 whaosoft 2009-01-21  
晕 这是做的什么呀
10 楼 wangchao_0625 2009-01-21  
在UserRule类中
应有
private UserRule(){}


顺便问一下lz,什么情景下用到的单例模式
9 楼 zozoh 2009-01-21  
#     public static UserRule getInstance() {  
#         if (instance == null) {  
#             instance = new UserRule();  
#         }  
#         return instance;  
#     }

应该写成
public static UserRule getInstance() {  
if (instance == null) {
synchronized(UserRule.class){
if (instance == null){
instance = new UserRule();
}
}
}  
return instance;  
}

以保证多个线程访问的安全

相关推荐

    单例模式.ppt

    【单例模式】是一种常用的软件设计模式,其主要目的是确保一个类只有一个实例,并提供一个...单例模式虽然方便,但过度使用可能导致设计复杂度增加,不易测试,以及违反了单一职责原则,因此在实际应用中应谨慎使用。

    C++中的单例模式及按需释放模型

    在描述中提到,传统的单例模式实现往往在程序运行结束时才会释放单例对象,即使在具有垃圾回收机制的语言如C#中也是如此。这种情况下,当系统切换到不使用特定单例对象的功能模块时,这些不再需要的单例仍然占用内存...

    2 单例模式-MOOC课程内容.pdf

    - 单例模式3使用了内部类来实现单例。SingletonHolder是一个私有的静态内部类,在Singleton类被加载时,SingletonHolder不会被加载,因此不会立即实例化Singleton。当getInstance()方法首次被调用时,...

    单例模式七种写法_转

    在软件工程领域中,单例模式是一种广泛使用的创建型设计模式,其目的是确保一个类只有一个实例,并提供一个全局访问点。单例模式在多线程环境下使用时,若不采取适当的同步措施,可能会导致创建多个实例,破坏模式的...

    JavaScript编程的单例设计模讲解

    不仅如此,单例模式在许多著名的JavaScript类库中也有应用,例如underscore和jQuery,可以说它们本身就是单例模式的一个实例。 通过单例模式,我们可以把相关的代码组织在一起,便于维护和重用。在大型项目中,通过...

    java设计模式之单例模式

    单例模式是java设计模式中的一种常用的创建型模式,是我们日常开发中最常使用的一种设计模式。它的主要作用是保证系统中一个类只有一个实例。单例模式可以被用来封装一些工具类,例如数据库连接等。 单例模式的定义...

    php单例模式的简单实现方法

    尽管如此,单例模式在PHP中的使用仍然有其特有的优势,比如减少new操作的资源消耗,便于调试和集中控制等。 具体到PHP实现单例的代码如下: ```php class Example { // 保存实例在此静态私有属性中 private ...

    Java多线程下的单例模式参考

    在Java编程中,单例模式是一种常见的设计模式,它保证一个类只有一个实例,并提供一个全局访问点。在多线程环境中,实现单例模式时需要特别注意线程安全问题,以防止在并发访问时产生多个实例。本篇将探讨如何在Java...

    PHP中数据库单例模式的实现代码分享

    尽管如此,单例模式在PHP中仍然有其用途,特别是在数据库操作和全局配置方面。 数据库单例模式在PHP中尤其重要,因为在Web应用中,数据库操作非常频繁。使用单例模式可以避免每次数据库操作时重复创建数据库连接,...

    鸡肋的PHP单例模式应用详解

    尽管如此,在实际应用中,特别是在涉及数据库操作的Web应用中,单例模式仍然具有其重要性。例如,在数据库操作中,可以使用单例模式来确保应用中只有一个数据库连接实例,这可以有效避免重复创建多个数据库连接所...

    js代码-js单例模式

    JavaScript中的单例模式是一种设计模式,它确保一个类只有一个实例,并提供一个全局访问点来获取这个实例。在软件工程中,单例模式被广泛应用,特别是在需要频繁实例化然后销毁的对象,或者创建对象需要消耗大量资源...

    通过示例分析Swift单例模式

    单例模式是软件设计模式中的一种,用于保证一个类只有一个实例,并提供一个全局访问点。在Swift编程语言中,有多种实现单例模式的方法。以下是根据标题和描述中提到的三种方式的详细解释: 1. **全局变量**: 在...

    java设计模式

    7.2 单例模式的定义 7.3 单例模式的应用 7.4 单例模式的扩展 7.5 最佳实践 第8章 工厂方法模式 8.1 女娲造人的故事 8.2 工厂方法模式的定义 8.3 工厂方法模式的应用 8.3.1 工厂方法模式的优点 8.3.2 工厂方法模式的...

    Java多线程编程环境中单例模式的实现

    单例模式是一种常用的软件设计模式,它确保一个类只有一个实例,并提供一个全局访问点。在Java中,单例模式的应用非常广泛,特别是在资源管理、日志记录、数据库连接等方面。然而,在多线程环境中实现单例模式时,...

    【BAT必备】设计模式面试题

    - **解析**:单例模式是一种创建型设计模式,其目的是确保一个类只有一个实例,并提供一个全局访问点。这种模式常用于管理资源密集型的对象,如数据库连接、线程池等。通过确保此类对象在整个系统中只存在一个实例,...

    常用设计模式及Java程序 pdf

    设计模式如工厂模式可以帮助创建复杂对象实例,单例模式确保类只有一个实例存在。 - **管理对象间的交互**:例如观察者模式允许对象之间动态地定义一对多依赖关系,适配器模式则用于让不兼容的接口协同工作。 - **...

    Delphi设计模式

    本书可能并未涵盖所有设计模式,但即便如此,它依然提供了许多关键模式的解释和示例,如单例模式、工厂模式、观察者模式、装饰器模式、代理模式、建造者模式等。以下是对这些模式的详细描述: 1. **单例模式**:...

    P2P-chat:此 P2P 聊天已实现为群聊。 单例模式、观察者模式和 MVC 模式

    #P2P 聊天 此 P2P 聊天已实现为群聊。 聊天是这样实现的: 您必须首先在同一本地... 具体来说,这个项目使用了Singleton 、 Observer和MVC 模式。 ##技术Java ##Bibliography Head First 设计模式 - O'Reilly Media

Global site tag (gtag.js) - Google Analytics