建议127:用形容词组给接口命名
接口规范的是“Can do”,也就是说,它规范的是类型可以具有哪些行为。所以,接口的命名应该是一个形容词,如:
IDisposable表示可以被释放
IEnumerable表示类型含有Items,可以被迭代。
正是因为接口表示的是类型的行为,所以从语义上可以让类型继承多个接口,如:
class SampleClass : IDisposable, IEnumerable<SampleClass> { //省略 #region 实现IDisposable public void Dispose() { throw new NotImplementedException(); } #endregion #region 实现IEnumerable public IEnumerator<SampleClass> GetEnumerator() { throw new NotImplementedException(); } IEnumerator IEnumerable.GetEnumerator() { throw new NotImplementedException(); } #endregion }
以上代码看起来觉得符合语法,又符合语义。如果我们将接口命名为IDisposal,这给人造成的误解是:该类型是一个类,而不是接口,虽然我们在前面加了前缀I,但仍然感觉这是符合语义的。
然而,FCL中也有一些违反此规定的例外,比如IEnumerator接口。但是,这种情况相对来说还是比较少的,在大多数情况下,我们需要始终考虑用形容词来为接口命名。
转自:《编写高质量代码改善C#程序的157个建议》陆敏技