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

简单的旅游网站怎么做北京推广营销

简单的旅游网站怎么做,北京推广营销,公司网址大全,h网站模版理论跟实践的关系#xff0c;说远不远#xff0c;说近不近。能不能把理论用到实践上#xff0c;还真不好说。通常讲到设计模式#xff0c;一个最通用的原则是SOLID#xff1a;S - Single Responsibility Principle#xff0c;单一责任原则O - Open Closed Principle… 理论跟实践的关系说远不远说近不近。能不能把理论用到实践上还真不好说。 通常讲到设计模式一个最通用的原则是SOLIDS - Single Responsibility Principle单一责任原则O - Open Closed Principle开闭原则L - Liskov Substitution Principle里氏替换原则I - Interface Segregation Principle接口隔离原则D - Dependency Inversion Principle依赖倒置原则嗯这就是五大原则。后来又加入了一个Law of Demeter迪米特法则。于是就变成了六大原则。 原则好理解。怎么用在实践中一、单一责任原则单一责任原则简单来说就是一个类或一个模块只负责一种或一类职责。看代码public interface IUser {void AddUser();void RemoveUser();void UpdateUser();void Logger();void Message(); } 根据原则我们会发现对于IUser来说前三个方法AddUser、RemoveUser、UpdateUser是有意义的而后两个Logger和Message作为IUser的一部分功能是没有意义的并不符合单一责任原则的。所以我们可以把它分解成不同的接口public interface IUser {void AddUser();void RemoveUser();void UpdateUser(); } public interface ILog {void Logger(); } public interface IMessage {void Message(); } 拆分后我们看到三个接口各自完成自己的责任可读性和可维护性都很好。 下面是使用的例子采用依赖注入来做public class Log : ILog {public void Logger(){Console.WriteLine(Logged Error);} } public class Msg : IMessage {public void Message(){Console.WriteLine(Messaged Sent);} } class Class_DI {private readonly IUser _user;private readonly ILog _log;private readonly IMessage _msg;public Class_DI(IUser user, ILog log, IMessage msg){this._user  user;this._log  log;this._msg  msg;}public void User(){this._user.AddUser();this._user.RemoveUser();this._user.UpdateUser();}public void Log(){this._log.Logger();}public void Msg(){this._msg.Message();} } public static void Main() {Class_DI di  new Class_DI(new User(), new Log(), new Msg());di.User();di.Log();di.Msg(); } 这样的代码看着就漂亮多了。二、开闭原则开闭原则要求类、模块、函数等实体应该对扩展开放对修改关闭。 我们先来看一段代码计算员工的奖金public class Employee {public int Employee_ID;public string Name;public Employee(int id, string name){this.Employee_ID  id;this.Name  name;}public decimal Bonus(decimal salary){return salary * .2M;} } class Program {static void Main(string[] args){Employee emp  new Employee(101, WangPlus);Console.WriteLine(Employee ID: {0} Name: {1} Bonus: {2}, emp.Employee_ID, emp.Name, emp.Bonus(10000));} } 现在假设计算奖金的公式做了改动。要实现这个我们可能需要对代码进行修改public class Employee {public int Employee_ID;public string Name;public string Employee_Type;public Employee(int id, string name, string type){this.Employee_ID  id;this.Name  name;this.Employee_Type  type;}public decimal Bonus(decimal salary){if (Employee_Type  manager)return salary * .2M;elsereturnsalary * .1M;} } 显然为了实现改动我们修改了类和方法。这违背了开闭原则。 那我们该怎么做我们可以用抽象类来实现 - 当然实际有很多实现方式选择最习惯或自然的方式就成public abstract class Employee {public int Employee_ID;public string Name;public Employee(int id, string name){this.Employee_ID  id;this.Name  name;}public abstract decimal Bonus(decimal salary); } 然后我们再实现最初的功能public class GeneralEmployee : Employee {public GeneralEmployee(int id, string name) : base(id, name){}public override decimal Bonus(decimal salary){return salary * .2M;} } class Program {public static void Main(){Employee emp  new GeneralEmployee(101, WangPlus);Console.WriteLine(Employee ID: {0} Name: {1} Bonus: {2}, emp.Employee_ID, emp.Name, emp.Bonus(10000));} } 在这儿使用抽象类的好处是如果未来需要修改奖金规则则不需要像前边例子一样修改整个类和方法因为现在的扩展是开放的。代码写完整了是这样public abstract class Employee {public int Employee_ID;public string Name;public Employee(int id, string name){this.Employee_ID  id;this.Name  name;}public abstract decimal Bonus(decimal salary); }public class GeneralEmployee : Employee {public GeneralEmployee(int id, string name) : base(id, name){}public override decimal Bonus(decimal salary){return salary * .1M;} } public class ManagerEmployee : Employee {public ManagerEmployee(int id, string name) : base(id, name){}public override decimal Bonus(decimal salary){return salary * .2M;} } class Program {public static void Main(){Employee emp  new GeneralEmployee(101, WangPlus);Employee emp1  new ManagerEmployee(102, WangPlus1);Console.WriteLine(Employee ID: {0} Name: {1} Bonus: {2}, emp.Employee_ID, emp.Name, emp.Bonus(10000));Console.WriteLine(Employee ID: {0} Name: {1} Bonus: {2}, emp1.Employee_ID, emp1.Name, emp1.Bonus(10000));} } 三、里氏替换原则里氏替换原则讲的是子类可以扩展父类的功能但不能改变基类原有的功能。它有四层含义子类可以实现父类的抽象方法但不能覆盖父类的非抽象方法子类中可以增加自己的特有方法当子类重载父类的方法时方法的前置条件形参要比父类的输入参数更宽松当子类实现父类的抽象方法时方法的后置条件返回值要比父类更严格。在前边开闭原则中我们的例子里实际上也遵循了部分里氏替换原则我们用GeneralEmployee和ManagerEmployee替换了父类Employee。 还是拿代码来说。假设需求又改了这回加了一个临时工是没有奖金的。public class TempEmployee : Employee {public TempEmployee(int id, string name) : base(id, name){}public override decimal Bonus(decimal salary){throw new NotImplementedException();} } class Program {public static void Main(){Employee emp  new GeneralEmployee(101, WangPlus);Employee emp1  new ManagerEmployee(101, WangPlus1);Employee emp2  new TempEmployee(102, WangPlus2);Console.WriteLine(Employee ID: {0} Name: {1} Bonus: {2}, emp.Employee_ID, emp.Name, emp.Bonus(10000));Console.WriteLine(Employee ID: {0} Name: {1} Bonus: {2}, emp1.Employee_ID, emp1.Name, emp1.Bonus(10000));Console.WriteLine(Employee ID: {0} Name: {1} Bonus: {2}, emp2.Employee_ID, emp2.Name, emp2.Bonus(10000));Console.ReadLine();} } 显然这个方式不符合里氏替原则的第四条它抛出了一个错误。所以我们需要继续修改代码并增加两个接口interface IBonus {decimal Bonus(decimal salary); } interface IEmployee {int Employee_ID { get; set; }string Name { get; set; }decimal GetSalary(); } public abstract class Employee : IEmployee, IBonus {public int Employee_ID { get; set; }public string Name { get; set; }public Employee(int id, string name){this.Employee_ID  id;this.Name  name;}public abstract decimal GetSalary();public abstract decimal Bonus(decimal salary); } public class GeneralEmployee : Employee {public GeneralEmployee(int id, string name) : base(id, name){}public override decimal GetSalary(){return 10000;}public override decimal Bonus(decimal salary){return salary * .1M;} } public class ManagerEmployee : Employee {public ManagerEmployee(int id, string name) : base(id, name){}public override decimal GetSalary(){return 10000;}public override decimal Bonus(decimal salary){return salary * .1M;} } public class TempEmployee : IEmployee {public int Employee_ID { get; set; }public string Name { get; set; }public TempEmployee(int id, string name){this.Employee_ID  id;this.Name  name;}public decimal GetSalary(){return 5000;} } class Program {public static void Main(){Employee emp  new GeneralEmployee(101, WangPlus);Employee emp1  new ManagerEmployee(102, WangPlus1);Console.WriteLine(Employee ID: {0} Name: {1} Salary: {2} Bonus:{3}, emp.Employee_ID, emp.Name, emp.GetSalary(), emp.Bonus(emp.GetSalary()));Console.WriteLine(Employee ID: {0} Name: {1} Salary: {2} Bonus:{3}, emp1.Employee_ID, emp1.Name, emp1.GetSalary(), emp1.Bonus(emp1.GetSalary()));ListIEmployee emp_list  new ListIEmployee();emp_list.Add(new GeneralEmployee(101, WangPlus));emp_list.Add(new ManagerEmployee(102, WangPlus1));emp_list.Add(new TempEmployee(103, WangPlus2));foreach (var obj in emp_list){Console.WriteLine(Employee ID: {0} Name: {1} Salary: {2} , obj.EmpId, obj.Name, obj.GetSalary());}} } 四、接口隔离原则接口隔离原则要求客户不依赖于它不使用的接口和方法一个类对另一个类的依赖应该建立在最小的接口上。通常的做法是把一个臃肿的接口拆分成多个更小的接口以保证客户只需要知道与它相关的方法。这个部分不做代码演示了可以去看看上边单一责任原则里的代码也遵循了这个原则。五、依赖倒置原则依赖倒置原则要求高层模块不能依赖于低层模块而是两者都依赖于抽象。另外抽象不应该依赖于细节而细节应该依赖于抽象。看代码public class Message {public void SendMessage(){Console.WriteLine(Message Sent);} } public class Notification {private Message _msg;public Notification(){_msg  new Message();}public void PromotionalNotification(){_msg.SendMessage();} } class Program {public static void Main(){Notification notify  new Notification();notify.PromotionalNotification();} } 这个代码中通知完全依赖Message类而Message类只能发送一种通知。如果我们需要引入别的类型例如邮件和SMS则需要修改Message类。下面我们使用依赖倒置原则来完成这段代码public interface IMessage {void SendMessage(); } public class Email : IMessage {public void SendMessage(){Console.WriteLine(Send Email);} } public class SMS : IMessage {public void SendMessage(){Console.WriteLine(Send Sms);} } public class Notification {private IMessage _msg;public Notification(IMessage msg){this._msg  msg;}public void Notify(){_msg.SendMessage();} } class Program {public static void Main(){Email email  new Email();Notification notify  new Notification(email);notify.Notify();SMS sms  new SMS();notify  new Notification(sms);notify.Notify();} } 通过这种方式我们把代码之间的耦合降到了最小。六、迪米特法则迪米特法则也叫最少知道法则。从称呼就可以知道意思是一个对象应该对其它对象有最少的了解。在写代码的时候尽可能少暴露自己的接口或方法。写类的时候能不public就不public所有暴露的属性、接口、方法都是不得不暴露的这样能确保其它类对这个类有最小的了解。这个原则没什么需要多讲的调用者只需要知道被调用者公开的方法就好了至于它内部是怎么实现的或是有其他别的方法调用者并不关心调用者只关心它需要用的。反而如果被调用者暴露太多不需要暴露的属性或方法那么就可能导致调用者滥用其中的方法或是引起一些其他不必要的麻烦。 最后说两句所谓原则不是规则不是硬性的规定。在代码中能灵活应用就好不需要非拘泥于形式但是用好了会让代码写得很顺手很漂亮。 全文完喜欢就来个三连让更多人因你而受益
http://www.zqtcl.cn/news/851568/

