C#通过Builder模式造车
Builder模式也可以造车。
对于Builder模式来说,首相要把要造的车确定下来:
public class Car { public string Model { get; set; } public string Engine { get; set; } public string Transmission { get; set; } public string Body { get; set; } public int Doors { get; set; } public List<string> Accessories { get; set; } public Car() { Accessories = new List<string>(); } public void ShowCarInfo() { Console.WriteLine(Model); Console.WriteLine(Engine); Console.WriteLine(Body); Console.WriteLine("门的数量:" + Doors); Console.WriteLine(Transmission); Console.WriteLine("配置为:"); foreach (var accessory in Accessories) { Console.WriteLine("\t{0}", accessory); } } }
这个Car可以交给Builder1也可以交给Builder2,等等,但首先需要提炼出Builder们的一个抽象类。这个抽象Builder可以设置和获取Car,并提供生产Car各个部件的抽象方法。
public abstract class CarBuilder { protected Car _car; public Car GetCar() { return _car; } public void SetCar() { _car = new Car(); } public abstract void SetModel(); public abstract void SetEngine(); public abstract void SetTransmission(); public abstract void SetBody(); public abstract void SetDoors(); public abstract void SetAccessories(); }
然后,就需要一个具体的Builder来派生抽象Builder。
public class BuilderOne : CarBuilder { public override void SetEngine() { _car.Engine = "发动机1"; } public override void SetModel() { _car.Model = "型号1"; } public override void SetTransmission() { _car.Transmission = "变速1"; } public override void SetBody() { _car.Body = "SUV"; } public override void SetAccessories() { _car.Accessories.Add("内饰"); _car.Accessories.Add("外饰"); } public override void SetDoors() { _car.Doors = 6; } }
这个抽象Builder的派生类可能有很多,所以需要一个管理这些派生Builder的类,用来决定到底选用哪个Builder来生产。
public class BuilderManager { private readonly CarBuilder _carBuilder; public BuilderManager(CarBuilder carBuilder) { _carBuilder = carBuilder; } public void BuildCar() { _carBuilder.SetCar(); _carBuilder.SetModel(); _carBuilder.SetEngine(); _carBuilder.SetBody(); _carBuilder.SetDoors(); _carBuilder.SetTransmission(); _carBuilder.SetAccessories(); } public Car GetCar() { return _carBuilder.GetCar(); } }
在客户端,如果需要造车,就找Builder的管理类,通过它的构造函数传入具体的Builder。
class Program { static void Main(string[] args) { var builderManager = new BuilderManager(new BuilderOne()); builderManager.BuildCar(); var car = builderManager.GetCar(); car.ShowCarInfo(); Console.ReadKey(); } }
抽象工厂和Builder模式都可以造车,但两者有也许的不同:
- 抽象工厂模式相当于为车找了一个专属工厂,要求工厂只能造这种类型的车
- Builder模式相当于为车找不同的工厂,不同的工厂生产出来的车型都不一样
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接
- C#设计模式之Builder生成器模式解决带老婆配置电脑问题实例
- C# StringBuilder和string
- C#中的char、string和StringBuilder的使用详解
- 浅谈C# StringBuilder内存碎片对性能的影响
- C#使用String和StringBuilder运行速度测试及各自常用方法简介
- C#中String和StringBuilder的简介与区别
- C#中String StringBuilder StringBuffer类的用法
- 浅析C#中StringBuilder类的高效及与String的对比
- 在C#及.NET框架中使用StringBuilder类操作字符串的技巧
- js实现C#的StringBuilder效果完整实例
相关文章
C# 串口接收数据中serialPort.close()死锁的实例
下面小编就为大家分享一篇C# 串口接收数据中serialPort.close()死锁的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2017-11-11C#使用Directoryinfo类获得目录信息和属性的方法
这篇文章主要介绍了C#使用Directoryinfo类获得目录信息和属性的方法,涉及C#操作目录的技巧,非常具有实用价值,需要的朋友可以参考下2015-04-04
最新评论