当前位置: 首页 > news >正文

登陆网站显示域名解析错误怎么办北京通州做网站

登陆网站显示域名解析错误怎么办,北京通州做网站,扬州市城市建设监察支队网站,wordpress主题lightsns设计模式最大的作用就是在变化和稳定中间寻找隔离点#xff0c;然后分离它们#xff0c;从而管理变化。将变化像小兔子一样关到笼子里#xff0c;让它在笼子里随便跳#xff0c;而不至于跳出来把你整个房间给污染掉。 设计思想 提供一个接口#xff0c;让该接口负责创建一… 设计模式最大的作用就是在变化和稳定中间寻找隔离点然后分离它们从而管理变化。将变化像小兔子一样关到笼子里让它在笼子里随便跳而不至于跳出来把你整个房间给污染掉。 设计思想 提供一个接口让该接口负责创建一系列“相关或者相互依赖的对象”无需指定他们具体的类。 动机 在软件系统中经常面临着“一系列相互依赖的对象”的创建工作同时由于需求的变化往往存在更多系列对象的创建工作。 如何应对这种变化如何绕过常规的对象创建方法new)提供一种“封装机制”来避免客户程序和这种“多系列具体对象创建工作”的紧耦合 如果没有应对“多系列对象构建”的需求变化则没有必要使用Abstract Factory模式这时候使用简单的工厂完全可以。 “系列对象”指的是在某一特定系列下的对象之间有相互依赖或作用关系。不同系列的对象之间不能相互依赖。 Abstract Factory模式主要在于应对“新系列”的需求变动。其缺点在于难以应对“新对象”的需求变动。 抽象工厂和工厂方法非常相像区别就在于抽象工厂需要一系列对应的对象而工厂方法就是唯一对象因此工厂方法也可以理解成抽象工厂的一个特例。 业务场景 要对 SQL Server 数据库进行操作需要有 ConnectionCommandDataReader等一系列配套的操作。而当需要更换数据库的时候也是这套操作 如何提高代码复用性 一个非常直观的思路是 class EmployeeDAO { public:vectorEmployeeDO GetEmployees() {SqlConnection* connection new SqlConnection();connection-ConnectionString(...);SqlCommand* command new SqlCommand();command-CommandText(...);command-SetConnection(connection);SqlDataReader* reader command-ExecuteReader();while (reader-Read()) {}} };看见这些熟悉的代码 SqlConnection* connection new SqlConnection();SqlCommand* command new SqlCommand();如果你看过前面的工厂方法模式你会很自然的联想到那个然后将代码改进成这样 // 数据库访问有关的基类 class IDBConnection {}; class IDBConnectionFactory { public:virtual IDBConnection* CreateDBConnection() 0; };class IDBCommand {}; class IDBCommandFactory { public:virtual IDBCommand* CreateDBCommand() 0; };class IDataReader {}; class IDataReaderFactory { public:virtual IDataReader* CreateDataReader() 0; };// 支持SQL Server class SqlConnection : public IDBConnection {}; class SqlConnectionFactory : public IDBConnectionFactory {};class SqlCommand : public IDBCommand {}; class SqlCommandFactory : public IDBCommandFactory {};class SqlDataReader : public IDataReader {}; class SqlDataReaderFactory : public IDataReaderFactory {};// 支持Oracle class OracleConnection : public IDBConnection {}; class OracleConnectionFactory : public IDBConnectionFactory {};class OracleCommand : public IDBCommand {}; class OracleCommandFactory : public IDBCommandFactory {};class OracleDataReader : public IDataReader {}; class OracleDataReaderFactory : public IDataReaderFactory {};class EmployeeDAO {IDBConnectionFactory* dbConnectionFactory;IDBCommandFactory* dbCommandFactory;IDataReaderFactory* dataReaderFactory;public:vectorEmployeeDO GetEmployees() {IDBConnection* connection dbConnectionFactory-CreateDBConnection();connection-ConnectionString(...);IDBCommand* command dbCommandFactory-CreateDBCommand();command-CommandText(...);command-SetConnection(connection); // 关联性IDBDataReader* reader command-ExecuteReader(); // 关联性while (reader-Read()) {}} };有没有解决问题呢确实解决了但是如果细心一点你会发现这三个工厂实例化出来的对象应该是一套的SQL只能用SQL的connectioncommand以及dataReaderMYSQL只能用MYSQL的也就是说在构造EmployeeDAO的时候虽然需要传入三个工厂对象dbConnectionFactorydbCommandFactorydataReaderFactory但是这三个对象却必须是一套的这就带来了问题1. 用户有可能传错对象2.既然必须是一套的那么完全可以将其封装成一个对象传进来 于是便有了抽象工厂模式将三个配套的操作再封装成一个类避免产生配套错误 代码案例 // 数据库访问有关的基类 class IDBConnection {};class IDBCommand {};class IDataReader {};// 三个操作绑定到一起 // 此处是这个模式的稳定部分 class IDBFactory { public:virtual IDBConnection* CreateDBConnection() 0;virtual IDBCommand* CreateDBCommand() 0;virtual IDataReader* CreateDataReader() 0; };// 支持SQL Server class SqlConnection : public IDBConnection {}; class SqlCommand : public IDBCommand {}; class SqlDataReader : public IDataReader {};class SqlDBFactory : public IDBFactory { public:virtual IDBConnection* CreateDBConnection() 0;virtual IDBCommand* CreateDBCommand() 0;virtual IDataReader* CreateDataReader() 0; };// 支持Oracle class OracleConnection : public IDBConnection {}; class OracleCommand : public IDBCommand {}; class OracleDataReader : public IDataReader {};class OracleDBFactory : public IDBFactory { public:virtual IDBConnection* CreateDBConnection() 0;virtual IDBCommand* CreateDBCommand() 0;virtual IDataReader* CreateDataReader() 0; };class EmployeeDAO {// 保证是同一个工厂// 是一个 familyIDBFactory* dbFactory;public:vectorEmployeeDO GetEmployees() {IDBConnection* connection dbFactory-CreateDBConnection();connection-ConnectionString(...);IDBCommand* command dbFactory-CreateDBCommand();command-CommandText(...);command-SetConnection(connection); // 关联性IDBDataReader* reader command-ExecuteReader(); // 关联性while (reader-Read()) {}} };
http://www.w-s-a.com/news/103347/

