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

赣榆网站建设做网站前置审批

赣榆网站建设,做网站前置审批,c#网站开发+pdf,程序员做外包怎么样文章目录 #xff08;四#xff09;创建型模式#xff1a;简单工厂模式#xff0c;工厂方法模式#xff0c;抽象工厂模式简单工厂模式工厂方法模式抽象工厂模式 #xff08;四#xff09;创建型模式#xff1a;简单工厂模式#xff0c;工厂方法模式#xff0c;抽象工… 文章目录 四创建型模式简单工厂模式工厂方法模式抽象工厂模式简单工厂模式工厂方法模式抽象工厂模式 四创建型模式简单工厂模式工厂方法模式抽象工厂模式 在软件系统中经常面临着创建对象的工作由于需求的变化需要创建的对象的具体类型经常变化。工厂模式的动机在于通过一个专门的工厂类来封装对象的创建过程以解耦对象的使用和创建隐藏复杂的对象实例化逻辑从而提高代码的灵活性和可维护性。通过工厂模式客户端代码只需与工厂接口或抽象类交互而不必直接与具体类耦合这使得系统更易于扩展和修改。 工厂模式可以分为简单工厂模式工厂方法模式和抽象工厂模式。 简单工厂模式 简单工厂模式不属于GoF的23种设计模式工厂类根据输入的参数决定创建哪一种产品类的实例。 #include iostream #include string// 抽象产品类 class Product { public:virtual void operation() 0;virtual ~Product() {} // 虚析构函数确保正确释放资源 };// 具体产品类 A class ConcreteProductA : public Product { public:void operation() override {std::cout ConcreteProductA operation. std::endl;} };// 具体产品类 B class ConcreteProductB : public Product { public:void operation() override {std::cout ConcreteProductB operation. std::endl;} };// 简单工厂类 class SimpleFactory { public:// 静态工厂方法根据传入的字符串类型创建具体的产品对象static Product* createProduct(const std::string type) {if (type A) {return new ConcreteProductA(); // 创建并返回 ConcreteProductA 对象} else if (type B) {return new ConcreteProductB(); // 创建并返回 ConcreteProductB 对象} else {return nullptr; // 如果传入的类型无效返回空指针}} };int main() {// 使用简单工厂创建产品 AProduct* productA SimpleFactory::createProduct(A);if (productA) {productA-operation();delete productA;}// 使用简单工厂创建产品 BProduct* productB SimpleFactory::createProduct(B);if (productB) {productB-operation();delete productB;}return 0; }以上代码通过引入一个工厂类SimpleFactory 将产品对象A和B 的创建过程封装在工厂方法中从而实现对象创建与使用的分离。客户端只需要通过工厂来获取对象无需了解对象的创建细节。 工厂方法模式 简单工厂违反了开闭原则对扩展开放对修改关闭因为每当需要引入新产品时都需要修改工厂类。为了避免这个问题工厂方法模式定义一个抽象工厂类通过继承得到可以创建不同产品的工厂。 示例 #include iostream #include string// 抽象产品类 class Product { public:virtual void operation() 0;virtual ~Product() {} // 虚析构函数确保正确释放资源 };// 具体产品类 A class ConcreteProductA : public Product { public:void operation() override {std::cout ConcreteProductA operation. std::endl;} };// 具体产品类 B class ConcreteProductB : public Product { public:void operation() override {std::cout ConcreteProductB operation. std::endl;} };// 抽象工厂类 class Factory { public:virtual Product* createProduct() 0;virtual ~Factory() {} // 虚析构函数确保正确释放资源 };// 具体工厂类 A创建 ConcreteProductA class ConcreteFactoryA : public Factory { public:Product* createProduct() override {return new ConcreteProductA();} };// 具体工厂类 B创建 ConcreteProductB class ConcreteFactoryB : public Factory { public:Product* createProduct() override {return new ConcreteProductB();} };int main() {// 使用具体工厂类 A 创建产品 AFactory* factoryA new ConcreteFactoryA();Product* productA factoryA-createProduct();productA-operation();delete productA;delete factoryA;// 使用具体工厂类 B 创建产品 BFactory* factoryB new ConcreteFactoryB();Product* productB factoryB-createProduct();productB-operation();delete productB;delete factoryB;return 0; }这段代码通过定义一个抽象工厂类Factory来声明创建产品对象的接口具体的产品创建由具体工厂类ConcreteFactoryA 和 ConcreteFactoryB来实现。工厂方法模式能在不修改已有代码的情况下通过增加新的工厂类来创建新的产品类型实现对开闭原则的遵循。 抽象工厂模式 抽象工厂模式的主要是为了解决在不需要指定具体类的情况下创建一组相关或依赖对象 (产品族)的需求。它通过提供一个接口来创建一系列相关或依赖对象的工厂使得客户端可以在不指定具体实现类的情况下创建产品族中的产品。 #include iostream #include string// 抽象产品 A 类 class ProductA { public:virtual void operation() 0;virtual ~ProductA() {} // 虚析构函数确保正确释放资源 };// 具体产品 A1 class ConcreteProductA1 : public ProductA { public:void operation() override {std::cout ConcreteProductA1 operation. std::endl;} };// 具体产品 A2 class ConcreteProductA2 : public ProductA { public:void operation() override {std::cout ConcreteProductA2 operation. std::endl;} };// 抽象产品 B 类 class ProductB { public:virtual void operation() 0;virtual ~ProductB() {} };// 具体产品 B1 class ConcreteProductB1 : public ProductB { public:void operation() override {std::cout ConcreteProductB1 operation. std::endl;} };// 具体产品 B2 class ConcreteProductB2 : public ProductB { public:void operation() override {std::cout ConcreteProductB2 operation. std::endl;} };// 抽象工厂类 class AbstractFactory { public:virtual ProductA* createProductA() 0;virtual ProductB* createProductB() 0;virtual ~AbstractFactory() {} };// 具体工厂 1创建产品 A1 和 B1 class ConcreteFactory1 : public AbstractFactory { public:ProductA* createProductA() override {return new ConcreteProductA1();}ProductB* createProductB() override {return new ConcreteProductB1();} };// 具体工厂 2创建产品 A2 和 B2 class ConcreteFactory2 : public AbstractFactory { public:ProductA* createProductA() override {return new ConcreteProductA2();}ProductB* createProductB() override {return new ConcreteProductB2();} };int main() {// 使用具体工厂 1 创建产品 A1 和 B1AbstractFactory* factory1 new ConcreteFactory1();ProductA* productA1 factory1-createProductA();ProductB* productB1 factory1-createProductB();productA1-operation();productB1-operation();delete productA1;delete productB1;delete factory1;// 使用具体工厂 2 创建产品 A2 和 B2AbstractFactory* factory2 new ConcreteFactory2();ProductA* productA2 factory2-createProductA();ProductB* productB2 factory2-createProductB();productA2-operation();productB2-operation();delete productA2;delete productB2;delete factory2;return 0; }
http://www.hkea.cn/news/14272694/

