火星链 火星链
Ctrl+D收藏火星链

TRA:一文了解Substrate与智能合约的异同

作者:

时间:1900/1/1 0:00:00

原创:王大锤搬运:PolkaBase这个系列面向的是智能合约开发者,或者是在智能合约和自己定制区块链之间摇摆不定的从业者。希望读完这个系列之后,可以帮助大家更好地了解Substrate与智能合约的异同,面对不同的业务需求时,可以更加高效进行技术选型。同时,也希望可以给大家提供一些有趣的视角来看待Substrate,欢迎任何反馈。什么是Substrate?

简单来说,Substrate是一个构造区块链的“轮子”。在Substrate之前,如果大家想要快速构造一条链,选择是非常少,而且可定制化程度也很低。基本上公链会forkBitcoin,联盟链会直接使用Hyperledger。Substrate是一个开箱即用的构造区块链的SDK,从简单的智能合约,到中层的链上逻辑,或者底层的p2p网络、数据库、共识,都可以自由定制。关于Substrate入门介绍文章已经很多了,这里就不赘述了。想入门的同学可以看看下面的资料:Substrate初次亮相视频15分钟速成搭链什么是Substrate-fromboka.network什么是Substrate-fromEthfans想要了解更多的童鞋也可以自行google。什么是智能合约

智能合约是部署在区块链之上的一段代码,可以按照合约里预先设定的不可篡改的规则执行功能。因目前主流的智能合约指的都是以太坊上的智能合约,下文中的智能合约指的都是以太坊网络中的智能合约。SubstrateVS智能合约

DCG要求法官合并集体诉讼案以避免相互矛盾的判决:金色财经报道,数字货币集团DCG及其首席执行官Barry Silbert要求合并两起集体诉讼案,这两起案件具有相同的事实、法律问题和几乎相同的类别定义。被告还辩称,为避免裁决冲突和提高司法效率,有必要将两案合并。

康涅狄格州的诉讼称,在三箭资本启动清算程序后,Silbert策划了一场误导性交易,以掩盖11亿美元内爆的迹象。被告面临着因作出误导性或虚假陈述而犯有证券欺诈的指控。

在持续的诉讼中,DCG已经决定关闭其主要经纪子公司TradeBlock。据该公司称,这一决定源于更广泛的经济状况和美国加密货币的不确定监管环境。[2023/6/2 11:54:55]

