模仿pet shop4做了个工厂模式的简单例子,初步了解其中流程,做个总结。
一、创建项目IDAL,包含若干接口如IOrder,是有关Order的数据库操作接口。
二、创建项目sqlServerDAL,其中包含一个Order类,继承IOrder接口,具体实现该接口中声明的若干函数。
三、创建项目DALFactory,就是一个数据库接口工厂,负责根据选择的数据库类型(在web.config中获取如<add key="WebDAL" value="Com.JJHua.sqlServerDAL"/>)来创建相应数据库操作接口实例。如下述代码:
public static IOrder CreateOrder()
{
string path = "Com.JJHua.sqlServerDAL";
string className = path + ".Index";
return (IOrder)Assembly.Load(path).CreateInstance(className);
}
四、创建项目BLL,负责业务逻辑实现。其中需要调用数据库操作函数的时候声明
private static IOrder iOrder = DataAccess.CreateOrder();
然后调用IOrder中声明(Com.JJHua.sqlServerDAL.Order类中定义)的函数。
上面就是一个基本的过程,其中需要注意几点:
1、数据接口工厂DALFactory中CreateOrder函数声明成static,其他有关的地方也要用static,因为此处是利用反射动态加载程序集,所以加载一次就够了,网上偶然看了资料,据说即使多次执行加载语句也只会加载一次。
2、会出现“未能加载文件或程序集“Com.JJHua.sqlServerDAL”或它的某一个依赖项。系统找不到指定的文件”的情况。其实原因贼简单,就是无法找到该程序集,主要是没理解它运行的机制,其实如果
Assembly.Load(path).CreateInstance(className);
写成
Assembly.Load(“Com.JJHua.sqlServerDAL.dll").CreateInstance(className);
就清楚了,这找的不是一个名称空间,而是在bin里的一个dll文件。而项目sqlServerDAL默认生成的dll文件的名字是sqlServerDAL.dll,于是就会出现以上的错误。那么只要在该项目属性里把程序集名称改成“Com.JJHua.sqlServerDAL“就行了。
编程的路太长了,很多的基础要打,太多的技术要学,快失去信心了!