CAIRO:StarkWare编程语言Cairo1.0测试版开源官方简介

主要内容:

?Cairo1.0开源啦!这仅仅是StarkNet栈开源的第一步。

?我们为读者带来了对Cairo1.0编译器的初步介绍。大家可以开始尝试使用基本的Cairo1.0代码了。

?Cairo1.0的核心与Rust非常相似。

?考虑到这是首次测试,而不是正式版本,优化还在进行当中。第一版的编译器计划在明年一季度初推出。

?目前,StarkNet还不支持Cairo1.0,需要到明年第一季度,StarkNet才会支持Cairo1.0。

介绍

Celo开发组织cLabs提议将Celo转变为基于OP Stack的以太坊L2:7月16日消息,据Celo治理论坛信息,Celo开发组织cLabs提议将Celo由独立的EVM兼容L1区块链转变为基于OP Stack的以太坊L2。该提案经过cLabs团队数月的研究以及Celo和以太坊核心社区成员的初步讨论。

转变后,去中心化定序器将由Celo现有的运行拜占庭容错共识的验证节点集提供支持。链下数据可用性层由EigenLayer和EigenDA提供支持,由以太坊节点运营商运营,并由restaked的ETH提供保护。

社区将于太平洋时间7月21日举行治理电话会议,并将在该会议后发起温度检查治理提案。[2023/7/16 10:57:59]

2020年,我们发布了Cairo,它是一种支持可验证计算的图灵完备编程语言。Cairo开始时是一种汇编语言,后来逐渐变得更具表达力。两个月前,我们宣布了Cairo1.0的诞生,它解决了当下一些主要问题:

稳定币项目Beanstalk在被攻击受损1.82亿美元四个月后将重新启动:金色财经消息,稳定币项目Beanstalk在被攻击受损1.82亿美元四个月后将重新启动。根据该项目的一份声明,该项目将重新启动。在周五结束的投票中,持有该项目99%以上的Stalk代币的人支持重启。

Beanstalk在声明中说,项目代码的更改已由两家公司审计,治理已转移到社区运行的多重签名钱包,直到可以实施安全的链上治理机制。Beanstalk团队早在5月就开始重启稳定币的进程,当时它提议从私人投资者那里筹集7700万美元的场外交易贷款。

今年四月,Beanstalk遭闪电贷攻击,损失近1.82亿美元。[2022/8/7 12:06:54]

?自诞生以来,虽然Cairo的语法结构已经有了很大的改进,但开发者的体验还是有改进的空间的。Cairo1.0是一个受Rust启发的完全类型语言,编写同样的逻辑会更加容易,并且出错的可能性更低。

Stablecorp完成150万美元Pre-A轮融资 参投方包括Circle Ventures:金色财经消息,加拿大金融科技公司Stablecorp完成150万美元Pre-A轮融资,参投方包括Circle Ventures、Genesis、Stellar Development Foundation、SideDoor Ventures、3iQ、Borderless等参投。本轮融资将用于推出VCAD来结合传统金融与链上金融框架。VCAD是使用Versa Bank的Versa Vault技术发行的数字存款票据,以加元存款1:1支持。(prnewswire.com)[2022/4/25 14:48:01]

?现有的编译器与StarkNet本身是在同一个repo中开发的,所以追踪语言变化的困难更大。Cairo1.0编译器是从头开始编写的,所以有更快的功能开发和更多的社区参与。

新加坡WBF交易所“Hotstar”专区将于10月22日进行XLA打折申购:据官方消息,WBF交易所“Hotstar”专区将于10月22日进行XLA打折申购活动(IDO)。具体详请登录官网查看公告。据悉,目前已有多家中国头部社区与XLA达成流量生态合作。

XLA是建立在区块链技术上的全球加密货币。用户可通过XLA在全球任何地方进行支付及结算,旨在成为一种被广泛接受,易于使用并允许人们在日常生活中轻松付款的加密货币。

WBF交易所集团,秉承“不作恶”的价值观和“长期主义”的经营理念,致力于打造全球币种最全、注册用户最多、客户体验最好、技术架构最稳定和最安全的数字金融服务平台。截至2020年5月9日,WBF交易所全球真实注册用户已突破500万,同期最高日活达24万。[2020/10/19]

?现在每一次计算都是可以证明的。目前,一个Cairo程序可能在特定的输入指令下出现失败,使计算无法被证明。在Cairo1.0中,程序在每个可能的分支中都是可证明的。这对StarkNet中的DOS保护和抗审查尤为重要。

