oo大原则之单一职责原则

单一职责原则(SRP,Single Responsibility Principle)强调的是职责的分离,在某种程度上对职责的理解,构成了不同类之间耦合关系的设计关键,因此单一职责原则或多或少成为设计过程中一个必须考虑的基础性原则。其核心的思想是:

    一个类,最好只做一件事,只有一个引起它变化的原因。

一个违背SRP原则的设计实例:对数据库的操作和用户权限判别封装在一个类中实现,如:

public   void  Add()
{
    
if (GetPermission(id.permission) == " CanAdd " )
    {
        Console.WriteLine(
" CanAdd " );
    }
}

 

显然这样的实现是很僵化的,一旦权限设置的规则发生变化,则所有的方法都必须跟着改变,这是不可想象的事情。我们应该把权限判断的职责与数据库操作的职责分开。P可以通过实现一个Proxy模式来解决职责交叉的问题

     public   interface  IDBAction
    {
        
void  Add();
    }
    
public   class  DBManager: IDBAction
    {
        
#region  IDBAction 成员

    
public   void  Add()
        {
            Console.WriteLine(
" DBManager.Add() " );
        }

        
#endregion
        
public  DBManager()
        {
            
        }

    }
    
public   class  DBManagerProxy : IDBAction
    {
        
#region  私有成员
    
private  IDBAction dbManager;
        
#endregion
        
public  DBManagerProxy(IDBAction dbAction)
        {
            dbManager 
=  dbAction;
        }
        
public   string  GetPermission( string  id)
        {
            
return  id;
        }
        
#region  IDBAction 成员

        
public   void  Add()
        {
            
if  (GetPermission( " CanAdd " ==   " CanAdd " )
            {
                dbManager.Add();
            }
        }

        
#endregion
    }
    
class  DBClient
    {
        
static   void  Main( string [] args)
        {
            IDBAction DBManager 
=   new  DBManagerProxy( new  DBManager());
            DBManager.Add();
        }
    }

关于单一职责原则的建议:

  • 一个类只有一个引起它变化的原因,否则就应当考虑重构
  • SRP由引起变化的原因决定,而不是由功能职责决定。虽然职责常常是引起变化的轴线,但是有时却未必,应该审时度势。
  • 测试驱动开发,有助于实现合理分离功能的设计。
  • 可以通过Facade模式和Proxy模式进行职责分离。

参考文献:你必须知道的.NET

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值