Cointime

扫码下载App
iOS & Android

化繁为简:Cairo1.0如何改变StarkWare的编写范式

1 月 5 日,StarkWare 宣布正式推出编程语言 Cairo 1.0 公开版本,正式取代为期两年的测试、预览版本,也标志着使用该语言在 StarkNet 上编写智能合约已经成为可能,同时也会兼顾高效的执行效率,成为 ZK 系 Layer 2 Rollup 技术派的里程碑事件。

此次更新的功能可归纳为三点,分别是智能、效率和安全。

更为智能:实现 Sierra 设计,确保 Cairo 代码可证明,StarkNet 智能合约将在下一个版本中实现。

更加高效:跟进 Rust 语言的强类型、所有权机制和借用等设计思路,兼顾执行效率和编写规范性;

更为安全:保持图灵完备性,STARK 机制的安全性由数学证明来保证;

Cairo 1.0 公开版的工作流程将与以往有所不同,最主要的开发方向将是在智能合约编写能力和开发者友好方面进行持续改进。

两全:走向 ZK-EVM

在本轮的 Layer 2 缠斗中,ZK 系中的 STARK 和 SNARK 成为两大主流路线,但 EVM 兼容性和执行效率也成为各方关注的焦点,更好的兼容性将会获得以太坊主网的安全性加持,而较高的执行效率则会加快 L2 自身的执行速度。

但这其中存在一个悖论:EVM 兼容性和执行效率往往无法兼得,越好的 L1 兼容性则会降低 L2 执行效率,反之则存在安全性问题。

因此 StarkWare 希望能使用 Cairo 语言作为两者之间的黏合剂,通过其编写的智能合约不仅可在 StarkNet 上全速运行,也可和以太坊主网保持较高的兼容性,这也是 ZK-EVM 的真正含义。

在本次更新中,Cairo 将会支持完整的 Cairo-VM,其中的关键就在于中间表示层 Sierra。

简单而言,Sierra 将作为 Cairo 语言编写的代码和其底层字节码之间「翻译层」,并且这种翻译将在确保安全性的基础上进行提速,而无需设置交易的执行状态,直接可根据当前状态开展证明。

这是 Cairo 自身的语法改进,除此之外,StarkWare 的智能合约也将逐步过渡到完全的 Cairo 语言上去,以完成自身的语言标准的统一。

由于保持了相当程度的以太坊主网兼容性,Cairo 和 Solidity 编写的智能合约之间的转换也将更为简易,以太坊客户端 Nethermind 的转译器 Warp 已经支持将 Uniswap V3 重写为 Cairo 代码。

实际上,在 2022 年 10 月末,StarkNet 便宣称使用 Cairo 开发出 ZK-EVM,而在接下来随着 StarkNet 的真正投入生产环境,这种兼容性的实际效果便可一验真伪。

新芽:基于 Rust 的平衡特性

事实上,Cairo 本身可以视为 Rust 语言写就的语言,其继承了较多的 Rust 特性。

Rust 本身不同于 Python/Go 等所谓的现代语言,其运行效率高度接近于较为底层的开发语言,但同时又兼顾了可读性,比如特殊的内存管理机制——所有权(ownership)和借用等特殊设计。

准确而言,Cairo/Rust 的所有权是指管理内存的显性要求,由于区块链特殊的节点运行机制,其是典型的内存敏感性开发环境,以 C/C++、Java 为例,目前主流有三种内存资源利用机制:

C/C++:手动管理内存,得益于(受害于)现代设备的进步,大多数开发者并未养成及时释放内存的习惯,会造成严重的资源浪费;

Java:自动回收资源机制,JVM 是 Java 运行时的虚拟机,其具备自动管理内存的功能,但一般为保证运行效率,JVM 会保持一段的内存资源,也会造成供需不匹配的问题;

Cairo/Rust:所有权机制管理内存资源,Rust 中的任何变量必须指定所有者,并且一次仅能有一个,当变量执行后即被释放,不能继续存在内存中。

这样的所有权机制设计可以保证宝贵的内存资源仅在执行时调用,即可以兼顾 C/C++ 的运行效率,但又避免了内存泄漏等问题,内存资源无需时刻准备着,对于减轻智能合约的整体大小具有重要意义。

其次是强类型的思路,Cairo/Rust 涉及众多智能合约的编写和运行,而其上承载的都是高价值的 Token、NFT 以及个人数据,需要特殊对待,并且每次改变都需要慎重对待。

强类型语言和弱类型语言是相对于变量的定义而言的,简单而言,强类型要求变量在使用前进行「数据类型"方面的定义,如整数、浮点数、字符串等,未经明确的类型变换操作,不可随意更改其定义。

