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

四川哪家网站做的最好哪里有免费的网站推广软件

四川哪家网站做的最好,哪里有免费的网站推广软件,搬瓦工 wordpress,推荐电子商务网站建设文章目录 一、单例模式 1.饿汉模式 2.懒汉模式 二、工厂模式 三、建造者模式 四、代理模式 设计模式是前辈们对代码开发的总结#xff0c;是解决特定问题的一系列套路。它不是语法规定#xff0c;而是一套用来提高代码可复用性、可维护性、可读性、稳健性以及安全性的解… 文章目录 一、单例模式 1.饿汉模式 2.懒汉模式 二、工厂模式 三、建造者模式 四、代理模式 设计模式是前辈们对代码开发的总结是解决特定问题的一系列套路。它不是语法规定而是一套用来提高代码可复用性、可维护性、可读性、稳健性以及安全性的解决方案。 设计模式的六大原则 1.单一职责原则 类的职责应该单一一个方法只做一件事。职责划分清晰每次改动到最小单位的方法或者类使用建议两个完全不一样的功能不应该放在同一个类中一个类应该是一组相关性很高的函数数据的封装用例网络聊天通信类聊天类 2.开闭原则 对扩展开发对修改封闭使用建议对软件实体改动最好使用扩展而非修改的方式用例:超市卖货商品价格 不是修改原来的商品价格而是新增促销的价格 3.里氏替换原则    不要破坏继承体系 父类可以出现的地方子类就可以出现而且替换为子类也不会产生错误或者异常在继承时务必完全重写父类的方法尤其是父类的protected方法子类尽量不要暴露自己的public方法供外界调用使用建议子类完全实现父类的方法子类可以有自己的个性覆盖或者实现父类的方法时输入参数可以被放大输出可以缩小用例:跑步运动员类-会跑步 子类长跑运动员会跑步且擅长长跑子类短跑运动员会跑步且擅长短跑 4.依赖倒置原则   面向接口编程 高层次模块不应该依赖低层次模块两者都应该依赖其抽象不可分割的原子逻辑就是低层模式原子逻辑组装成的就是高层模块模块直接按依赖通过抽象接口发生具体类之间不直接依赖使用建议每个类都尽量有抽象类任何类都不应该从具体类派生。尽量不要重写基类的方法结合里氏替换原则使用用例奔驰类司机--只能开奔驰 司机类--给什么车就开什么车 开车的人司机 依赖抽象 5.迪米特法则 最少知道法则   降低耦合 尽量减少对象间的交互从而减小类之间的耦合。一个对象应该其他对象有最少的了解对类的低耦合提出明确的交流用力老师让班长点名 老师给班长一个名单班长完成点名勾选返回结果而不是班长点名老师勾选 6.接口隔离原则 客户端不应该依赖它不需要的接口类间的依赖关系应该建立在最小的接口使用建议接口设计尽量精简单一不要对外暴露没有实际意义的接口用例:修改密码就提供单一的最小修改密码接口不应该提供用户信息接口更不要暴露数据库 一、单例模式 一个类只能创建一个对象即单例模式该设计模式中可以保证系统中该类只有一个实例并提供一个访问它的全局访问点该实例被所有程序模块共享。 那我们需要保证 1该类不能被拷贝构造不能赋值。 2构造函数私有 单例模式有两种实现方式饿汉模式和懒汉模式 1.饿汉模式 a.直接定义静态对象 b.静态指针类外初始化时new 程序启动时候就会创建一个唯一的实例对象。因为单例对象已经确定所以比较适用于多线程环境中多线程获取单例对象不需要加锁可以有效避免资源竞争提高性能。缺点就是如果单例对象构造特别耗时或者耗费资源加载插件加载网络资源等比较占用内存 templatetypename T class singleTon {private:singleTon(){}~singleTon(){}public:singleTon(const singleTon) delete;singleTon operator(const singleTon) delete;static T getInstance(){return _eton;}private:static singleTon _eton; };singleTon singleTon::_eton;2.懒汉模式 第一次要使用的时候创建实例对象。 a.静态指针用到的时候初始化 b.局部静态变量 templatetypename T class singleTon{private:singleTon(){}~singleTon(){}public:singleTon(const singleTon) delete;singleTon operator(const singleTon) delete;static T getInstance(){static singleTon _eton;return _eton;} };二、工厂模式 工厂模式是一种创建型设计模式在工厂模式中创建对象时候不会对上层暴露创建逻辑而是通过一个共同结构指向新创建的对象以此实现创建-使用的分离 1.简单工厂模式 简单工厂模式实现由一个工厂对象通过类型决定创建出来指定产品类的实例。假设有个工厂可以生产水果客户需要产品的时候明确告知工厂生产哪类水果工厂需要接收用户提供的类别信息当新增产品的时候工厂内部去添加新产品的生产方式。 这个模式的结构和管理对象的方式十分简单但是它的可扩展性非常差当我们需要新增产品的时候就需要修改工厂类新增一个类型的产品创建逻辑违背了开闭原则。 class Fruit {public:Fruit(){}virtual void show() 0; };class Apple :public Fruit {public:Apple(){}virtual void show(){ coutapple method...endl;} };class Banana :public Fruit() {public:Banana(){}virtual void show(){coutbanana method ...endl;} };class FruitFactory {public:static std::shared_ptrFruit create(const std::string name){if(name Apple)return std::make_sharedApple();else if(name banana)return std::make_sharedBanana();}return std::shared_ptrFruit(); } };int main() {std::shared_ptrFruit fruit FruitFactory::create(Apple);fruit-show();return 0; }2.工厂方法模式 在简单工厂模式下新增多个工厂多个产品每个产品对于一个工厂。假设有a,b两种产品则开两个工厂工厂a负责生产产品a,工厂b生产产品b用户只知道产品的工厂名而不知道具体的产品信息工厂不需要再接收客户的产品类别而只负责生产产品。 工厂方法模式每次增加一个产品时都需要增加一个具体产品类和工厂类这会使得系统中类的个数成倍增加在一定程度上增加了系统的耦合度。 class Fruit {public:Fruit(){}virtual void show() 0; };class Apple :public Fruit {public:Apple(){}virtual void show(){ coutapple method...endl;} };class Banana :public Fruit() {public:Banana(){}virtual void show(){coutbanana method ...endl;} };class AppleFactory:public FruitFactory {public:virtual std::shared_ptrFruit create(){return std::make_sharedApple();} };class BananaFactory:public FruitFactory {public:virtual std::shared_ptrFruit create(){return std::make_sharedBanana();} };int main() {shared_ptrFruitFactory Factorynew AppleFactory());fruit Factory-create();fruit-show()return 0; }3.抽象工厂模式 工厂方法模式引入工厂等级结构解决了简单工厂模式中工厂类职责太多的问题但是由于工厂方法模式每个工厂只生产一类产品可能会导致系统中存在大量的工厂类会增加系统的开销。此时可以将一些相关的产品组成一个产品族位于不同产品等级结构中功能相关联的产品组成的家族由同一个工厂来生产这就是抽象工厂模式的基本思想。 抽象工厂模式适用于生产多个工厂系列产品衍生的设计模式增加新的产品等级结构复杂需要对原有系统进行较大的修改甚至需要修改抽象层代码违背了“开闭原则”。 //围绕一个超级工厂创建其他工厂每个生产的工厂按照工厂模式提供对象。 //思想将工厂抽象成两层 抽象工厂 具体工厂子类在子类中生产不同的子产品class Fruit {public:Fruit(){}virtual void show() 0; };class Apple : public Fruit {public:Apple() {}virtual void show(){std::cout 我是⼀个苹果 std::endl;}private:std::string _color; };class Banana : public Fruit {public:Banana() {}virtual void show() {std::cout 我是⼀个⾹蕉 std::endl;} }; class Animal {public:virtual void voice() 0; }; class Lamp: public Animal {public:void voice() { std::cout 咩咩咩\n; } }; class Dog: public Animal {public:void voice() { std::cout 汪汪汪\n; } }; class Factory {public:virtual std::shared_ptrFruit getFruit(const std::string name) 0;virtual std::shared_ptrAnimal getAnimal(const std::string name) 0; }; class FruitFactory : public Factory {public:virtual std::shared_ptrAnimal getAnimal(const std::string name) {return std::shared_ptrAnimal();}virtual std::shared_ptrFruit getFruit(const std::string name) {if (name 苹果) {return std::make_sharedApple();}else if(name ⾹蕉){return std::make_sharedBanana();}return std::shared_ptrFruit();} };class AnimalFactory : public Factory {public:virtual std::shared_ptrFruit getFruit(const std::string name) {return std::shared_ptrFruit();}virtual std::shared_ptrAnimal getAnimal(const std::string name) {if (name ⼩⽺) {return std::make_sharedLamp();}else if(name ⼩狗) {return std::make_sharedDog();}return std::shared_ptrAnimal();} }; class FactoryProducer {public:static std::shared_ptrFactory getFactory(const std::string name) {if (name 动物) {return std::make_sharedAnimalFactory();}else {return std::make_sharedFruitFactory();}} }; int main() {std::shared_ptrFactory fruit_factory FactoryProducer::getFactory(⽔果);std::shared_ptrFruit fruit fruit_factory-getFruit(苹果);fruit-show();fruit fruit_factory-getFruit(⾹蕉);fruit-show();std::shared_ptrFactory animal_factory FactoryProducer::getFactory(动物);std::shared_ptrAnimal animal animal_factory-getAnimal(⼩⽺);animal-voice();animal animal_factory-getAnimal(⼩狗);animal-voice();return 0; } 三、建造者模式 建造者模式是一种创建型设计模式使用多个简单的对象一步一步构建成一个复杂的对象能够将一个复杂的对象的构建与它的表示分离提供一种创建对象的最佳方式。主要用于解决对象的构建过于复杂的问题。 建造者模式主要基于四个核心类实现 抽象产品类 具体产品类 抽象builder类创建一个产品对象所需的各个部件的抽象接口 具体产品的builder类实现抽象接口构建各个部件 指挥者director类统一组件过程提供给调用者使用通过指挥者来构造产品 //抽象电脑类 class Computer {public:using ptr std::shared_ptrComputer;Computer(){}void setBoard(const std::string board) { _board board;}void setDisplay(const std::string display) { _display display;}virtual void setOs() 0;std::string toString(){std::string computer Computer:{\n;computer \tboard _board ,\n;computer \tdisplay _display ,\n;computer \tOs _os ,\n;computer }\n;return Computer;}protected:std::string _board;std::string _display;std::string _os; };//具体产品类 class MacBook : public Computer {public:using ptr std::shared_ptrMacBook;MacBook() {}virtual void setOs() {_os Max Os X12;} };//抽象建造者类 包含创建一个产品对象各个部件的抽象接口 class Builder {public:using ptr std::shared_ptrBuilder;virtual void buildBorad(const std::string board) 0;virtual void buildDisplay(const std::string display)0;virtual void buildOs()0;virtual Computer::ptr build() 0; };//具体产品的具体建造者类实现抽象接口构建和组装各个部件 class MacBookBuilder:pubilc Builder {public:using ptr std::shared_ptrMacBookBuilder;MacBookBuilder():_computer(new MackBook()){}virtual void buildBoard(const std::string board){_computer-setBoard(board);}virtual void buildDisplay(const std::string display){_computer-setDisplay(display);}virtual void buildOs(){_computer-setOs();}private:Computer:: ptr _computer; };//指挥者类 提供给调用者 通过指挥者来构造复杂产品 class Director {public:Director(Builder * builder):_builder(builder){}void construct(const std::string board,const std::string display){_builder-buildBoard(board);_builder-buildDisplay(display);_builder-buildOs();}private:Builder::ptr _builder; };int main() {Builder * builder new MacBookBuilder();std:: unique_ptrDirector pd(new Director(builder));pd-construct(Inter,aoc);Computer:: ptr computer builder-build();return 0; } 四、代理模式 代理模式指的是代理控制对其他对象的访问也就是代理对象控制原对象的引用。在某些情况下一个对象不适合或者不能直接引用访问而代理对象可以在客户端和目标对象之间起到中介的作用。 代理模式结构包括一个真正要访问的对象目标类一个是代理对象。 目标类和代理对象实现一个接口先访问代理对象再通过代理对象访问目标对象。 代理模式分为静态代理和动态代理 静态代理指的是在编译时就已经确定好了代理类和被代理类的关系。也就是说在编译时就已经 确定了代理类要代理的是哪个被代理类。动态代理指的是在运⾏时才动态⽣成代理类并将其与被代理类绑定。这意味着在运⾏时才能 确定代理类要代理的是哪个被代理类 以租房为例房东将房⼦租出去但是要租房⼦出去需要发布招租启⽰ 带⼈看房负责维修这 些⼯作中有些操作并⾮房东能完成因此房东为了图省事将房⼦委托给中介进⾏租赁 class RentHouse {public:virtual void rentHouse() 0; };//房东类 class LandLord: public RentHouse {public:void rentHouse(){coutrent..endl;} };//中介 对租房功能进行加强实现租房外的其他功能 class Intermediary :public RentHouse {public :void rentHouse(){//发广告//带人看房_landlord.rentHouse();//后续维修}private:Landlord _landlord; };int main() {Intermdiary inter;inter.rentHouse(); }
http://www.w-s-a.com/news/951034/