相关文章:

  • 摄影素材网站做知识问答的网站
  • 中小企业网站建设济南兴田德润电话门店管理系统软件排行
  • 昆明工程建设信息网站柳州网站建设公司哪家好
  • 如何分析网站关键词北京门户网站网址
  • 做网站与做游戏那个好网站域名怎么起
  • 有没有做cad单的网站银行网站建设方案视频
  • 和各大网站做视频的工作高校网站群管理系统
  • 中国建设人才服务信息网是正规网站怎么注销自己名下的公司
  • 网站开发新型技术那些网站做任务领q币
  • 海口手机网站建设wordpress微支付宝
  • 做公司网站需要几天深圳自定义网站开发
  • 做网站学多长时间可以学会推广软件公司
  • 网络网站设计培训长沙建站模板大全
  • 站群搭建移动端处理器天梯图
  • 岳池发展建设集团有限公司门户网站湛江seo咨询
  • 手机网站工具关键词排名是什么意思
  • 游民星空是谁做的网站沈阳网站托管公司
  • 做网站搭建需要什么人vs2017移动网站开发
  • 购物网站开发需要什么技术怎么查看网站是否备案
  • 学做电商那个网站好网站建设投票主题
  • 中卫网站推广网络营销毕业设计做网站大小有什么要求
  • 做问卷网站义乌网站建设推广专家
  • 不会编程怎样建设网站昆明做网站哪家
  • 直播网站模板新营销平台电商网站
  • 建设部指定招标网站免费的企业查询软件
  • 做前端常用的网站及软件下载平台优化是什么意思
  • 企石镇仿做网站wordpress 网站白屏
  • 班级网站建设规划书专业定制网红变色杯
  • 上海网站设计公司电话甘肃路桥建设集团有限公司官方网站
  • 哈尔滨网站建设网站开发陕西省建设监理工程协会网站