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

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

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

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

新火科技旗下MPC自托管平台Sinohope推出Start-up扶持计划,BeWater首批加入合作:据官方消息,Web3开发者社区BeWater近日宣布,该平台组织的Web3创新大赛获奖项目将入选新火科技旗下MPC自托管平台Sinohope新推出的Start-up扶持计划。获奖项目将享有Sinohope提供的每月价值数千美金的企业级服务定制,Sinohope还将为获奖项目开放使用企业级MPC钱包、自动化 AML&KYT 流程、全链协议和币种访问、定制化功能开发等多项服务。

作为新火科技新近推出的重点产品,Sinohope致力于为每个机构打造专属的数字资产自托管平台。Sinohope通过采用MPC-CMP技术支持用户分布式管理私钥分片与协同签名解决私钥单点风险,有效增加透明性和易用性。近期,为进一步助力早期项目发展,Sinohope推出Start-up扶持计划,面向万千开发者和早期项目提供专属服务,入选扶持计划的项目将享受新火科技提供的一系列扶持政策。[2023/6/14 21:35:53]

在这里,会从最宏观的角度去理解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更像是一个数字的文字化表述,例如下面的定义:

Lifeform以1亿美元估值完成A轮融资,Geek Cartel领投:金色财经报道,DID解决方案提供商Lifeform以1亿美元估值完成A轮融资,本轮融资由Geek Cartel领投,KuCoin Labs、DHVC、SevenX Ventures、Foresight Ventures、K24 Ventures、Another World参投。

此前,Lifeform种子轮由Binance Labs领投,前种子轮由GeekCartel独家投资。

据悉,Lifeform的UE5版虚拟人编辑器PC端已于2022年11月上线,Lifeform Avatar及相关服饰item铸造总量超40万。Unity版移动端于2023年2月17日上线,截至目前Lifeform Cartoon Avatar铸造总量已突破85万,官方网站单日PV量达2000万。[2023/2/25 12:29:02]

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

Cosmos跨链功能IBC存在严重漏洞,安全补丁公开版本预计今日发布:10月14日消息,Cosmos联合创始人Ethan Buchman在Cosmos官方论坛中表示,在BSC漏洞利用之后,Cosmos和Osmosis核心团队的成员一直在对IBC进行广泛的审计,此过程中发现了一个严重的安全漏洞,该漏洞影响所有支持IBC的Cosmos链,适用于所有IBC版本。

已经采取步骤确保所有支持IBC的主要公共链都打入补丁。一旦1/3的投票权应用于补丁,就不会受到严重漏洞的威胁。一旦正式补丁发布,剩余2/3链仍应该尽快打补丁。该补丁的公开版本将在UTC时间10月14日14:00(北京时间10月14日22:00)24小时内在CosmosSDKv0.45.9和v0.46.3中发布。

强烈建议所有的链和验证器立即升级到新发布的补丁,即使他们已经私下打了补丁。该补丁可以由验证器单独部署,而不需要链式停止升级,并且应该尽快应用。[2022/10/14 14:27:30]

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

并且对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作为区块链开发的“轮子”,因为优秀的框架设计和抽象分层,给开发者提供了多阶定制选择:

BitMEX计划在今年年底推出平台Token BMEX:10月2日消息,加密交易平台 BitMEX 首席执行官 Alexander Hoeptner 在新加坡举行的 Token2049 会议上接受采访时表示,计划在今年年底推出其交易平台 Token BMEX。

此前报道,今年 7 月,BitMEX 考虑到市场条件不理想决定推迟 BMEX 上线时间,并希望让 BMEX 在持有者能获得最佳回报机会的环境中上线。[2022/10/3 18:37:57]

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。总结

Web3教育社区Encode Club完成500万美元融资,Galaxy Digital和Lemniscap领投:5月17日消息,Web3教育社区Encode Club完成500万美元融资,Galaxy Digital和Lemniscap领投,Dragonfly Ventures、Folius Ventures、not3lau Capita、Ascensive Assets、Stefan George(Gnosis联合创始人)、Anton Bukov(1inch联合创始人)、SolBigBrain等参投。

此轮融资资金将用于进一步发展Encode的Web3训练营、黑客马拉松和加速器项目。(Decrypt)[2022/5/17 3:23:03]

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

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

金星链

PolygonEFI:DeFi如何跨越鸿沟?

1)用户为以太坊的何种用途支付Gas费?数据分析平台Glassnode对Gas费进行了分析,试图发现以太坊网络的主要用途是什么?数据显示,自成立以来.

[0:31ms0-1:28ms