我正试图找到初始化设备驱动程序(由生产人员维护)的最佳方式。配置通常包含串行端口和其他信息,如果设备驱动程序的底层硬件发生变化,生产人员可能需要更改这些信息。使用依赖注入容器初始化可配置对象
例如
using System.IO.Ports;
public class Scanner : IDriver
{
public SerialPort SerialPort { get; private set; }
public String Id { get; private set; }
public String DisplayName { get; private set; }
public Scanner(SerialPort serialPort, String id, String displayName)
{
SerialPort = serialPort;
Id = id;
DisplayName = displayName;
}
}
public class TestMethod
{
public Scanner MainScanner { get; private set; }
public Scanner SecondaryScanner { get; private set; }
public TestMethod (Scanner main, Scanner secondary)
{
MainScanner = main;
SecondaryScanner = secondary;
}
}
如何在运行时使用DI容器并仍然可以更改配置?我希望避免使用DI容器附带的XML配置,因为我期望生产人员经常修改这些(配置)文件。一个单独的配置文件将是首选。
一种可能实现XML配置
<DeviceDrivers>
<Driver name="main" id="IX234" displayName="main scanner">
<SerialPort name="serialPort" portName="COM8" baudRate="11560" parity="None" dataBits="8" stopBits="None">
</Driver>
<Driver name="secondary" id="IX2E3" displayName="secondary scanner">
<SerialPort name="serialPort" portName="COM9" baudRate="11560" parity="None" dataBits="8" stopBits="None">
</Driver>
</DeviceDrivers>
SerialPort
本身需要从配置文件intialised。
感谢
PS:我正在考虑Ninject,但不知道如果我能顺利完成这件事。
不是真的,配置文件可由生产人员编辑。我不想让他们暴露于统一语法,而只是简单的可配置项目。我还发现[Unity配置架构](http://msdn.microsoft.com/en-au/library/ff660914(v = pandp.20).aspx#config_registerelement)更有用。 – resp78