c#类接口设计
本文关键字:接口 | 更新日期: 2023-09-27 18:01:55
我正试图为我的项目使用的iTextsharp (PDF创建库)设计一个界面。我不想在我的项目中引用任何iTextsharp,只需要接口。
比方说,我有
interface IPdfTable { /* */ }
public class PdfTable : IPdfTable { /* */ }
interface IPdfCell { /* */ }
public class PdfCell : PdfCell { /* */ }
虽然我可以很容易地为每个类单独构建接口,但当这些类相互交互时,我在实现上遇到了困难。在代码的某个地方,我需要表能够接受单元格的集合。
当我有一个单元格集合时,问题就出现了,我需要将它添加到表中。不知何故,我需要将IPdfCell转换为库(iTextSharp)接受的原始元素。我认为快速和简单的实现是令人沮丧的,但不是一个好的设计。
我能想到的唯一其他解决方案是使用接口来收集不同的设置,并在它被传递到其他元素时动态地创建原始元素(被iTextsharp接受)。
有更好的实现吗?
我不明白这样一个接口的目的。无论如何,您的pdf生成代码将绑定到您正在使用的库,构建完全镜像库的代理类/接口并不能阻止这一点,它只是增加了另一层。如果您要切换到一个不同的PDF生成库,那么新库与iText中的等效库的匹配是极不可能的,并且您最终将更改接口和调用代码。
我的建议是创建一个IPDFGenerator
,然后创建一个与ittext耦合的iTextPDFGenerator:IPDFGenerator
,并将其留在那里。你将拥有你想要的分离,将iText从你的核心服务中分离出来的能力,但它不需要在相同的类之间进行一堆无意义的映射。
我认为你应该重新评估SOLID中的S, I和D,并确保你没有过度使用
通常,您会有一个转换层,将您的接口外观实现转换为iTextSharp本地支持的类型。
如果您需要属性到属性的映射,AutoMapper可以帮助您解决这个问题,并且可以为您省去大量的翻译工作。