木星链 木星链
Ctrl+D收藏木星链
首页 > XLM > 正文

STR:一文了解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智能合约

巴西证券监管机构要求修改加密货币法案:金色财经报道,巴西证券监管机构CVM的新指令现在要求对加密货币法案进行具体修改,等待国会讨论。该组织希望纠正当前文件中的一个漏洞,其中一些代币不会被视为证券,包括代币化的实物商品和碳信用额。[2022/9/12 13:23:48]

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

安全团队:Nirvana遭闪电贷攻击,请相关用户注意资产安全:7月28日消息,据慢雾区情报,Solana 链上稳定币项目 Nirvana 遭遇闪电贷攻击,攻击者通过部署恶意合约,使用闪电贷从 Solend 借出 10,250,000 USDC,随后调用 Nirvana 合约 buy3 方法购买了大量 ANA 代币,随后调用 Nirvana 合约 swap 方法卖出部分 ANA,得到USDT 和 USDC ,在归还完闪电贷后共获利3,490,563.69 USDT,21,902.48 USDC 及 393,230.32 ANA代币,随后黑客出售 ANA 代币,并将所有脏款通过跨链桥转移。Nirvana 源代码未完全开源,据链上调用日志分析,攻击者可能利用了 ANA 价格计算漏洞进行套利,请相关用户注意资产安全。[2022/7/28 2:43:46]

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

Citadel Securities全球业务开发负责人将离职成为加密业务CEO:金色财经消息,一位发言人透露,知名做市商Citadel Securities的全球业务开发负责人Jamil Nazarali将离职并担任该公司旗下加密业务的首席执行官。

Nazarali将领导该公司与Virtu Financial、Charles Schwab和Fidelity Digital Assets的合资公司,旨在促进投资者获得加密和数字资产敞口。

此前消息,消息人士称,Citadel Securities将与Fidelity Investments和Charles Schab Corp合作创建一项加密货币产品,旨在拓宽获取数字资产的渠道。这三家金融巨头将与Virtu Financial合作开发一个加密货币交易生态系统,该系统允许“零售券商向其客户提供加密货币业务。”(The Block)[2022/6/29 1:37:43]

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

分析师:如果加密熊市继续,ADA价格有可能减半:5月22日消息,加密分析师Benjamin Cowen表示,自己在关注ADA/BTC交易对的走势,认为其正处于强劲的下跌趋势中。在加密熊市中,如果ADA/BTC交易对重回2018年熊市低点0.0000085 BTC或0.25美元,他认为Cardano(ADA)将损失一半以上的价值。(The Daily Hodl)[2022/5/22 3:34:10]

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

东南亚数字支付公司Xendit完成3亿美元D轮融资,融资总额达5.38亿美元:金色财经报道,东南亚数字支付公司Xendit宣布已完成3亿美元D轮融资,联合领投方为加密投资机构Coatue 和 Insight Partners ,参投方包括Accel、Tiger Global、Kleiner Perkins、EV Growth、Amasia、Intudo 和Goat Capital等知名投资商和投资人。Xendit 创始人兼首席执行官Moses Lo表示,到 2025 年,东南亚数字经济价值将超过 3600 亿美元,Xendit 支付产品和服务使该地区更多的企业和个人能够参与数字经济。[2022/5/20 3:31:21]

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

标签:STRRATTRATRATCSTRMRAT价格Decentralized OracleStratos

XLM热门资讯
区块链:科普:如何进行链上治理

通过本文,你会了解到:典型区块链网络的治理机制有哪些;·什么是链上治理;·Kusama网络的治理机制。·为什么需要链上治理人类社会的进步,除了依赖技术的创新,还与社会的治理息息相关.

1900/1/1 0:00:00
EFI:2020年加密货币市场概念行情的机会

6月份即将结束,2020年的时间也即将过半,站在半年的这个关口,扪心自问:这半年的币圈交易里,收获如何?我们经历了年初的减半行情,3.12瀑布后的超跌反弹行情,DeFi概念热潮.

1900/1/1 0:00:00
DEF:DeFi发币潮或开启:前有COMP上线暴涨,后有交易所“强上”DF

编者按:本文来自巴比特资讯,作者:海伦,星球日报经授权发布。近日,DeFi项目好不热闹,前有COMP上线暴涨,后有交易所强上DF,而且这两个项目均最高暴涨近400%.

1900/1/1 0:00:00
DFO:dForce加急写白皮书,借风翻盘,下一个COMP?

编者按:本文来自小吒闲谈,Odaily星球日报经授权转载。对于DeFi项目,个人逻辑是,先看经过时间检验的头部产品,接着看有实力团队做的头部仿品,再看创新型产品,最后是边缘的DeFi产品.

1900/1/1 0:00:00
GAS:科普:如何在Opium上购买看涨期权来对冲Gas价格

编者按:本文来自以太坊爱好者,作者:AnastasiaKorchagina,翻译:闵敏,Odaily星球日报经授权转载.

1900/1/1 0:00:00
DEX:COMP大火后,DEX还有机会吗?

编者按:本文来自小吒闲谈,Odaily星球日报经授权转载。DeFi,已成为以太坊网络应用的核心驱动因素之一。也是2020年下半年的一大热点,如最近火热的COMP代币.

1900/1/1 0:00:00