
集 Python、C、R、Ruby 之所长,动态编程语言 Julia 1.0 正式发布
动态编程语言 Julia 迎来了 1.0 正式版本,下载地址:
https://julialang.org/downloads/
Julia 可以看作是一门集众家之所长的编程语言,在首次公开时开发团队就已明确其需求:
我们想要一种拥有自由许可的开源语言,同时拥有 C 的速度和 Ruby 的灵活。我们想要一种同像性语言,有像 Lisp 这样真正的宏,也有像 Matlab 这样的浅显熟悉的数学符号。我们想要一门像 Python 一样可用于通用编程,像 R 一样易于统计,像 Perl 一样自然地用于字符串处理,像 Matlab 一样强大的线性代数,像 shell 一样擅长将程序粘合在一起的语言。它简单易学,却能让严苛的黑客为之倾心。我们希望它是交互式的,具备可编译性。
开发团队表示,围绕这一语言,一个充满活力的社区已蓬勃发展起来,为实现同一目标,来自世界各地的开发者们不断地重塑并精炼 Julia 。超过 700 人对 Julia 做出了实质性贡献,还有更多的人数以千计的令人惊叹的 Julia 开源包。总之,我们构建了这样一种语言:
快速:Julia 为高性能而生。Julia 程序通过 LLVM 为多个平台编译高效本地代码。
通用:它使用多分派(multiple dispatch)作为范例,使得表达许多面向对象和函数式编程模式变得容易。标准库提供异步 I / O 、进程控制、日志记录、性能分析、包管理器等。
动态:Julia 是动态编程语言,与脚本语言相似,并且对交互式使用有很好的支持。
专业:它擅长于数值计算,其语法非常适合数学,支持多种数字数据类型,和开箱即用的并行性。Julia 的多分派非常适合定义数字和数组类型的数据类型。
(可选)多样:Julia 具有丰富的描述性数据类型,类型声明可用于阐明和巩固程序。
可组合:Julia 的包可以很好地协同工作。单位数量的矩阵,或货币和颜色的数据表列都可以组合工作 - 并具有良好的性能。
想要尝试 1.0 的用户,如果是从 Julia 0.6 或更早版本升级代码,建议先使用 0.7 过渡版。0.7 版本包括弃用警告,可以帮助指导你完成升级过程。等到你的代码不再出现警告,就可以直接升级至 1.0 而不会产生任何功能性更改。已注册的软件包也正在利用 0.7 的过渡期发布 1.0 兼容的更新。
当然,Julia 1.0 中最重要的一个新特性是对语言 API 稳定性的承诺:你为 Julia 1.0 编写的代码将可以继续在 Julia 1.1、1.2 等版本中运行。语言是“完全成熟的”,核心语言开发者和社区都可以专注于基于这个坚实的基础去构建软件包、工具和新特性。
Julia 1.0 不仅仅涉及稳定性,还引入了一些新的、强大的和创新的语言功能。自 0.6 版本以来的一些新特性包括:
全新的内置包管理器带来了巨大的性能改进,使包及其依赖项安装变得前所未有的简单。它还支持 per-project 的包环境,并记录工作应用的确切状态,以便与他人共享 - 以及你未来的项目。此外,还引入了对私有包和包存储库的无缝支持。你可以使用与开源软件包生态系统相同的工具来安装和管理私有软件包。
Julia 有一个新的缺失值表示规范。能够表示和处理缺失的数据是统计和数据科学的基础。采用典型的 Julian 方式,新的解决方案具有通用性、可组合性和高性能。任何泛型集合类型都可以通过允许元素包含预定义值来有效地支持缺失值 missing 。在之前的 Julia 版本中,这种“统一类型化”集合的性能会太慢,但随着编译器的改进允许 Julia 匹配其他系统中自定义 C 或 C ++ 缺失数据表示的速度,同时也更加通用和灵活。
内置 String 类型现在可以安全地保存任意数据。你的程序不会因为无效 Unicode 的单个丢失字节就浪费数小时或数天的时间。保留所有字符串数据,同时指示哪些字符有效或无效,使你的应用程序可以安全方便地处理具有所有不可避免的瑕疵的真实数据。
广播(broadcasting)已经成为一种具有方便语法特性的核心语言功能 - 它现在比以往更强大。在 Julia 1.0 中,将广播扩展到自定义类型并在 GPU 和其他矢量化硬件上实现高效优化计算很简单,为将来更高的性能提升铺平了道路。
命名元数组是一种新的语言特性,它使得通过名称有效和方便地表示和访问数据。例如,你可以将一行数据表示为 row = (name="Julia", version=v"1.0.0", releases=8) 并使用 row.version 访问该 version 列,其性能与不那么方便的 row[2] 相同。
点运算符现在可以重载,允许类型使用 obj.property 语法来获取除 getting 和 setting 结构字段之外的含义。这对于使用 Python 和 Java 等面向对象的语言进行更顺畅的互操作时特别有用。属性访问器重载还允许获取一列数据以匹配命名元组语法的语法:你可以编写 table.version 访问 version 列,就像使用 row.version 访问 version 行的字段一样。
Julia 的优化器在很多方面远比下面列出来的还要更聪明,但这些亮点仍值得一提。优化器现在可以通过函数调用传播常量,从而允许比以前更好地消除无用代码和静态评估。编译器在避免在长期对象周围分配短期包装器方面也要好得多,这使得开发者可以使用方便的高级抽象而无需降低性能成本。
现在始终使用与声明相同的语法调用参数类型构造函数,这消除了语言语法中比较模糊且令人困惑的角落。
迭代协议已经完全重新设计,以便更容易实现多种迭代。
作用域规则(scope rule)已经简化。无论命名的全局绑定是否已存在,局部作用域的结构现在都是一致的。这消除了先前存在的 “soft/hard scope” 差异,并且意味着 Julia 现在可以始终静态地确定变量是本地的还是全局的。
语言本身非常精简,许多组件被拆分为“标准库”软件包,而不再属于“基础”语言的一部分。如果需要,可以导入它们(不需要安装),但它们不再被强加给你。在未来,这也将允许标准库独立于 Julia 本身进行版本控制和升级,从而允许它们以更快的速度发展和改进。
对 Julia 的所有 API 进行彻底的评估,以提高一致性和可用性。许多模糊的遗留命名和低效的编程模式已被重命名或重构,以更优雅地匹配 Julia 的功能。这使得处理集合更加一致和连贯,以确保参数排序遵循整个语言的一致标准,并在适当的时候(更快的)将关键字参数整合到 API 中。
此外,围绕 Julia 1.0 的新特性,还正在构建许多新的外部软件包。像是:改进数据处理和操作生态系统,以利用新的缺失支持。
Cassette.jl 提供了一种强大的机制,可以将代码转换传递注入 Julia 的编译器,从而实现事后分析和现有代码的扩展。除了用于分析和调试等开发工具之外,这甚至可以实现机器学习任务的自动区分。
异构体系结构支持得到了极大的改进,并且与 Julia 编译器的内部结构进一步分离。
有关更改的完整列表,可参阅:
0.7 NEWS file:
https://docs.julialang.org/en/release-0.7/NEWS/
Julia 1.0:
https://julialang.org/blog/2018/08/one-point-zero
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
R 语言:数据科学与科研领域的核心工具及优势解析 一、引言 在数据驱动决策的时代,无论是科研人员验证实验假设(如前文中的 T ...
2025-09-08T 检验在假设检验中的应用与实践 一、引言 在科研数据分析、医学实验验证、经济指标对比等领域,常常需要判断 “样本间的差异是 ...
2025-09-08在商业竞争日益激烈的当下,“用数据说话” 已从企业的 “加分项” 变为 “生存必需”。然而,零散的数据分析无法持续为业务赋能 ...
2025-09-08随机森林算法的核心特点:原理、优势与应用解析 在机器学习领域,随机森林(Random Forest)作为集成学习(Ensemble Learning) ...
2025-09-05Excel 区域名定义:从基础到进阶的高效应用指南 在 Excel 数据处理中,频繁引用单元格区域(如A2:A100、B3:D20)不仅容易出错, ...
2025-09-05CDA 数据分析师:以六大分析方法构建数据驱动业务的核心能力 在数据驱动决策成为企业共识的当下,CDA(Certified Data Analyst) ...
2025-09-05SQL 日期截取:从基础方法到业务实战的全维度解析 在数据处理与业务分析中,日期数据是连接 “业务行为” 与 “时间维度” 的核 ...
2025-09-04在卷积神经网络(CNN)的发展历程中,解决 “梯度消失”“特征复用不足”“模型参数冗余” 一直是核心命题。2017 年提出的密集连 ...
2025-09-04CDA 数据分析师:驾驭数据范式,释放数据价值 在数字化转型浪潮席卷全球的当下,数据已成为企业核心生产要素。而 CDA(Certified ...
2025-09-04K-Means 聚类:无监督学习中数据分群的核心算法 在数据分析领域,当我们面对海量无标签数据(如用户行为记录、商品属性数据、图 ...
2025-09-03特征值、特征向量与主成分:数据降维背后的线性代数逻辑 在机器学习、数据分析与信号处理领域,“降维” 是破解高维数据复杂性的 ...
2025-09-03CDA 数据分析师与数据分析:解锁数据价值的关键 在数字经济高速发展的今天,数据已成为企业核心资产与社会发展的重要驱动力。无 ...
2025-09-03解析 loss.backward ():深度学习中梯度汇总与同步的自动触发核心 在深度学习模型训练流程中,loss.backward()是连接 “前向计算 ...
2025-09-02要解答 “画 K-S 图时横轴是等距还是等频” 的问题,需先明确 K-S 图的核心用途(检验样本分布与理论分布的一致性),再结合横轴 ...
2025-09-02CDA 数据分析师:助力企业破解数据需求与数据分析需求难题 在数字化浪潮席卷全球的当下,数据已成为企业核心战略资产。无论是市 ...
2025-09-02Power BI 度量值实战:基于每月收入与税金占比计算累计税金分摊金额 在企业财务分析中,税金分摊是成本核算与利润统计的核心环节 ...
2025-09-01巧用 ALTER TABLE rent ADD INDEX:租房系统数据库性能优化实践 在租房管理系统中,rent表是核心业务表之一,通常存储租赁订单信 ...
2025-09-01CDA 数据分析师:企业数字化转型的核心引擎 —— 从能力落地到价值跃迁 当数字化转型从 “选择题” 变为企业生存的 “必答题”, ...
2025-09-01数据清洗工具全景指南:从入门到进阶的实操路径 在数据驱动决策的链条中,“数据清洗” 是决定后续分析与建模有效性的 “第一道 ...
2025-08-29机器学习中的参数优化:以预测结果为核心的闭环调优路径 在机器学习模型落地中,“参数” 是连接 “数据” 与 “预测结果” 的关 ...
2025-08-29