写点什么

JSR 308:Java 语言复杂度在恣意增长?

  • 2008-05-19
  • 本文字数:2180 字

    阅读完需:约 7 分钟

在上周举行的 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 语言来说可能是最糟糕的时候。目前,整个软件开发界都在对动态语言大加赞赏。上面代码兜了一大圈,如果换成采用动态语言,我们只须:<pre id="d58t41">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 语言前进的四条原则的关心。

查看英文原文: JSR 308: Unwarranted Increase in Java Language Complexity?

2008-05-19 19:562351

评论

发布
暂无评论
发现更多内容

微信官方kbone,Web端同构的福音

Geek_99967b

小程序

洞见商业新机,云原生数据库GaussDB让企业决策更科学

华为云开发者联盟

数据库 后端 华为云

秒验丨Android客户端集成指南

MobTech袤博科技

android Android Studio Gradle

什么是知识库,为什么需要它?

Geek_da0866

重磅升级!TDengine3.0正式发布

TDengine

数据库 tdengine 时序数据库

容器化 | 一文搞定镜像构建方式选型

RadonDB

MySQL Docker Kubernetes 镜像 RadonDB

HUAWEI内网最新发布了一份452页网络协议手册,GitHb百万收藏

小柴说Java

Java 网络协议 java程序员 TCP/IP Java工程师

直播系统源码——重视哪些功能的开发?

开源直播系统源码

软件开发 直播系统源码 直播功能

CSDN 加入星策开源社区,携手推动企业智能化转型建设

星策开源社区

企业转型 智能化 CSDN

企业实践|基于软件研运一体化DevOps平台的应用解析

云智慧AIOps社区

DevOps 自动化 敏捷开发 研发管理 代码托管

7 天找个 Go 工作,Gopher 要学的条件语句,循环语句 ,第3篇

梦想橡皮擦

Python 爬虫 8月月更

谁在构建超云?

Kent Yao

超云

兆骑科创创新创业大赛,双创活动,赛事承办,三招三引

兆骑科创凤阁

对话张星亮,洞察本质,SaaS首先是一种商业模式

B Impact

兆骑科创国内外创新创业服务平台,创业大赛,企业落地孵化

兆骑科创凤阁

Linux C/C++后台开发高级架构师进阶指南-剑指腾讯T9

C++后台开发

后台开发 后端开发 linux开发 Linux服务器开发 C/C++开发

软件测试100天上岸1-测试就是找茬游戏

和牛

测试 8月月更

开源一夏 | 在STM32L051上使用RT-Thread (一、无线温湿度传感器 之 新建项目)

矜辰所致

开源 RT-Thread 8月月更 STM32L051

极盾·析策,XDR的正确打开方式

极盾科技

网络安全 安全 数据安全 xdr

从0到1打造推荐系统工程实战

Jay Wu

推荐系统

点赞破百万!字节算法大佬亲撰30W字数据算法笔记:GitHub标星93K

小柴说Java

数据结构 算法 算法题 算法与数据结构 算法面试题

XSKY星辰天合与观测云完成产品兼容性互认证 构建全业务链路的可观测性

观测云

重磅发布!阿里云全链路数据湖开发治理解决方案

阿里云大数据AI技术

大数据 阿里云 数据湖 数据分析

如何区分透明LED显示屏种类及应用领域

Dylan

LED显示屏 led显示屏厂家

参与openEuler社区不到1年,我成为了Maintainer……

openEuler

开源 成长 openEuler 开源社区 开发者说

干货!XDR产品安全检测体系如何更好的落地?

极盾科技

网络安全 安全 信息安全 数据安全 xdr

【Java】:程序流程的控制

翼同学

Java 学习 编程语言 分享 8月月更

Alibaba最新发布的Spring Boot项目实战文档,Github标星78k

Java面试那些事儿

Java Java 面试 java程序员 Java工程师 spring-boot

种草 Vue3 中几个好玩的插件和配置

江南一点雨

Java Vue

让GitHub炸锅的深入理解MySQL实战手册,竟出自阿里云“藏经阁”

冉然学Java

Java MySQL 高可用 阿里 构架

从GitHub火到了InfoQ!共计1658页的《Java岗面试核心MCA版》,拿走不谢

收到请回复

Java 程序员 金九银十 Java面试八股文 常见面试题

JSR 308:Java语言复杂度在恣意增长?_Java_Alexander Olaru_InfoQ精选文章