相关文章:

  • 哪里有网站模板下载免费的网站有哪些平台
  • 网站上的咨询窗口是怎么做的培训机构 网站建设
  • 简述网站建设的基本过程网站做seo
  • 单位网站建设管理情况怎样做网站才不能被攻破
  • 微信微网站是什么情况做网站被坑能找司法吗
  • 关注网站怎么做网络工程师教程
  • 项目合作网站在线制图网
  • dedecms能做什么网站购物平台搭建
  • 网站建设需要多久苏州网站建设智能 乐云践新
  • 广州企业建设网站云南手机网站建设
  • html网站设计范例自适应网站建设专家
  • 优化网站排名推荐公司优的网站建设明细报价表
  • 为国外的公司提供网站建设 维护网站建设时间计划书
  • 提升网站流量建筑师培训
  • 途牛网网站是哪家公司做的服装网站建设开题报告
  • 有产品做推广 选哪个 网站百度怎么做广告推广
  • 官方微网站泰安互联网公司
  • 网站开发公司成本是什么深圳正规燃气公司一览表
  • 网站功能需求分析文档交流平台网站怎么做
  • 大庆市建设网站网站建设合同 模板 下载
  • 做直播网站找哪个展馆设计论文
  • 建设通招标网站怎么评价网站做的好坏
  • 网站班级文化建设大连网站制作公司费用多少
  • 做网站链接要多少钱wordpress隐私页
  • 网站数据库空间大小设计师培训心得体会
  • 手机网站 备案异次元wordpress模板
  • 惠州网站建设领头wordpress 回收站在哪
  • 网站设计步骤的教学设计吉林长春火车站官网
  • 计算机网站怎么做四川最新情况最新消息今天
  • 建设网站需申请什么互联网的推广