狠忙一个月,今晚终于要上线了.想来,改了很多东西,也学到了不少.就把这里当做一个写笔记的地方吧,也许还会对一些人有所帮助.如果有时间我会继续在这里写一下总结的.还望大家多多批评指正!
这次想谈谈他的数据访问层,没有修改的.
废话少说了.在分析以前,首先要懂得接口和抽象类的区别和联系.抽象方法是必须实现的方法。
抽象类和接口的相似处:
抽象类和接口都包含可以由派生类继承的成员。接口和抽象类都不能直接实例化,但可以声明它们的变量。如果这样做,就可以使用多态性把继承这两种类型的对象指定给它们的变量。接着通过这些变量来使用这些类型的成员,但不能直接访问派生对象的其它成员。
抽象类和接口的区别:
派生类只能继承一个基类,即只能直接继承一个抽象类(但可以用一个继承链包含多个抽象类)。相反,类可以使用任意多个接口。
抽象类可以拥有抽象成员和非抽象成员。
抽象成员:没有代码体,且必须在派生类中执行,否则派生类本身必须也是抽象的。
非抽象成员:拥有代码体,也可以是虚拟的,这样就可以在派生类中重写。
接口成员必须都在使用接口的类上执行——它们没有代码体。
接口成员被定义为公共的,但抽象类的成员也可以是私有的受保护的、内部的或受保护的内部成员(其中受保护的内部成员只能在应用程序的代码或派生类中访问)。此外,接口不能包含字段、构造函数、析构函数、静态成员或常量。
了解了这些要不如正题了.在petshop中,他是定义了接口,在sqldataprovider又继承的,这点在我的petshop系列中可以看到.主要说cs中的。CommunityServerComponents中的Provider中定义抽象类并事例化指向SqlDataProvider的类.
在其他对实体的操作类中引用:
举例任意一个类 Groups:
CommonDataProvider dp = CommonDataProvider.Instance();
group.GroupID = dp.CreateUpdateDeleteGroup(group, DataProviderAction.Create);
CommonDataProvider :
public static CommonDataProvider Instance() {
return _defaultInstance;
}
private static void CreateDefaultCommonProvider()
{
_defaultInstance = DataProviders.CreateInstance(sqlForumsProvider) as CommonDataProvider;
....} // 指向SqlDataProvider中的饿sqlForumsProvider
如上,sqlForumsProvider继承抽象类CommonDataProvider,在这里CommonDataProvider.Instance();
事例化并指向他,就可以引用.
而在petshop中接口充当了抽象类的角色,数据层是继承的接口,在bbl中是返回的事例化的接口.而在cs中返回的是事例化的抽象类.据此看来,在做大型项目时还是应该用抽象类来做构架.
CommonDataProvider 是实体与数据层的交接,说明要在数据库中操作的类和给类赋值.