弱类型语言并无此严格规定,变量的数据类型可灵活改变。

在智能合约的编写中,资产类型和数量必须被显性对待,以确保其归属权清晰和交易、转换等流程明确,而 Cairo/Rust 的可读性强,其对开发者较为友好,便于避免更多的安全问题。

按照官方进度,Cairo 1.0 的编译器将在今年一季度面世,届时,将和 StarkNet 进行更深度的融合,而借助 Rust 的语言特性,有望从底层提高执行速度,从而将其 TPS 抬升到日常可用的水平。

重生:开发者友好

Cairo 1.0 肩负着打通 L2 和以太坊主网的重任,根据其官方的 Regenesis(重生)计划,StarkNet 将在 2023 年一季度完全过渡到 Cairo 之上,结束目前的割裂状态,从而进入生态竞争的新发展阶段。

而缺乏真正杀手级的应用,再叠加上 dYdX 等头部项目的出走,StarkWare 的晋级之路仍然布满荆棘。

在目前的公链 /L2/dApp 开发格局中,Solidity(Vyper)占据了近 98% 的垄断地位,而 Cairo 仅占据不到 1% 的市场空间,基本上目前只有 StarkWare 能够支撑起运行。

自从 StarkNet 和 StarkEx 设立以来,由 Cairo 驱动的 dApp 已经处理了超过 3 亿笔交易,铸造了超过 6500 万个 NFT,并处理了价值 7000 亿美元的交易,并且这些交易都利用以太坊上作为最终结算层。

在 Cairo 1.0 真正应用至 StarkNet 之前,开发者的体验是争夺其进入 StarkWare 生态的第一步,除 Nethermind 的 Warp 支持之外,ConsenSys 也和 StarkWare 达成合作,将为 Cairo 提供智能合约提供安全审计服务。

根据官方说明,目前 Cairo 0 的各项功能开发进度如下,我们也可从中参照 Cairo 1.0 的发展方向,并且说明 StarkWare 将会遵循将全部 StarkNet 开源的计划,Cairo 将是其开迈出的第一步。

相关阅读:盘点 StarkWare 生态:StarkEx 共 7 个应用,StarkNet 105 个生态项目

可以从中发现,Cairo 的功能开发进度较快,并且预计实现的功能也较多,而 StarkNet 也将在 Cairo 实现后补齐目前的功能缺口,而最终实现 StarkNet 系统级调用的全功能模块。

目前可以适当参考下 StarkEx 的数据,不同于 StarkNet 的通用化路线,StarkEx 面向主要几个大型项目,包括 Immutable X、Sorare、Rgino.Fi 和 dYdX,使用过服务的用户数达 2 千万人次,日均月活在数万量级。

借助和成熟的 DeFi 和链游进行合作,StarkEx 的市场化之路整体较为顺利,但是 StarkNet 将作为通用 Layer 2 参与各个 L2 竞争之中,Cairo 将有望进一步带动 StarkNet 市场占有率的提升。

结语

Cairo 1.0 并非简单作为语言更新,而是要承担更为丰富的角色,包括激活 StarkNet 的 EVM 兼容性和执行效率,通过借助 Rust 成熟的编程范式,如所有权、强类型等,减轻了开发难度。

同时需要注意,Cairo 1.0 仍有些未完全实现的功能,其完全状态可能需要更长的开发周期,其 Token 发行时间也会随之进行调整。

总之,Cairo 在结束 StarkNet 目前的「非完全」版具有重要意义,结合 Sierra、编译器等新工具,以及和主流开发工具的结合,显著减少开发者在其上编写智能合约的压力。

评论

所有评论

