首页
/ Starknet Cairo 2.10.0版本发布:核心库升级与功能增强

Starknet Cairo 2.10.0版本发布:核心库升级与功能增强

2025-06-27 16:06:07作者:温玫谨Lighthearted

项目背景

Starknet是一个基于零知识证明技术的Layer2扩容解决方案,而Cairo则是Starknet生态中的智能合约编程语言。作为Starkware团队开发的核心组件,Cairo语言专门为可验证计算设计,能够高效地生成STARK证明。本次发布的2.10.0版本是与Starknet 0.13.4配套的Cairo版本,虽然目前新版本编写的合约还不能在Starknet上声明,但为开发者带来了多项重要改进。

核心改进与特性

条件编译功能增强

2.10.0版本实现了cfg属性的逻辑运算符支持,包括notandor。这一改进使得开发者能够编写更复杂的条件编译逻辑,根据不同的编译环境或目标平台灵活控制代码的包含与排除。例如,现在可以轻松实现"仅在测试环境且非Windows平台时包含某段代码"这样的复杂条件判断。

错误处理与诊断优化

本次更新对编译器的错误处理机制进行了多项改进:

  1. 依赖配置错误处理:当检测到依赖项配置错误时,编译器现在会直接panic,而不是继续执行可能导致更隐蔽问题的编译过程。这种"快速失败"的策略有助于开发者更早发现和解决问题。

  2. 十六进制前缀检查:对于需要十六进制格式的输入,当缺少"0x"前缀时,错误信息更加明确,帮助开发者快速定位问题。

  3. 多行诊断信息:改进了多行错误信息的显示,现在会包含最后一行内容,使错误上下文更加完整。

  4. 诊断优先级调整:优化了输出诊断信息的优先级排序,确保最重要的错误信息能够优先展示给开发者。

类型系统与Gas计算改进

  1. 快照类型不匹配:修复了快照类型不匹配时的错误提示,现在会显示正确的类型信息。

  2. 默认Gas重存款:在交易处理中,现在默认会包含Gas重存款操作,这有助于优化交易执行的成本计算。

  3. 有界整数修剪重构:对bounded_int_trim函数进行了重构,提高了代码的健壮性和可维护性。

Starknet类型常量支持

新增了对Starknet类型的常量支持,这使得开发者能够在合约中定义和使用特定于Starknet生态的常量值,提高了代码的可读性和可维护性。

开发者影响与升级建议

虽然2.10.0版本带来了多项改进,但需要注意的是:

  1. 声明兼容性:使用此版本编写的合约目前还不能在Starknet主网上声明,需要等待网络升级。

  2. 错误处理变化:新的错误处理机制可能导致之前一些被忽略的配置问题现在会直接导致编译失败,建议开发者提前检查项目配置。

  3. 条件编译:新增的cfg逻辑运算符为跨平台开发提供了更大灵活性,建议熟悉其使用方式。

社区贡献

本次版本更新特别感谢来自社区的14位新贡献者,他们的工作涉及文档改进、错误信息优化、功能实现等多个方面,体现了Cairo语言生态的活跃度和开放性。

总结

Cairo 2.10.0版本虽然在功能上属于增量更新,但对开发者体验的多个方面进行了优化,特别是在错误处理和诊断信息方面有了显著提升。这些改进虽然看似细微,但对于日常开发效率的提升具有重要意义。随着Starknet生态的不断发展,Cairo语言也在持续演进,为开发者提供更强大、更易用的工具链。建议开发者关注后续的Starknet网络升级计划,以便及时使用新版本的功能。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
144
1.93 K
kernelkernel
deepin linux kernel
C
22
6
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
192
274
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
145
189
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
930
553
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
423
392
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Jupyter Notebook
75
66
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.11 K
0
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
64
511