IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

干嘛不去掉“I”和“Impl”?

外刊IT评论 2011-05-15 21:27:55 累计浏览 6,750 次
本机暂存
本文是从 Why drop the I if you’re going to just add an Impl? 这篇文章翻译而来。

    今天早上我仔细研究TopShelf项目的源代码,想追查里面一个API的修改,突然发现TopShelf终于向新近流行的去掉接口名称上的“I”字母做法屈服了。在.NET上这还是个新事物,使用Java的人这样做了有一段时间了,但在.NET里很多都还是新事物。这些可不是从ruby偷来的。

    如果你对此不太熟悉,我先解释一下,传统的习惯是在接口的名称前加入一个毫无必要的“I”字母,事实上这个接口的使用者并不在意这个接口前是否有个“I”字母,这种加入“I”字母的形式是一种匈牙利标记法,文明世界里几乎一致认为这是一种糟糕的做法。

    所以你的代码…

1 public interface ISomeBehavior { }

    ..应该写成..

1 public interface SomeBehavior { }

    这样合情合理。而有问题的是当你把一个实现这个接口的类像下面这样命名时:

1 public interface SomeBehavior { }
2 public class SomeBehaviorImpl { }

    我不知道把接口上的“I”移到实现类上然后再加三个字母究竟有什么好处。除了让我的指头关节多活动几下还能做什么?难道这个程序的使用方还在意这是一个没有“I”的接口实现类吗?

    从一些基础层面上讲,接口就是个契约。契约声明一个类要实现接口提供的特定用途的一些方法和属性。从另一个角度看这个问题可以观察接口的行为。

    考察一下.NET里提供的IDisposable这个接口。没有一个DisposableImpl伴随着它。这个接口描述的是一个实现类型的特征,它可以代表任何的东西。

    接口跟实现类并不是一对一的关系。事实上,一个类可以实现多个接口。引用Brett L. Schuchert的例子:

1 class Manager : public ISing, public IDance {}

     保持简洁的接口,让manager们尽情放纵

    我相信你看到这里已经露出愤怒的表情了,会想“那好,聪明人,你想让我们怎么做?”

    对于我,我喜欢这个“I”字母,但喜欢的是它读起来像一种声明。

1 public interface IReadFiles { }//我读取文件
2 public interface ICalculateRates { }//我计算比例
3 public interface ISingAndDance {//我唱歌跳舞}

    你会发现这和传统的“I”/“Impl”用法相反。但这很酷不是?每个“I”都代表我,但这该死的“Impl”里不是。

同分类推荐文章

  1. 科技爱好者周刊(第 401 期):如何赚到10亿美元 (2026-06-26 08:05:38)
  2. 如何做决策 - 从 Go 的一个 issue 说起 (2026-06-26 08:00:00)
  3. Seven Player:Windows上播放115网盘视频的增强工具 (2026-06-09 00:06:47)

查看更多 开发者 文章 →

建议继续学习

  1. SmartSprites - 命令行形式的CSS Sprites生成器 (累计阅读 123,894)
  2. Java开发岗位面试题归类汇总 (累计阅读 22,155)
  3. android 开发入门 (累计阅读 19,527)
  4. 我的PHP,Python和Ruby之路 (累计阅读 13,146)
  5. HashMap解决hash冲突的方法 (累计阅读 12,652)
  6. 一个大二学生有关如何成为一名软件工程师的疑问及答复 (累计阅读 9,178)
  7. 代理的加密部分 (累计阅读 8,416)
  8. Java程序员应该知道的10个eclipse调试技巧 (累计阅读 8,011)
  9. 如何让员工忠于公司? (累计阅读 7,938)
  10. 怎么样才是好的程序员 (累计阅读 7,744)