在这里,会从最宏观的角度去理解Substrate和智能合约的异同,不会涉及到具体的功能性demo和细节。更加详细的主题我们会在后续的文章中提及。1.存储类型1.1智能合约和Substrate都有的boolintegersaddress(`accountIdinSubtrate)arraymapenum1.2智能合约(Solidity)中独有的string:虽然存在string类型,但是没有完善的string处理方法1.3Substrate中特有的linked_map:可以遍历的mapper_things:可以认为定点数double_map:双键mapenum:这里单独列出来,是因为solidity中的enum只是数字的枚举,而substrate中的enum包含类型信息1.4单独说明Substrate中没有stringSubstrate中没有string类型,与string对应的,只有Vec<u8>。这就要涉及到Substrate或者是区块链的设计哲学。链上存储是很宝贵的,并且string和Vec<u8>是相互可转换的,因此Substrate决定不用string.Substrate中的enumSolidity和Substrate中都有enum,但是两者存在的意义对整个系统来说是完全不同的。Solidity中的enum更像是一个数字的文字化表述,例如下面的定义:

FTX将在Voyager收购案中支付5100万美元现金,价值13.1亿美元的加密资产将按比例分配给债权人:10月1日消息,法庭文件显示,FTX在对Voyager的收购中支付了5100万美元的现金,针对Voyager知识产权、用户等产生的约6000万美元溢价则由给予迁移至FTX的Voyager用户的每人50美元信用额度以及总计2000万美元的津贴抵消。此外,价值约13.1亿美元的加密资产将按比例分配给符合条件的债权人。[2022/10/1 22:43:31]

这里的Red,Yellow和Green其实只是0,1,2而已。而Substrate中的enumhttps://doc.rust-lang.org/book/ch06-01-defining-an-enum.html则可以携带类型信息,功能强大。例如Substrate中的Error,

Substrate中的linked_map与Solidity中的map写智能合约的最大的痛之一就是,很简单的存储逻辑却需要多种类型的组合使用。例如以下场景,想要记录一个班级中所有的学生信息,在智能合约中,需要如下声明:

Axie Infinity宣布Ronin Bridge已正式开放:据官方消息,Axie Infinity宣布Ronin Bridge已正式开放,用户现在可以轻松地在Ronin(RON)网络上进行充提。用户拥有的所有wETH和USDC都由新桥1:1完全支持,新桥设计包括一个断路器系统作为应急计划,可通过阻止大量可疑提款来增加桥的安全性。

Ronin Bridge在推出之前已进行一次内部审计和两次外部审计(由Verichains和Certik完成)。

此外,Axie Infinity可能会在本周发布土地质押(Land Staking)功能。[2022/6/28 1:37:20]

并且对array进行元素删除并且是一件O(n)的操作,这意味着我们无法支付的起昂贵的gas费用,并且涉及到多个存储的更改,稍不留神可能就会出现逻辑错误。Substrate中提供了多种map,包括map,linked_map,double_map。其中linked_map即是对map提供了iterate的功能。这使得存储和逻辑变得更加贴近真实。想要深入学习Substrate中存储类型的童鞋,请移步Substratec存储类型概览https://zhuanlan.zhihu.com/p/1035109592.更加深度的定制作为一个前智能合约er,深知dapp的痛:gas费用太高,用户玩不起;出块时间长,用户等不起;一般dapp都会有自己的token,但是用户必须现有eth才可以玩,这对不习惯区块链的用户来说是一大门槛;新用户经常弄丢私钥,资产都没了;...这当然不是智能合约的错。站在昨天,智能合约是划时代的产物;站在现在,智能合约的不足需要新的技术来弥补。有些dapp开发者选择不在eth公链上部署dapp,而是自己使用eth开发私链来部署自己的dapp,确实可以解决上述的部分问题,但是类似私钥、多种token对用户门槛的提高,仍然是无法避免的。而Substrate作为区块链开发的“轮子”,因为优秀的框架设计和抽象分层,给开发者提供了多阶定制选择:

中国支付清算协会:推广数字人民币新场景:金色财经报道,据中国支付清算协会微信官方公众号,6月6日,中国支付清算协会发布关于助力稳住经济的倡议书,其中指出为进一步贯彻《国务院关于印发扎实稳住经济一揽子政策措施的通知》,中国支付清算协会倡议各会员单位助力消费提升。做好非接支付产品和服务的开发,协助发放消费券、优惠券等,协助拓展消费新业态,推广数字人民币新场景。[2022/6/7 4:07:39]

Substrate分层这里简单介绍一下Substrate的分层,想要深入了解的童鞋可以自己搜索一下,SubstrateNode:节点层。在这一层基本上不做什么改动。就是编译一下就可以运行一个节点了。如果想要做一些改动,就重写一下创世配置文件就好了。重新定义链中的参数,但是无法修改链的运行逻辑。SubstrateFRAME:runtime层。基本上绝大部分的定制化都发生在这一层。在这一层大家可以做的事情很多,概括起来就是修改区块链的运行逻辑。比如转账、治理、链上升级逻辑、staking等都发生在这一层。是智能合约开发者最需要关注的一部分。SubstrateCore:核心层。整个FRAME/runtime层在Core面前都可以被忽略。可以用任何语言从0开始搭建一个runtime,只要它最终可以被编译成WebAssembly.这一层主要包括区块链的一些底层组件,包括共识、数据库、p2p网络等。对于智能合约开发者而言,我们把大部分目光放在FRAME层就可以了。在这一层中,大家可以实现任何可以用智能合约实现的功能,以及用智能合约办不到的事情。比如:自定义tokensystem,除了转账,还实现链逻辑层面上的锁仓、自定义释放规则等;自定义区块间隔时间和手续费:这里,所有原先区块链的出快慢、手续费高的烦恼都可以丢掉,开发者可以自定义出块时长,以及操作手续费多少;实现链逻辑的整体升级;实现链的治理;实现多种账户支持,例如在用户丢失私钥的情况下,如果保证用户的资产不受损失;....所有对区块链操作门槛、用户友好、响应速度的抱怨,都可以在runtime层通过巧妙地设计来化解。接下来会详细聊到其中的一些部分。3.不用重复“造轮子”solidity智能合约开发者,还有一层痛苦就是,需要不停地ctrl+C和ctrl+V。因为solidity是独立于现有编程语言系统的,没有任何可以直接调用的依赖;solidity里自带的library,与其说是library,更像是一段“不配拥有地址的”代码引用。即使有import,前提也是依赖必须自己写。哪怕复制粘贴。这使得大家在写solidity代码的时候,无法直接找到现有轮子,然后下载引入;而是复制粘贴+改写,某种程度上,分散了dapp开发者的注意力,进一步阻碍了dapp的生态进步。毕竟,除了注意复杂的业务逻辑和防不胜防的安全漏洞之外,还要自己写轮子。对此dapp开发者有一段心酸地自嘲,“只要能用solidity写出log(n)就足以创建一个项目了”。Substrate的FRAME,目前parity自己使用Rust语言进行开发,但任何可以编译成WebAssembly的语言都可以用来写FRAME。终于,开发区块链逻辑也可以像正常写程序一样正常进行了。这里举个例子,比如著名的BTC-Relay项目,实现了BTC->ETH的跨链,方法是用solidity在智能合约中实现了一个BTC的SPV,其中最关键的一步就是验证比特币网络中的交易的有效性。验证交易有效性在solidity中的实现,也得益于solidity中提供的precompile的hashfunction和在BTC中使用的一样(SHA256),否则可以想见,这样著名的项目,可能就不会出现。所以,自由地使用各种现有的基础设施,不仅帮助开发者节省时间和精力,更是鼓励整个应用生态层层推进,向水更深、更未知的方向去探索。如果说之前dapp开发者是带着镣铐在跳舞,那现在substrate就是在帮助他们卸下枷锁,更自由地舞蹈。4.自动执行ETH是没有延后执行或者自动执行功能的,所有的交易必须手动触发。有一些区块链平台已经实现了延后执行的功能,但是不能精准控制执行的时间和条件。在Substrate中有一个很棒的自定义功能,on_initialize和on_finalize两个功能会在validator构造区块的开始和结束时自动执行,也就是如果有一些很重要的功能,需要根据是否达到时间点或者条件阈值而触发时,这是一个不错的选择。不建议大规模使用,因为如果需要消耗太多算力的话,会影响到validator的打包出块5.Off-chainworker在写智能合约时,如果想要获取链下数据比如随机数,第一可以自己手动写进去,这样缺乏公信力;或者也可以去请求oracle服务,贵且数据源选择不多。Substrate有一个功能叫做off-chainworker,用来执行一些计算密集并且计算周期长的操作。例如在获取链下数据时,可以把http请求操作写在offchainworker中,可以在runtime中被触发执行,获取链下数据并在请求成功之后把结果返回给链上进行相关计算操作。这不仅给了dapp开发者带来了很多便利,例如随机数请求;更给区块链开发者带来了全新的想象空间。比如在联盟链领域,之前通常的做法就是往左走区块链架构,往右走传统存储服务,因为区块链天然和链下世界隔离的特点,好像很难把两件事情融合在一起。有了off-chainworker,是不是可以发现一些新的交叉地带?请大家此处放飞想象力。6.相似点说了这么多不同,个人感觉,在开发Substrateruntime时,和开发智能合约在思路上,还是很类似的。无论写智能合约还是runtime,首先都会进行填空题操作:以上部分在Solidity中直接按照写代码的方式声明变量和方法就可以了,在Susbtrate中则是在相应的宏内声明,详见上表。所以对于智能合约开发者来说,所需要的只是学习Rust相关的语法,在逻辑构造环节,无缝迁移。Substrateruntime相关资料,请参考:SubstrateRuntime7.安全当然Substrate也不是全都是好处,最大的缺点,就是上手开发确实比智能合约要难。这里的难不仅体现在Rust语法上,还体现在Substrateruntime中的方法不像智能合约一样可以原子调用。即在智能合约中,如果其中一个逻辑失败,那么整个交易执行失败,所有存储更改全部回滚。但是在Substrate中,即使一笔交易在某一处逻辑判断失败,但是在这之前的执行,还是会发生。所以强烈提醒Substrateruntime开发者在开发runtime时,一定要Verifyfirst,WriteLast。总结

币安将于5月19日进行钱包维护,受影响网络取款将暂停约三小时:5月18日消息,币安发布公告将于北京时间5月19日14:00对以下网络进行钱包维护,5月19日13:55起,将暂停受影响网络的取款。维护可能需要约三个小时,维护完成后,重新开放取款。受影响的网络包括比特币、以太坊、Cosmos、AVAXC-Chain、BNBChain、CELO、Fantom、Terra、Polygon等。[2022/5/18 3:24:47]

作为系列开篇,简单地总结一下Substrate和合约开发的异同。在接下来的系列文章中,会从具体的例子触发,希望可以帮助大家在实操层面,感受到Substrate开发的自由。欢迎任何反馈和问题。

标签:STRRATTRATRATStrikeRATS币TRATTRAT币

比特币交易所热门资讯
BAL:一文读懂Balancer“流动性挖矿”原理

编者按:本文来自加密谷Live,作者:DeFiPulse,翻译:Liam,Odaily星球日报经授权转载。流动性对于DeFi的发展至关重要。许多DApp需要可靠的流动性池来支撑其运行.

1900/1/1 0:00:00
加密货币:国际清算银行对CBDC态度转变,Libra“施压”还是全球形势所迫?

近日,国际清算银行拒绝了此前较为流行的说法,即FaceBook发行的稳定币Libra是刺激中央银行数字货币的关键因素.

1900/1/1 0:00:00
ETH:GAS费暴涨,以太坊繁荣的背后

编者按:本文来自链内参,作者:内参君,Odaily星球日报经授权转载。随着交易费用激增,使用第二大加密货币进行交易的成本越来越高.

1900/1/1 0:00:00
ATM:国盛区块链 | 四探央行数字货币:第三方支付产业新变量

编者按:本文来自吉时通信,作者:宋嘉吉、孙爽,Odaily星球日报经授权转载。5月,人民银行行长易纲表示,数字人民币研发工作遵循稳步、安全、可控、创新、实用原则,先行在深圳、苏州、雄安、成都及未.

1900/1/1 0:00:00
加密货币:比特币价格较历史最高点缩水52% ,但机构投资者增长56%

编者按:本文来自LongHash区块链资讯,作者:JosephYoung,Odaily星球日报经授权转载.

1900/1/1 0:00:00
MIR:衍生品监管机构概述

Overview概述本文将简述全球衍生品监管现状,以便明晰和呼吁「市场监管是繁荣的必要条件」这一理念.

1900/1/1 0:00:00