相关文章:

  • 网站备案为什么这么慢目录更新 wordpress
  • 视频在线制作网站Wordpress 外链图片6
  • 网站域名后缀有什么用网站建设的投资预算怎么写
  • 化妆品网站建设网站惠州网站关键字优化
  • 保定网站制作企业下载天眼查企业查询官网
  • 中山企业网站建设公司制作一个景点的网站
  • 连云港集团网站建设株洲建设网站
  • 做运动鞋评价的网站南山做网站联系电话
  • 网站开发公众号开发海南做公司网站
  • 论企业网站建设的必要性微信小程序做一个多少钱
  • 网站制作价格是多少元上海市中小企业服务中心
  • 网站建设管理人员济宁网站建设top
  • 桂林网站建设桂林网站的元素有哪些
  • 广东网站开发推荐网页制作个人简历模板教程
  • e建网保定百度seo公司
  • 网站建设中html代码网络培训课堂app
  • 无锡做网站seo自己做的网站如何上传网上
  • 园林景观网站模板小白怎么做跨境电商
  • 找第三方做网站 需要注意企业网站带数据库
  • 北京南站到北京站flash网站制作单选框和复选框ui组件
  • 网站建设核电集团网站设计案例
  • 宝塔做的网站能不能访问上海的广告公司网站建设
  • 网站会员系统方案新能源网站建设哪家好
  • 全球网站域名域名被墙查询
  • 做期货看资讯什么网站好哈尔滨网站设计联系方式
  • 建站宝盒免费下载上海网论坛网址
  • 国内最有趣的25个网站推广流程
  • 红河做网站抖音小程序怎么挂到抖音上
  • 高度重视机关门户网站建设外包
  • 网站里面送礼物要钱怎么做代码网站开发怎么对接客户