大多数面向对象语言的接口名称都以大写的I开头,为什么Java不这样做呢?不遵循这一惯例的理由是什么?
为了证明我的意思,如果我想有一个用户界面和一个用户实现,我在Java中有两个选择:
类=用户,接口= UserInterface
类= UserImpl,接口=用户
在大多数语言中:
类=用户,接口= IUser
现在,您可能会争辩说,您总是可以为用户实现选择一个最具描述性的名称,这样问题就解决了,但Java正在推动POJO方法,大多数IOC容器广泛使用dynamicproxy。这两件事加在一起意味着您将使用单个POJO实现拥有许多接口。
所以,我想我的问题可以归结为:“是否值得遵循更广泛的接口命名约定,尤其是考虑到Java框架的发展方向?”
遵循良好的OO原则,您的代码应该(尽可能地实际/可能)依赖于抽象而不是具体类。例如,通常更好的方法是这样写的:
public void doSomething(Collection someStuff) {
...
}
比这个:
public void doSomething(Vector someStuff) {
...
}
如果您遵循这个想法,那么我认为,如果您为接口命名为“User”和“BankAccount”(例如),而不是“IUser”、“UserInterface”或其他变体,那么您的代码将更具可读性。
唯一应该关心实际具体类的代码是具体类的构造位置。其他所有内容都应该使用接口编写。
如果您这样做了,那么像“UserImpl”这样“难看”的具体类名应该安全地隐藏在代码的其余部分中,这些代码可以愉快地继续使用“漂亮”的接口名。