Blockstack启动分布式应用程序商店:Blockstack宣布推出一个新的通用Dapp(分布式应用)商店,该平台名称为App.co。包括大约138个生态系统应用程序的聚合列表,通过利用诸如区块链、加密货币、IPFS、Zeronet等分布式技术的优势来提供实用价值。[2018/5/18]

?今天,我们达到了上述目标方面的第一个里程碑,因为我们将开发工作转移到了公共repo,并将Cairo1.0开源!现在,开发人员可以编译和执行简单的Cairo1.0程序。由此,开发者可以开始尝试使用Cairo1.0,并逐渐适应新的功能,即使在这个阶段,他们还不能在StarkNet上实现。

目前的性能

目前,你可以编译和执行基本的原生Cairo程序。虽然许多语法/语言的优化仍在进行中,但你还是可以慢慢去习惯Cairo1.0,享受升级带来的好处。

请注意,目前仍然无法编写StarkNet合约。StarkNet语法会在未来几周内添加。

代码示例

为了说明旧的语法和Cairo1.0之间的差异,我们选择了几个不同的实现/类型模板来展示找到第n个斐波那契数。

例一:匹配表达式

在Cairo1.0中,你可以使用类似Rust的匹配表达式。你再也不用担心if/else语句会导致引用撤销了!

例二:数据类型

Cairo0使用的是felt和指针,而在Cairo1.0中,我们可以在语言中访问复杂的数据类型。下面你可以看到一个例子,它生成了一个前n个斐波那契数的数组。

如上所示,我们没有直接使用内存指针,而是使用`Array::<felt>`类型和`array_append`函数。

例三:结构体和所有权

下面的代码说明了Cairo1.0中结构体的用法。

下面这段话是为Rust开发者准备的。Cairo1.0管理内存的方式与Rust类似。而且,它使用了所有权和借用的概念。因此,通过访问`FibResult`结构体的一个成员,我们已经移动了`result`,这意味着除非FibResult是可复制的,否则我们不能在`result.index`中再次访问它。为了解决这个问题,我们在`FibResult`类型中添加了`#`属性。在未来的版本中,我们会为结构体添加自动解构功能。在不影响其他成员的情况下移动某个成员的所有权。

特别要注意的是,Cairo1.0完全抽象掉了Cairo原有的内存模型。

例四:错误传播

下面的代码是计算第n个斐波那契数,但与前面的例子不同,所有的输入指令都是uint128类型的。注意,这解决了Cairo0中处理uint的一个主要痛点。在这里,uint128是原生类型。

两个128个比特位的整数相加会导致溢出。上面的代码使用Option枚举和问号运算符来处理其中一个中间加法中的溢出情况。与目前的uint256加法语法相比,必须调用`unit256_check`函数来保证完整性。此外,在不久的将来,我们会在语言中加入`panic`的概念,像加法溢出这样的简单错误会是无法捕捉并自动传播的,也就是说,你在添加uint时不必使用`Option`或`?`。

赶紧试试吧

你现在可以编译和运行当前支持的Cairo1.0程序了。按照这些说明,学会使用`cairo-run`指令。注意,它的后台由Lambdaclass开发的RustCairoVM执行指令。

你可以在这里找到更多的例子帮助你入门。请注意,这只是对编译器开发的第一次测试;未来几周,我们会随着编译器改进CLI。

未来计划

第一版编译器的重点是支持Cairo1.0中StarkNet的所有功能,该版本计划在明年第一季度推出。此外,我们正在努力扩展Cairo1.0编译器的功能。未来几周,即将上线:

?StarkNet的性能——编写智能合约和使用系统调用。

?循环

?新的库函数

?优化的语言服务器

?StarkNetgas的概念

请务必保持关注并跟踪编译器的进展!

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

链链资讯

火币交易所BOC:推文:探测Etherscan上钱包4

我会不会需要一个关于Crypto.com冷钱包设置的解释器?我决定在Etherscan上探测一下钱包4,这是我所看到的情况: 几乎所有的流入都来自只从交易所或其他进行dex交易的钱包收到的地址.

NEAR比特币:Arthur Hayes:CBDC——彻底的邪恶

以下所表达的任何观点均为作者的个人观点,不构成任何投资建议。也许除了光速,一切都是相对的。因此,当我称央行数字货币为“纯粹之恶”时,下一个合乎逻辑的问题应是——从谁的角度来看?对一些人来说是邪恶.

[0:0ms0-11:488ms