您的位置:首页 > 运维架构 > 网站架构

你必须要知道的架构知识~第二章 代码是否面向对象,要看你的继承怎么用

2012-03-01 00:10 393 查看
儿子今天玩的有点晚了,所以今天的文章写的也有点晚了,呵呵!

从标题上可以知道,今天主要来讲继承,事实上是“继承”在项目架构中有没有用,如果有用,那应该如何去用的问题,一说到继承就肯定会说两个东西,基类(父类)和派生类(子类),在架构中,我们这样定义一个基类:当很多类型有相同的属性或相似的行为时,我们应该把它们的公共部分提取到一个新的类型中,这个类我们称为它们的基类,基类在架构中多为抽象类,即本身只定义和简单的实现,具体的调用和复杂逻辑由它的子类去实现和复写。

在N层架构中,UI层,Service层及Data层都应该有自己的基类,而基类的主要作用就是将通用的部分进行抽象,这样在功能扩展,代码维护等方面都会变得方便,当然也更符合面向对象的原则。

UI层的基类:

/// <summary>
/// Controller基ù类à
/// </summary>
public class BaseController : System.Web.Mvc.Controller
{
/// <summary>
/// 数y据Y统3一?操ù作÷对?象ó
/// </summary>
protected IDataContext _db { get; set; }
/// <summary>
/// 用?户§操ù作÷权¨限T
/// </summary>
protected int UserOperatorRole { get; set; }
/// <summary>
/// 当±前°登?陆?的?用?户§ID
/// </summary>
protected long Current_UserID { get; set; }
}
这是我的测试代码,我就把service层省去,下面是Data层的抽象:


/// <summary>
/// 数y据Y库a基ù类à
/// </summary>
public abstract class DataBase
{
/// <summary>
/// 数y据Y库a对?象ó
/// </summary>
protected DataContext _db = new DataContext();
/// <summary>
/// 统3一?提á交?动ˉ作÷
/// </summary>
protected virtual void SubmitChanges()
{

try
{
_db.SubmitChanges();
}
catch (System.Data.Linq.ChangeConflictException ex)
{
throw;
}
}
}


在使用它们时,通过是用一个具体功能类去继承它们,以便来使用它们公开的属性和方法,如下:





我们看到上面的HomeController类型继承了BaseController类型,它的构造方法提供了带参和空参的方法重载,这样写的好处是更好的实现代码的松耦合,提供代码的稳定性及可测试性,即,当我们使用空参构造类实例时,它会建立默认的数据访问对象,而如果我们希望建立一个“测试”的内存数据对象时,可以使用第二个构造方式进行建立对象。

 

从本篇文章开始,将会出现大量的代码,以便去说明问题,希望符合大家的胃口。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: