大家好,今天小编关注到一个比较有意思的话题,就是关于java运算符和c语言的问题,于是小编就整理了1个相关介绍Java运算符和c语言的解答,让我们一起看看吧。
为什么Java不支持运算符重载?
许多大能对java不支持运算符重载的原因进行了分析。就我个人理解,不管java设计者当初出于什么样的考虑,这一决策的一个明显的好处是使得程序易于理解!为什么?
运算符本身具有其缺省的、确定的运算含义,而运算符重载使得运算符的运算功能具有了不确定性,从而使得基于这种不确定性的包含重载运算符的程序代码具有了不确定性!
也就是说,要想理解包含重载运算符的程序代码的确切含义,首先要找到运算符被重载的地方,理解重载后运算符的含义!运算符被重载了吗?在哪里重载的?重载后它是什么意思?带有这些疑问去阅读程序会相当累,还不如直接了当用函数来表达相应功能更显得简单!
另外,允许运算符重载在某种程度上违背了开闭设计原则。运算符的重载和使用不是局部化的,重载可能发生在多处,使用的地方可能会更多。对某一重载代码的修改,其影响范围存在某种程度的不确定性!
总之,运算符重载有其优点,对于追求形式美的人来说具有极大的诱惑力!然而我们大多数人是现实的!java不支持运算符重载,我认为更多的是现实的考量!!!
1) 简单性和清晰性。
清晰性是 Java 设计者的目标之一。设计者不是只想复制语言,而是希望拥有一种清晰,真正面向对象的语言。添加运算符重载比没有它肯定会使设计更复杂,并且它可能导致更复杂的编译器, 或减慢 JVM,因为它需要做额外的工作来识别运算符的实际含义,并减少优化的机会, 以保证 Java 中运算符的行为。
Java 不允许用户定义的运算符重载,因为如果允许程序员进行运算符重载,将为同一运算符赋予多种含义,这将使任何开发人员的学习曲线变得陡峭,事情变得更加混乱。
据观察,当语言支持运算符重载时,编程错误会增加,从而增加了开发和交付时间。由于 Java和 JVM 已经承担了大多数开发人员的责任,如在通过提供垃圾收集器进行内存管理时,因为这个功能增加污染代码的机会, 成为编程错误之源, 因此没有多大意义。
3) JVM复杂性。
从JVM的角度来看,支持运算符重载使问题变得更加困难。通过更直观,更干净的方式使用方法重载也能实现同样的事情,因此不支持 Java 中的运算符重载是有意义的。与相对简单的 JVM 相比,复杂的 JVM 可能导致 JVM 更慢,并为保证在 Java 中运算符行为的确定性从而减少了优化代码的机会。
这是在 Java 中不支持运算符重载的另一个好处。省略运算符重载后使语言更容易处理,如静态分析等,这反过来又更容易开发处理语言的工具,例如 IDE 或重构工具。Java 中的重构工具远胜于 C++。
1)简单性和清晰性。清晰性是Java设计者的目标之一。设计者不是只想***语言,而是希望拥有一种清晰,真正面向对象的语言。添加运算符重载比没有它肯定会使设计更复杂,并且它可能导致更复杂的编译器, 或减慢 JVM,因为它需要做额外的工作来识别运算符的实际含义,并减少优化的机会, 以保证 Java 中运算符的行为。
2)避免编程错误。Java 不允许用户定义的运算符重载,因为如果允许程序员进行运算符重载,将为同一运算符赋予多种含义,这将使任何开发人员的学习曲线变得陡峭,事情变得更加混乱。据观察,当语言支持运算符重载时,编程错误会增加,从而增加了开发和交付时间。由于 Java 和 JVM 已经承担了大多数开发人员的责任,如在通过提供垃圾收集器进行内存管理时,因为这个功能增加污染代码的机会, 成为编程错误之源, 因此没有多大意义。
3)JVM复杂性。从JVM的角度来看,支持运算符重载使问题变得更加困难。通过更直观,更干净的方式使用方法重载也能实现同样的事情,因此不支持 Java 中的运算符重载是有意义的。与相对简单的 JVM 相比,复杂的 JVM 可能导致 JVM 更慢,并为保证在 Java 中运算符行为的确定性从而减少了优化代码的机会。
4)让开发工具处理更容易。这是在 Java 中不支持运算符重载的另一个好处。省略运算符重载使语言更容易处理,这反过来又更容易开发处理语言的工具,例如 IDE 或重构工具。Java 中的重构工具远胜于 C++。
到此,以上就是小编对于java运算符和c语言的问题就介绍到这了,希望介绍关于java运算符和c语言的1点解答对大家有用。