飞天发布时刻:2024年 Forrester 公有云平台Wave™评估报告解读 了解详情
写点什么

Martin Odersky 在纽约 Scala Days 指出,继沉寂的 2015 之后 Scala 将有大动作

  • 2016-08-11
  • 本文字数:2458 字

    阅读完需:约 8 分钟

继相对沉寂的 2015 年之后,Scala 之父 Martin Odersky 在 2016 年 5 月 9 日纽约的 Scala Days 的主题发言中表示,Scala 在今年正在加速发展。Odersky 现在是洛桑联邦理工学院(EPFL:École Polytechnique Fédérale de Lausanne)的现任编程研究组教授, Lightbend 的联合创始人。他指出了“最近已经或将要发生的改变”:

  • Scala Center
  • Scala 2.12
  • 计划从新思考 Scala 库
  • 开发新的目标平台
  • DOT 与 Dotty

我们简要看一下以上这些主要变化

Scala Center

Odersky 介绍了新的 Scala Center 并将之描述为“承担造福整个 Scala 社区的项目”。据 2016 年 5 月 14 日 Scala Center官方博客所述,Scala Center 的创建是由于日益增加的 Scala 相关职位以及“ scala 教程”在 Google 的搜索量,这些都表明了 Scala 越来越被大家所接受。Scala Center 主要针对开源社区和相关教育培训。同时也为了能更近距离地和 Scala 社区进行协作,正如上述博文指出的:

Scala 巨大的用户基数以及多元化的项目意味着将有大量的对语言与其工具的需求。同时也有大量的有能力的活跃贡献者。Scala Center 的首要任务是询问用户社区,定义一个通用的目标,组织贡献者和所拥有的资源来共同实现这个目标。

Scala Center 建立在 EPFL 并由研究员 Heather Miller 作为常务董事来领导。Lightbend 的 Scala 首席技术 Adriaan Moors 也在 Scala Center 工作。在他就 Lightbend 与 Scala Center 的相互合作接受 InfoQ 采访时,当被问及 Lightbend 每日的工作是否受 Scala Center 的影响时,Moors 表示:

它正在影响我们的计划,但是要说它是否影响我们的日常工作还为时过早。Lightbend 的整个 Scala 团队正在尽全力保证在接下来几周的 2.12.0-RC1 发布,这是唯有我们应尽的职责(当然还有许多开源贡献者)

在许多采纳使用 Scala 的组织中,Lightbend 拥有其中的 62 个案例研究

Scala 2.12

Scala 2.12 已经经历了两年的开发旅程并计划在2016 年中发布( Scala 2.12.0 milestone 5 自 2016 年 6 月 29 日就已发布)。这将是第一个 Java 8 优化的版本,并将利用 Java 8 的 lambdas 表达式实现更短的代码,更快的执行速度。Scala 的 GitHub仓库记录了Scala 2.12 的 33 个新特征。Lightbend 将为运行在 Java 6/7 上的应用提供延伸的 Scala 2.11 的维护周期。

DOT 用时 8 年, DOT - 一种依赖对象类型 (dependent object types,原文疑误写为 document object types) 的演算 - 被证明在 Scala 中是一种可靠的基础。如 Odersky 在 2016 年 2 月 3 日的博客所述:

一个演算可以理解为微语言(mini-language),它足够小,小到可以真正地被研究。换用 Scala 的说法,DOT 包含的语言可以用下图的摘要语法来表述

正如 GitHub仓库中定义的 DOT 演算,以上的抽象语法是:

一个依赖对象类型的最小的完备版本。这个演算只通过交叉,嵌套绑定的组合来实现方法(functions),标签类型(labeled types)和术语(terms)。

选用这种演算可以使得正式的表达式可以在编译语言其他部分时一起被实现和证明。这为将来 Scala 的开发提供更大的信心。这种演算考虑到类型安全。_ 类型规则(Typing rules)_ 将类型分派给术语和 _ 运算规则 _ 来确保程序运算的正确,如下面的属性示例:
如果术语t拥有类型T,在t运算结束后,它的结果将是类型T的值v
Odersky 解释到,以上所说的重要性在于“它为我们提供了一个可以推出语言特性正确性的技术。”

Dotty

Dotty 是一个内部使用 DOT 数据结构的新编译器。它的代码量几乎是现有nsc编译器的一半,同时承诺两倍的速度。Dotty 将包含如下新特性:

  • 交叉类型(Intersection types)(修正了类型无交换性的问题)
  • 组合类型(Union types)(避免了大量过度构建)
  • 方法实参适配(Function arity adaption)(更高效的参数匹配)
  • Trait 参数(trait 类似于 java 中的接口)
  • @static 方法和字段
  • 恒等(Multiversal equality)(像 == 和!= 等操作符现在是类型安全的了)
  • 命名的类型参数

创建这些新特性的初衷包含希望建立一个更好的基础和一个更简单更安全的语言。目前 Dotty 的状态可以在网站查询。
为了保持语言的简单性,Odersky 宣布一些现有的 Scala 特性将被移除

  • 过程式语法(Procedure Syntax)(不是很高效)
  • 类延迟初始化(未被使用)
  • 宏(实验性特性,并不在长期计划中)
  • 预初始化(被 Trait 参数取代)
  • 存在性类型(Existential types)(与 Scala 基础不兼容)
  • 通用类型投影(General Type Projection)(被确定为类型不可靠的)