推荐阅读

  • 5月16日晚间要闻速递

    1. ETH跌破3,000.00美元

  • 游戏平台Param Labs完成700万美元融资,Animoca Brands领投

    游戏平台Param Labs完成700万美元融资,Animoca Brands领投,Delphi Ventures和Cypher Capital参投。Param Labs的目标是建立一个由其原生PARAM代币管理的游戏生态系统,该代币即将推出。该公司的第一款游戏“Kiraverse”是一款边玩边赚钱的多人射击游戏。

  • 区块链SaaS解决方案AfriDex完成500万美元Pre-Seed轮融资,Endeavor Ventures领投

    总部位于英国伦敦的区块链软件即服务解决方案 AfriDex 宣布完成 500 万美元 Pre-Seed 轮融资,Endeavor Ventures 领投,African Crops Limited、Oldenburg Vineyards 和 Hank Oberoi 参投。AfriDex 目前主要专注于农业市场,通过全面的链上解决方案为供应链参与者提供支持和保护,利用区块链技术实现可追溯性、无摩擦支付、防欺诈交易、经过验证的认证、简化税收和补贴管理。(finsmes)

  • 以太坊上假冒NOT代币发生Rugpull

    据PeckShield监测,以太坊上假冒Notcoin NOT下跌100%。0xE0eB开头地址抛售了 1,645,040,633,338,481.95枚NOT并兑换为93.5枚WETH(价值28.13万美元)。 注:Rugpull代币与合法代币名称相同。

  • 瑞士联邦委员会计划实施加密资产报告框架以提高税收透明度

    瑞士联邦委员会(由七名成员组成,共同领导瑞士政府)打算实施加密资产报告框架(CARF),以提高税收透明度。15 日,联邦委员会发布了一份咨询文件,以调查加入国际税务机关合作打击偷税漏税的自动信息交换(AEOI)的民意。目前,瑞士加入 AEOI 的时间定于 2026 年 1 月 1 日。据悉,经合组织(OECD)为 20 国集团(G20)国家建立了 AEOI 和其他倡议,后来扩大到包括其他国家。瑞士此前在 2014 年采用了经合组织的共同报告标准(CRS),但未纳入监管加密资产及其提供商处理的 CARF。(Cointelegraph)

  • 埃及RWA金融科技初创公司Mnzl完成350万美元种子轮融资,P1 Ventures等领投

    金色财经报道,埃及RWA金融科技初创公司Mnzl宣布完成350万美元种子轮融资,P1 Ventures、Localglobe 和 Ingressive Capital领投,500 Global、Flat6Labs、First Circle Capital、Enza Capital、Beenok和一批未透露姓名的天使投资人参投。Mnzl 允许用户将汽车和房地产等非流动资产转换为流动资产,并将资产上传到数字钱包进行管理。

  • 4月加密项目融资额增环比增长3.8%至13.6亿美元

    Messari 发布 2024 年 4 月融资报告。2024 年 4 月,加密货币项目融资交易额环比增长 3.8%,达到 13.6 亿美元,自 2023 年 8 月低点(3.72 亿美元)以来持续 8 个月的增长趋势;但融资交易数量下降 16.7%,仅 259 笔。4 月网络领域的投资额占总投资额的 37.7%,大额融资项目包括 Monad(融资 2.25 亿美元)等。值得注意的是,4 月比特币 Layer2 项目激增,多个项目从隐身模式中脱颖而出。金融和基础设施领域也出现显著的融资活动,与前几个月相比,资本在各个类别中的分布更加均衡。

  • 摩根士丹利披露其对灰度GBTC投资近2.7亿美元,成为最大持有者之一

    5月16日消息,摩根士丹利(Morgan Stanley)在Q1提交给SEC的13F文件中披露,其通过灰度GBTC向现货比特币ETF投资了2.699亿美元。根据Fintel的数据,这笔投资使其成为继Susquehanna International Group(投资10亿美元)之后,GBTC的最大持有者之一。 摩根士丹利也是众多披露了对现货比特币ETF投资的全球系统重要性银行(G-SIB)之一,其他银行包括加拿大皇家银行、摩根大通、富国银行、法国巴黎银行和瑞银集团。

  • Coinbase计划为澳大利亚自助养老金部门提供服务

    Coinbase计划为澳大利亚的自助养老金部门提供服务。交易所亚太区总经理John O’Loghlen告诉彭博社:“我们不认为这会损害ETF玩家的利益。”Coinbase正在开发一项专门针对澳大利亚自助养老金部门的服务。自2019年3月以来,澳大利亚的自助基金越来越多地持有加密货币。根据澳大利亚税务局的最新数据,近10亿澳元(6.64亿美元)用于加密货币。成千上万的澳大利亚人使用自助养老金基金押注加密货币,甚至在2023年3月据路透社报道,有人损失了数百万美元。

  • 美国立法者:美SEC应在参议院投票前废除加密会计政策

    美国立法者 Wiley Nickel 在 5 月 15 日致美国证券交易委员会(SEC)主席 Gary Gensler 的一封信中表示,美 SEC 应在参议院投票前废除加密会计政策(SAB 121)。保护投资者是美国证券交易委员会的使命,然而 SAB 121 恰恰相反,它阻止了受到严格监管的美国银行大规模托管数字资产。此外,Wiley Nickel 批评美 SEC 在发布 SAB 121 时绕过了规则制定程序,他认为加密会计政策的目的是澄清现有政策,而不是制定新政策。 此前消息,白宫于 5 月 8 日发布「政府政策声明」表示,限制美 SEC 为加密资产维持全面有效的金融监管框架的能力,将带来严重的金融不稳定和市场不确定性。