你是不是应该总是创建一个接口,如果可能有其他东西可以使用它,或者等到实际需要它,然后重构来使用一个接口?
对接口进行编程通常看起来像是合理的建议,但还有YAGNI...
我想这可能要视情况而定。现在,我有一个表示文件夹的对象,该文件夹可以包含食谱或其他文件夹。与其直接使用文件夹,我是否应该担心实现像IContainer这样的东西呢?以防将来我想有一个引用其他子食谱的食谱(比方说一个苹果派食谱,它也是一个饼皮食谱的容器)
发布于 2009-04-06 04:59:05
很多人已经概述了非常合理的建议。我想补充的一件事是,如果您希望避免对具体类的直接硬依赖,那么接口将通过提供松散耦合来帮助您。如果您正在创建一个基于插件的体系结构,那么接口绝对是最佳选择。此外,如果您计划并排或稍后编写单元测试,您可能会注意到,调用您的文件夹类的代码必须携带一个具体的实现才能使调用代码可测试。如果您的folder类的具体实现依次与DB或服务对话,那么您也需要将其带入测试,这很快就会变得非常笨拙。就我的两分钱。
https://stackoverflow.com/questions/720115
复制相似问题