问题描述
|
我想重构一些遗留代码。
通过读取一些寄存器可以获得一些数据。此数据以csv和xml文件表示。
当前的方法很脏。数据和视图(XML,CSV)之间没有分隔。因此,实际上,对于每种格式,每次都进行数据收集。
为了给您一张照片,它的当前外观是这样的:
A::Timestamp()
{
//does some data collection and dumps to csv file
//the header for this csv file is built in PreTimeStamp function.
//depending on some command line options certain cols are added.
filehndle << data1 << \",\"<<data2<<\",\" << data3;
if( cmd_line_opt1 )
{
filehndle << \",\" << statdata1 <<\",\"<<statdata2;
}
}
A::PreTimeStamp()
{
//header for csv file
filehndle << \"start,end,delta\";
if( cmd_line_opt1 )
{
filehndle << \",\" << \"statdata1,statdata2\";
}
}
还有另一个类B :: Profile(),它与A :: Timestamp一样进行数据收集,但是数据作为XML转储。
我想对其进行重构,以将数据收集放在一个普通的地方。并为csv和xml使用一些适配器以获取数据并以该格式转储。
现在,我需要一些关于可以用来表示数据的模型的帮助。收集的数据不是固定的,因此我无法将其建模为struct
或某些静态类型。添加到csv文件的cols取决于命令行选项。
接下来的帮助我可以将诸如xmlWriter和CsvWriter之类的插件插入该数据模型吗?
解决方法
我建议为此使用策略模式。
在'Dumper \'接口中,TimeStamp和PreTimeStamp声明将是纯虚拟的(即virtual void Timestamp()= 0),并且Dumper_A和Dumper_B实现将被声明为虚拟的。
然后,将为装入数据的类分配适当的Dumper实现以处理数据的转储。
, 是表格数据吗?如果是这样,您可以考虑使用向量向量。
而我的结构方式是在抽象的基类中实现数据收集,然后为实现写功能的xml和csv版本提供子类。
, 撇开您是否会真正从这项工作中获得实际好处的问题,我想说XML本身是中间格式的一个不错的选择,只要您不需要高性能即可。您可以用它来表示任何文档,它周围有一个好的工具链,它在某种程度上是人类可读的(尽管不如YAML那样好),并且您已经在使用它作为数据的本机格式之一。我不认为引入第三种格式(例如YAML或JSON)或任何值得您花时间的东西。
, 我将使用XML作为中间格式,并编写多个(现在为1个)XSL转换,以将数据转换为所需的其他格式。转换为CSV非常简单。
, 从您的需求来看,MVC模式可能对您有很大帮助。
你有数据(模型),你有控制器(事件,cmd选项)。因此,您唯一需要拥有的就是视图。您可以有一个抽象的视图基类,然后继承您的特定视图类,例如XML和CSV(将来可能会更多),它们将以特定格式显示模型
, 您需要一个结构,其中包括用于特定迭代的所有可能收集的数据,以及一个适配器类,该适配器类将文本字段(输出中所需的属性标签)映射到该结构中的成员指针(可能是用于从文本输入或输入中解析或生成所需类型的函数)输出)。如果不可能或不希望具有包含所有可能收集的数据的结构,则可以仅使用地图作为原型对象。