解决方法
从功能的角度来看,这不是一个任务,也不是
Java复杂或运行时.但是,其编码标准被更广泛的社区所接受.甚至许多静态代码审查工具(如
checkstyle和许多其他人)都会检查这些类是否遵循此类规定.
为什么遵循这一惯例,已在其他答案中解释,甚至OP也涵盖了这一点.
我想进一步解释一下,大多数Utility类都有与对象实例无关的方法/函数.这些是聚合函数.因为它们仅依赖于返回值的参数而不依赖于实用程序类的类变量.因此,大多数这些函数/方法都是静态的.因此,Utility类理想地是具有所有静态方法的类.
因此,任何调用这些方法的程序员都不需要实例化这个类.然而,一些机器人编码器(可能没有经验或兴趣)将倾向于在调用其方法之前创建他们认为需要的对象.为避免创建对象,我们有3个选项: –
>继续教育人们不要实例化它. (没有理智的人可以继续这样做.)
>将类标记为抽象: –
现在robo-coders再次不会创建对象.然而,审查和更广泛的Java社区将争辩说,标记抽象意味着你希望有人扩展它.所以,这也不是一个好选择.
>私人建设者: –
受保护将再次允许子类创建对象.
现在,再次如果有人想为这些实用程序类添加一些功能的新方法,他不需要扩展它,他可以添加新方法,因为每个方法都是独立的,没有机会破坏其他功能.所以,不需要覆盖它.而且你也不会去见,所以需要将它子类化.最好将其标记为最终.