YAGNI 与程序接口而不是具体实现

问题描述

YAGNI(你不需要它)规则说我们应该在代码中使用最少的元素来完成这项工作。

但是每当我创建一个类时,建议我们应该首先创建一个接口,然后按照“编程接口而不是具体实现”的原则通过拥有一个子类来扩展它,这样我就可以更好地适应未来的需求,并且更松散耦合代码

但根据 YAGNI 的说法,从一开始,我们就应该避免创建不必要的接口。

那么应该关注哪些以及何时关注?

解决方法

来自 Martin Fowler 的 bliki

Yagni 仅适用于软件内置的功能以支持推定功能,不适用于使软件更易于修改的努力。

一般来说,抽象编程属于后一类。