相关文章:

  • 西安做网站公网站做友链有行业要求吗
  • 做现金贷网站的公司软件开发设计文档
  • 数据做图网站表示商业网站的域名
  • 网站备案单位备案老域名
  • 黔西南州建设局网站网站建设流程的过程
  • 河南龙王建设集团网站沈阳专业建站
  • 百度网盘app下载安装手机版百度排名优化咨询电话
  • 网站微信公众号链接怎么做免费访问国外网站的应用
  • 东莞网站搜索排名wordpress 小工具居中
  • 网上商城网站源码网站建站中关键字搜索怎么弄
  • 房地产开发公司网站源代码 墨绿色风格河北省建设项目环保备案网站
  • 有没有做机械加工的网站企业网站建站企业
  • 网站自创重庆宣传片制作
  • 如何做美发店网站世界上网站做的好的例子
  • 不会代码可以做网站维护吗成版年蝴蝶视频app免费
  • html5手机论坛网站模板支付商城网站制作
  • 自己主机做多个网站网站备案和服务器备案
  • 长安手机网站建设江西做网站的公司有哪些
  • 泉州微信网站开发万能浏览器有哪些
  • 商丘做网站公司新站seo快速收录网站内容页快速建站工具
  • 质监站网址数字化展厅建设方案
  • 免费网上商城网站建设廊坊十大名牌模板厂
  • 网站建设格式龙泉建设工程有限公司网站
  • 四海网络网站建设咨询深圳网站优化网站
  • 报名网站开发多钱做酒网站
  • 2014年网站设计趋势怎样用代码建设一个网站
  • 手机网站使用微信支付瑞诺国际公司团队介绍
  • 如何做网站内容架构分析网站建站平台eazyshop
  • 网站开发 商标第几类建站模板大全
  • 找事做的网站杭州网站建设有限公司