以上部分特性将被新特性取代,其他的将被移除。
Dotty 的高级工具包含:

  • 与 Scala 的构建工具 sbt 的集成
  • 带语法高亮的可交互式命令行(REPL:read-eval-print-loop)
  • 新的 Intellij 的 Dotty 插件
  • 文档生成(对跨库引用的动态超链接)
  • 一个高效并且更健壮的连接器

Dotty 的架构图如下

其中引入了一个新的序列化类型抽象语法树, TASTY ,它的设计目标为可靠,懒加载,可扩展,精确。Dotty 是在 EPFL 开发的,但 Lightbend 的 Scala 团队负责其基础建设,复审和指导建议。其源代码位于 Dotty 的 GitHub仓库

Scala 2.12 及之后

在 Scala 2.13 的先期计划中,Scala 将专注于找出方法来更新类库,在移除一些现有的极端案例的同时使它们用起来更方便。Odersky 表示这个灵感来源于 Spark 使用弹性分布式数据集 (RDD) 的延迟构建操作来实现集合。
为了更好地调节 Scala 类库。Odersky 提议拆分 Scala 的stdlib

Odersky 邀请开发人员参加现有或新的稻草人提案

小结

Moors 维护着 Scala 官方 GitHub仓库并提供了源码和开发者如何贡献代码的信息。
Lightbend 告诉 InfoQ 在这个夏末,他们正“计划着揭晓一个对数千 Java 和 Scala 开发者进行的调查结果,并分享他们对容器,微服务,原生云应用(cloud-native applications)和其他热点领域的经验。”

查看英文原文: After a Quiet 2015 Martin Odersky Outlined Significant Plans for Scala at Scala Days New York


感谢张龙对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2016-08-11 19:002668
用户头像

发布了 41 篇内容, 共 14.5 次阅读, 收获喜欢 3 次。

关注

评论

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

音乐api接入HIFIVE音乐开放平台,获取百万正版音乐,最快30分钟集成上线!

曲多多(嗨翻屋)版权音乐

API sdk 音乐 物联网,API,sdk

Nacos配置安全最佳实践

Robert Lu

nacos 配置中心

终于有人把 "高可用" 说清楚了

架构精进之路

3月日更

美团优选大数据开发岗面试真题-附答案详细解析

五分钟学大数据

大数据 面试 28天写作 3月日更

开课啦 dubbo-go 微服务升级实战

阿里巴巴云原生

容器 微服务 云原生 k8s dubbo

滚雪球学 Python 之内置函数:filter、map、reduce、zip、enumerate

梦想橡皮擦

28天写作 3月日更

Yarn日志聚合优化—摆脱HDFS依赖

kwang

大数据 YARN

守护网络安全不是问题,iptables的四表五链为你开启“八卦阵”

华为云开发者联盟

网络安全 iptables 虚拟私有云 安全组 网络ACL

身份和访问管理(IAM)

龙归科技

iam 身份和访问管理

【动态规划/路径问题】强化 DP 分析方法练习题 ...

宫水三叶的刷题日记

面试 LeetCode 数据结构与算法

Linux C/C++ 学习路线(已拿腾讯、百度等)

赖猫

c++ Linux服务器开发 LinuxC/C++

世纪联华的 Serverless 之路

Serverless Devs

Java Serverless 架构 运维 云原生

大作业(二)

cc

大厂社招Java面经:蚂蚁金服、拼多多、字节跳动(现已入职蚂蚁)

Java架构之路

Java 程序员 架构 面试 编程语言

#开工新姿势#开启一年新征程,云社区叫你来充电啦!

华为云开发者联盟

内容 技术人 华为云 文章 云社区

华为云PB级数据库GaussDB(for Redis)介绍第四期:高斯 Geo的介绍与应用

华为云开发者联盟

数据库 redis 华为云 geo Gauss DB

在CentOS上安装MySQL,并使用DataGrip远程管理

pyfn2030

centos SSH MySQ datagrip

android开发教程!写给安卓软件工程师的3条建议,一线互联网公司面经总结

欢喜学安卓

android 程序员 面试 移动开发

Linux 查询 OS、CPU、内存、硬盘信息

薇薇

Linux cpu 内存

一个三本生的Java进阶之路:6年时间,从菜鸟到阿里P7!

Java架构之路

Java 程序员 架构 面试 编程语言

如何破解区块链人才的结构性问题?

CECBC

区块链

android开发板!Android开发你需要了解的那些事,大牛最佳总结

欢喜学安卓

android 程序员 面试 移动开发

2021年爆锤39K月薪Offer!阿里巴巴Java面试(知识点)整理

Java架构追梦

Java 阿里巴巴 架构 面试 全栈知识点

Mysql是怎么运行的-读书笔记1

一个大红包

3月日更

四年Java开发,面试核心知识点(腾讯+阿里+快手面经)附答案

Java架构之路

Java 程序员 架构 面试 编程语言

震荡的比特币:区块链的“照妖镜”

CECBC

数字货币

【LeetCode】基本计算器Java题解

Albert

算法 LeetCode 28天写作 3月日更

一文读懂Apache Flume概念、使用和原理

大数据技术指南

大数据 28天写作 3月日更

Redis 如何存储上亿级别的用户状态?

薇薇

数据库 redis 存储

大作业(一)

cc

“看得见 摸不着”的数字货币 助推数字经济强国建设

CECBC

数字经济

Martin Odersky在纽约Scala Days指出,继沉寂的2015之后Scala将有大动作_Java_Michael Redlich_InfoQ精选文章