原帖地址:http://www.infoq.com/cn/news/2008/05/JSR-308
在上周举行的JavaOne大会中关于“被提议的Java SE7(“
TS-5581:即将到来的Java编程语言的变化”)语言新特性”的介绍中,JSR 308 (
Java类型注解)的综述占了很重要的一部分。除此之外,
Alex Buckley (Sun Microsystems)、
Michael Ernst (MIT) 和
Neal Gafter (Google)等与会者还介绍了其他一些Java语言新特性:如
改进的catch子句(multi-catch)、
安全的re-throw,
和Java模块(Java Modules)。
JSR 308想要解决在
Java 1.5注解中出现的两个问题:
☆
在句法上对注解的限制:只能把注解写在声明的地方
☆
类型系统在语义上的限制:类型系统还做不到预防所有的bug
JSR 308 通过如下方法解决上述两个问题:
对Java语言的句法进行扩充,允许注解出现在更多的位置上。包括:方法接收器(method receivers,译注:例public int size() @Readonly { ... }),范型参数,数组,类型转换,类型测试,对象创建,类型参数绑定,类继承和throws子句。
通过引入
可插拔的类型系统(pluggable type systems)能够创建功能更强大的注解处理器。类型检查器对带有类型限定注解的源码进行分析,一旦发现不匹配等错误之处就会产生警告信息。
针对上述有关JSR 308的内容,
Michael Nygard写了一篇题为
Java程序员什么时候离身而去?JSR 308就是使大家离开Java的导火索的帖子,文章表明了他的观点:JSR 308对Java语言本身和Java开发者来说都有较大影响。在这篇帖子中,在给出了几个如何使用注解的例子之后,Nygard说JSR 308和Java 1.5中引入的范型技术一起都大大增加了Java语言的复杂性,但这些复杂性却没有为Java带来一点点益处:
引用
每种语言都有复杂度预算。Java语言的复杂度预算一下就被Java 5引入的范型给打破了。再认真端详下面的代码:
@NotEmpty List<@NonNull String> strings = new ArrayList<@NonNull String>()>
这还像Java吗? 复杂度预算就像后视镜上淡淡的污渍一样被人忽视。现在,我们只是写出更冗长的代码以提供更详尽的语义信息给编译器,使它能高兴轻松的执行编译工作,可是我们却完完全全忘记了我们真正开发的项目本身到底是什么。
更令Nygard不安的是,他注意到JSR 308出现的时间正好是软件开发者们对动态语言越来越感兴趣的时候:
引用
所有这些都说明目前已到了对于Java语言来说可能是最糟糕的时候。目前,整个软件开发界都在对动态语言大加赞赏。上面代码兜了一大圈,如果换成采用动态语言,我们只须:
var strings = ["one", "two"];
说实在的,上面两种代码,你希望选用哪一种?毫无疑问,动态语言版的不需要我们借助编译器的辅助去满足某些强制性条件。当然,使用动态代码确实需要进行更多的单元测试。可是我还是喜欢使用动态语言,我宁愿选择“不讲究繁文缛节”而不是“满嘴虚礼”。
Nygard 相信:一旦JSR 308成为Java语言的一部分,Java开发者们就会转向其他语言。Nygard的结论是:
引用
因此,对Java语言的升级、修订应该赶快回到Java开发者的主流技术认识上......看上去似乎只有两种选择:更动态或者更静态。要么更形式化、更严格,要么更随意、更简明。无疑,JSR 308将彻底加速这种分化。
意料之中地,上面的观点招致了
很多评论员的不同反应。有评论员发现注解对于开发者来说是一条便捷的“迂回之路”,开发者不用再花大把力气去阅读大量的API文档,可以只集中精力关注思考他们自己的任务。对此,cfagan 作出了回应:
引用
说到底,代码才是“最根本”的文档。代码中包含的注解清楚表明了代码编写者的意图。当没有及时更新或者有遗漏的时候,恰恰是注解中包含的意图信息,最容易在其他文档中被丢失。无论采用什么语言,我赞成“出众的才能产生上好的结果”这种说法。将运行时的错误转到编译阶段,不但可以加速开发进程,还可以节省测试时检查bug的时间。
Josef谈到了注解其实是一种并不要求一定要使用的可选项,同时还谈了他自己关于注解被采纳的可能途径的看法。他讲到:
引用
Nygard的观点似乎认为JSR 308被采纳后,注解就变成了必须使用的语言元素,所有Java开发者都必须马上开始书写带有注解的Java代码。但是我预计:一开始,几乎不会有Java程序员使用注解。只会有那些需要书写高确信性软件的公司才会立刻开始使用注解。因为这些公司需要注解所提供的功能来详细说明正确性条件,并对这些正确性条件进行自动检查或半自动检查。
Josef还解释了注解与范型的区别之处:
引用
JSR 308中的注解是可以缺省的,这是件好事。对于范型来说这当然不行,否则你就不会知道程序中要使用什么类型。但是对于JSR 308中的注解来说,即使不关注它们,程序员也可以顺顺当当的往下写代码。只有在你使用检查器时,才需要真正考虑注解的事情。
JavaOne大会上“即将到来的Java编程语言的变化”的介绍者们总结了一些主要原则,使用这些原则可以对那些加入Java语言中的新特性进行评估。这些原则如下:
鼓励高级实践(作正确的事)
追求清晰(把事情做好)
静态类型优先(保持安全性)
语言与API分离(保持抽象性)
用以上的原则来衡量,JSR 308看上去与Java语言的未来方向很“合拍”。最近这些关于“JSR 308新特性的加入”的讨论或许表明对于上述四条原则的解释存在某种程度的分歧。另一方面,这些讨论或许也能充分说明大家对引领Java语言前进的四条原则的关心。
分享到:
相关推荐
8. **JSR 341:JavaServer Pages 2.2 (JSP)** - 更新了JSP语法,增加了对表达式语言和EL 2.2的支持。 9. **JSR 352:Batch Applications for the Java Platform** - 为JavaEE添加了批量处理能力,使得大数据处理...
JSR-000343则是对这个标准的第2.0版本的规范定义,它详细描述了如何在Java应用程序之间可靠地发送和接收消息。Javadoc是一种特殊的文档生成工具,它能从源代码中的注释生成文档,为开发者提供API的详细说明。 在...
5. **JSR 363: Unified Expression Language (EL) 3.0**:EL 3.0增强了表达式语言,提供了更多的功能,如方法调用、类型转换、null安全操作等,提升了模板语言的灵活性和表达能力。 6. **JSR 365:Contexts and ...
JSR(Java Specification Requests)是Java社区进程(Java Community Process)中定义新API或改进现有API的标准提案。在J2ME开发中,JSR系列API扮演着至关重要的角色,它们为开发者提供了丰富的功能和接口来实现特定...
标签:fasterxml、jackson、datatype、jsr310、中文文档、jar包、java; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和说明...
JSR 是提出新特性的提议,通常涉及到Java平台的增强或新API的开发,涵盖了从核心Java语言到企业级应用框架的广泛领域。 在Java世界中,每当开发者、公司或者社区成员想要为Java平台添加新的功能、修改现有标准或者...
【标题】"powershell-jsr223" 是一个针对 Java 平台的 PowerShell 脚本引擎,它实现了 JSR 223(Java Scripting API)规范,使得开发者能够在 Java 应用程序中方便地执行 PowerShell 脚本。这个引擎允许你利用 ...
标签:jackson、jsr310、datatype、fasterxml、jar包、java、中英对照文档; 使用方法:解压翻译后的API文档,用浏览器打开“index.html”文件,即可纵览文档内容。 人性化翻译,文档中的代码和结构保持不变,注释和...
7. **JSR 372: JavaServer Pages (JSP) 2.3**:JSP 2.3引入了对EL 3.0的支持,提供了更多表达式语言功能,同时也提升了性能。 8. **CDI 2.0**:Contexts and Dependency Injection (CDI) 2.0改进了依赖注入框架,...
根据提供的文件内容,以下是关于“JSR-000343 Java Message Service 2.0 Specification for Evaluation”的详细知识点: ### 标题知识点 - **JSR-000343**: Java Message Service (JMS) 2.0 规范的代号,JSR(Java...
Java编程语言在处理日期和时间方面历经了多次进化。早期的`java.util.Date`和`java.util.Calendar`类虽然广泛使用,但因其设计缺陷和易用性不足而饱受批评。为了解决这些问题,Java 8引入了JSR 310(Java ...
使用JSR356在Java中构建WebSocket应用,详细介绍,包括1.服务器推送给客户端和2.客户端发送给服务器
JSR303,全称为Java Specification Request 303,是Java Community Process(JCP)提出的一个关于数据校验的标准。它定义了一个用于验证JavaBeans属性的API,旨在简化和标准化应用程序的数据验证过程。这个标准后来...
Java EE 6企业级应用开发教程是一门针对高等教育领域的课程,旨在教授学生如何利用Java Enterprise Edition(Java EE)6平台进行高效、可扩展且健壮的企业级应用开发。Java EE 6是Java平台上用于构建分布式、多层...
- **移动设备**: 虽然Android采用了Java作为其主要开发语言,但Java Mobile Edition (Java ME) 仍然在某些移动设备上有所应用。 - **智能卡**: Java Card 用于安全芯片上的应用开发。 #### Java平台的设计目标 ...
JSR 223定义了一套标准API,用于在Java应用程序中加载、运行和管理脚本语言。它允许Java开发者通过简单的接口调用,就能执行各种脚本语言代码,如JavaScript、Groovy、JRuby等。这种机制不仅增强了Java应用的动态性...
This document is the proposed final draft version of the JSR-133 specification, the Java Memory Model (JMM) and Thread Specification. This specification is intended to be part of the JSR-176 umbrella ...
Java字节码是Java程序在虚拟机中运行的中间表示形式,类似于汇编语言。通过字节码编程,开发者可以在运行时动态修改或生成Java字节码,实现高级功能,如代码注入和性能优化。以下是一些学习资源: 1. **Java Zone: ...