Solidity 技巧:如何减少字节码大小及节省 gas_SOL:SOLA

译文出自:登链翻译计划

译者:翻译小组

校对:Tiny熊

Solidity是一种特殊的语言,有许多的奇怪巧。由于Solidity被创建为可在EVM上使用其有限的函数集,因此许多函数在Solidity中的行为与大多数其他语言不同。几个月前我写了一篇博客文章,通过有十个技巧来节省Solidity中的gas消耗,但是收到了很大的反响。

10个技巧是:

合并打包变量

uint8不总是比uint256便宜

Mappings大部分时候比Arrays便宜

Solana:漏洞攻击根本原因尚不清楚,约7767个钱包被盗:8月3日消息,Solana Status 发推称,一个漏洞允许恶意行为者从 Solana 的多个钱包中盗取资金。截至世界标准时间凌晨 5 点,大约有 7767 个钱包受到影响。该漏洞利用影响了多个钱包,包括 Slope 和 Phantom,移动钱包和插件钱包都受到影响。工程师目前正在与多个安全研究人员和生态系统团队合作,以确定漏洞利用的根本原因,目前尚不清楚。没有证据表明硬件钱包受到影响,强烈建议用户使用硬件钱包,并且不要在硬件钱包上重复使用助记词,创建一个新的助记词。被盗取的钱包应被视为已损坏并丢弃。[2022/8/3 2:55:40]

不是所有的元素可以被打包

Polygon联合创始人:“Web 3小白”才会觉得Solana比Polygon更具吸引力:金色财经报道,加密货币分析师 Spencer Noon 此前表示,许多 Web 3 用户认为Solana 是使用次数第二多的智能合约平台,但如果看“日活用户”指标的话,其实Polygon表现更好。1月9日,Polygon 联合创始人 Nailwal 做出回应并表示,“我觉得‘Solana 比 Polygon更具吸引力’的想法可能在Web 3小白用户中更为普遍,因为他们受到了美国机构营销的影响。”据Nailwal透露,Polygon目前拥有2,000-3,000 个活跃的开发团队,而 Solana 只有 200-300 个活跃的开发团队;Solana的日活用户量大约为18万,而Polygon日活用户量达到了27万。[2022/1/10 8:38:23]

用bytes32而不是string/bytes

Solana(SOL)将于5月13日16时上线ZBG:据ZBG官方消息,Solana(SOL)已于5月12日16时开启充值和提币服务。并将于5月13日16时开启SOL/USDT交易对。

Solana是一个单层区块链,采用委托权益证明协议,其专注点是在不牺牲去中心化或安全性的前提下提供可扩展性。Solana扩展方案的核心是一个名为“历史证明(PoH)”的去中心化时钟,旨在解决缺乏单个可信赖时间源的分布式网络中的时间问题。通过可验证的延迟功能,PoH算法允许每个节点使用SHA256算法在本地生成时间戳。因此免除了在网络中广播时间戳的需求,从而提高整个网络的效率;SOL是Solana区块链的本地令牌。[2021/5/13 21:57:59]

少使用外部调用

库币合约已上线IOST, FIL, SOL永续合约:据库币KuCoin交易所消息,库币合约已正式上线IOST (IOST), Filecoin (FIL), Solana (SOL)永续合约,支持1-50倍杠杆,以USDT稳定币结算。库币合约是库币自主研发的数字货币衍生品平台,目前总用户数已经超过60万。[2021/2/24 17:48:10]

使用外部函数修改器

删除不需要的变量

使用短电路规则

尽量避免修改存储变量

在我的专栏:智能合约开发-打通Solidity任督二脉,有更多的文章深入介绍如何介绍GAS,订阅超值。

从那篇文章起,我又收集了更多的技巧与大家分享,再次分享给大家:

函数修饰器可能效率低下

添加函数修饰器时,将提取修饰器的代码并替换函数内出现的_符号。这也可以理解为函数修饰器是内联的。在普通的编程语言中,内联小代码更高效,并且不有任何实际的缺点,但Solidity不同。在Solidity中,EIP170将合约的最大大小限制为24KB,如果同一代码多次内联,则加起来就会很容易达到24KB大小限制。

另一方面,内部函数不是内联的,而是称为独立函数。这意味着它们在运行时gas要稍微贵一点,但是在部署中可以节省很多冗余字节码。内部函数还可以帮助避免可怕的“堆栈太深错误”,因为在内部函数中创建的变量与原始函数不会共享相同的堆栈,但是在修饰器中创建的变量共享相同的堆栈。

通过这种技巧,我将一份合约的大小从23

要设置或清除布尔值,可使用:

functionsetBoolean(uint256_packedBools,uint256_boolNumber,bool_value)publicviewreturns(uint256){if(_value)return_packedBools|uint256(1)<<_boolNumber;elsereturn_packedBools&~(uint256(1)<<_boolNumber);}

使用这种技术,你可以在一个存储槽中存储256个布尔值。如果你尝试正常打包bool(如在结构体中)变量,一个插槽中则只能在装入32个布尔型。

注意:仅当你要存储32个以上的布尔值时才使用此技巧。

使用库节省字节码

当你调用库的公共函数时,该函数的字节码不会包含在合约内,因此可以把一些复杂的逻辑放在库中,这样减小合约的大小。不过你得清楚,调用库会花费一些gas和使用一些字节码。对库的调用是通过委托调用的方式进行的,这意味着库可以访问合约拥有的数据,并且具有相同的权限。因此对于简单任务不值得这样做。

另外,你还需要知道,库的内部函数,solc编译器则把器内联到了合约内。内联有其自身的优点,但是需要字节码空间。

本文收录于专栏《智能合约开发-打通Solidity任督二脉》扫码进入专栏获取智能合约大师秘籍

无需使用默认值初始化变量

如果未设置/初始化变量,则变量具有默认值(0,false,0x0等,取决于数据类型)。如果你使用默认值对其进行显式初始化,那只会浪费gas。

本文来源于非小号媒体平台:

登链社区

现已在非小号资讯平台发布105篇作品,

非小号开放平台欢迎币圈作者入驻

入驻指南:

/apply_guide/

本文网址:

/news/9558545.html

免责声明:

1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险

2.本文版权归属原作所有,仅代表作者本人观点,不代表非小号的观点或立场

上一篇:

币安为何推出第三条链?这对BNB意味着什么?

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

水星链

屎币从上帝视角看 DeFi 和 Uniswap_EFI:DefiCliq

Overview概述 到目前为止,我没有看到一篇令人满意的DeFi的技术和业务的研究报告,决定将本内部研究报告分享给大家。本报告以技术分析为基础描述uniswap业务机制和背后的金融原理.

[0:15ms0-0:549ms