-
bitcoin $87959.907984 USD
1.34% -
ethereum $2920.497338 USD
3.04% -
tether $0.999775 USD
0.00% -
xrp $2.237324 USD
8.12% -
bnb $860.243768 USD
0.90% -
solana $138.089498 USD
5.43% -
usd-coin $0.999807 USD
0.01% -
tron $0.272801 USD
-1.53% -
dogecoin $0.150904 USD
2.96% -
cardano $0.421635 USD
1.97% -
hyperliquid $32.152445 USD
2.23% -
bitcoin-cash $533.301069 USD
-1.94% -
chainlink $12.953417 USD
2.68% -
unus-sed-leo $9.535951 USD
0.73% -
zcash $521.483386 USD
-2.87%
如何用 Solidity 编写节省 Gas 的智能合约?
Optimize Solidity gas usage by grouping same-type storage vars, caching array lengths, using unchecked only when safe, reverting with custom errors, and enabling solc’s --via-ir flag.
2026/01/26 13:59
优化存储布局
1. 将相同类型的变量分组在一起,以尽量减少槽的使用。 2. 使用uint256而不是较小的类型,除非是故意打包的。 3. 按大小递减的顺序声明状态变量: uint256 、 uint128 、 uint64 、 uint32 、 uint16 、 uint8 。 4. 如果存在具有链外索引的数组等替代方案,请避免对大型数据集使用映射。 5. 对于部署时已知但动态计算的值,更喜欢不可变而不是常量。
最小化外部调用和循环
1. 外部调用比内部函数调用消耗明显更多的gas;尽可能将逻辑合并到单个事务中。 2. 切勿在链上函数内迭代无界数组——使用基于事件的分页或链下计算。 3. 当长度可预测时,将for (uint i = 0; i < array.length; i++)替换为固定长度循环。 4. 循环前将数组长度缓存在内存中: uint len = array.length; 5. 完全避免嵌套循环,除非两个维度都严格限制且很小。
利用关键路径的装配
1.内联汇编可以绕过Solidity的安全检查并减少算术和内存访问的开销。 2. 在性能至关重要的情况下,使用mstore和mload代替高级内存分配。 3. 对预组装字节序列进行哈希处理时,将keccak256(abi.encodePacked(...))替换为keccak256(bytes) 。 4. 仅当您确定槽索引和可变性时,才可以直接通过sload和sstore访问存储槽。 5. 切勿使用汇编来实现复杂的控制流——保持核心业务逻辑的可读性和可审计性。
避免热路径中昂贵的操作
1.除法和取模运算比位移位消耗更多的gas;除以 2 的幂时,使用x >> n而不是x / 2**n 。 2. 使用abi.encodePacked进行字符串连接比string.concat便宜,但在频繁调用的函数中应避免使用这两种方法。 3. 不要在循环内发出事件,除非每次发出都携带唯一的、必要的数据。 4. 使用自定义错误而不是字符串消息进行恢复: revert InvalidAmount();每次调用可节省约 2000 Gas。 5. 仅当上溢/下溢在数学上不可能时才使用未经检查的块,切勿在涉及用户输入的算术中使用。
测试和测量实践
1. 使用 Hardhat 的GasReporter或 Foundry 的forge test --gas-report测量气体使用情况。 2. 比较每次优化前后的基准 Gas 成本,以避免过早的微优化。 3. 模拟最坏情况:完整数组、最大递归深度、边缘情况输入。 4. 使用 Tenderly 或 Blockscout 等 EVM 跟踪分析工具单独配置文件存储读/写。 5. 使用solc --asm审核字节码输出,以验证编译器优化,例如常量折叠和死代码消除。
常见问题解答
Q1.使用视图或纯函数会减少gas消耗吗? A1。不会。这些修饰符会影响调用行为和状态可变性,但不会改变外部调用期间的 Gas 成本。它们仅在内部或链外调用时消除 Gas 费用。
Q2。在现代 Solidity 版本中使用SafeMath更安全吗? A2。不需要。 Solidity 0.8.0+ 包含内置溢出检查。显式SafeMath添加了不必要的操作码并增加了部署 Gas。
Q3。我可以通过部署带有剥离字节码的合约来减少gas吗? A3。是的。将 --via-ir标志与 solc 结合使用可以实现高级优化器传递,通常可以将运行时字节码大小减少 15-30%,并显着降低部署 Gas。
Q4。为什么发出带有索引参数的事件会花费更多的gas? A4。索引参数生成存储在日志的主题数组中的主题哈希,这需要额外的SHA3计算并存储在日志结构中 - 每个主题消耗一个 32 字节的字。
免责声明:info@kdj.com
所提供的信息并非交易建议。根据本文提供的信息进行的任何投资,kdj.com不承担任何责任。加密货币具有高波动性,强烈建议您深入研究后,谨慎投资!
如您认为本网站上使用的内容侵犯了您的版权,请立即联系我们(info@kdj.com),我们将及时删除。
- Bybit上线ELON,点燃现货交易场Meme币热潮
- 2026-01-30 21:50:17
- 旁遮普邦阿博哈尔的硬币爆炸导致幼儿受伤,突显了不可预见的危险
- 2026-01-30 21:50:17
- Coinbase、华尔街和未来金融体系的拉锯战
- 2026-01-30 19:15:01
- 一枚 1 英镑硬币的“煎蛋”缺陷开启了皇家造币厂的稀有价值富矿
- 2026-01-30 19:05:01
- 罕见的皇家造币厂硬币价值飙升:从煎鸡蛋到大西洋鲑鱼
- 2026-01-30 19:10:02
- 华尔街新玩法:比特币进入下一个时代,为何聪明的投资者纷纷关注比特币亿光
- 2026-01-30 19:05:01
相关百科
如何使用LayerZero合约执行跨链消息?
2026-01-18 13:19:39
了解 LayerZero 架构1. LayerZero 作为一种轻量级、无需许可的互操作性协议运行,无需依赖可信中介或包装资产即可实现区块链之间的通信。 2. 它利用部署在每条链上的超轻节点(ULN)来验证消息的完整性和一致性,而无需存储完整的区块链状态。 3. 核心组件包括处理消息路由的 Endp...
如何实施EIP-712进行安全签名验证?
2026-01-20 22:20:26
EIP-712 概述和核心目的1. EIP-712 定义了以太坊应用程序中类型化结构化数据哈希和签名的标准。 2. 它使钱包能够在签名请求期间显示人类可读的域和消息字段,而不是原始的十六进制字符串。 3. 该规范通过域分隔符哈希引入域分离,防止跨不同 dApp 或链的签名重放。 4. 每个签名的有效...
如何通过新合约交互获得空投资格?
2026-01-24 21:00:23
了解合约交互要求1. 大多数空投活动都要求与部署在受支持的区块链(例如以太坊、Arbitrum 或 Base)上的智能合约进行直接交互。 2. 交互通常涉及使用连接到 dApp 接口的钱包执行诸如approve() 、 stake()或mint()之类的函数。 3. 某些协议需要多种交易类型,例如将...
如何监控智能合约的安全警报?
2026-01-21 07:59:57
链上监控工具1. Etherscan和Blockscout等区块链浏览器允许实时检查合约字节码、交易日志和内部调用。 2. 在信任任何链上数据之前必须确认合约验证状态——未经验证的合约存在高风险。 3. 事件日志解析可以检测异常状态变化,例如意外的代币转移或所有权修改。 4. 可以针对特定事件签名设...
如何建立自动支付合同并为其提供资金?
2026-01-26 08:59:35
了解智能合约部署1. 开发者必须根据gas效率和安全性要求选择兼容的区块链平台,例如以太坊、Polygon或Arbitrum。 2. Solidity 仍然是编写支付自动化逻辑的主要语言,特别是对于定期或有条件的转账。 3. 在主网部署之前,使用 Hardhat 或 Foundry 等本地开发环境来...
如何使用 OpenZeppelin 合约构建安全的 dApp?
2026-01-18 11:19:49
了解 OpenZeppelin 合约基础知识1. OpenZeppelin Contracts 是一个可重用、经过社区审核的智能合约组件库,专为以太坊和 EVM 兼容的区块链而构建。 2. 库中的每个合约都遵循严格的安全实践,包括遵守“检查-效果-交互”模式以及广泛使用访问控制修饰符。 3. 该库提...
如何使用LayerZero合约执行跨链消息?
2026-01-18 13:19:39
了解 LayerZero 架构1. LayerZero 作为一种轻量级、无需许可的互操作性协议运行,无需依赖可信中介或包装资产即可实现区块链之间的通信。 2. 它利用部署在每条链上的超轻节点(ULN)来验证消息的完整性和一致性,而无需存储完整的区块链状态。 3. 核心组件包括处理消息路由的 Endp...
如何实施EIP-712进行安全签名验证?
2026-01-20 22:20:26
EIP-712 概述和核心目的1. EIP-712 定义了以太坊应用程序中类型化结构化数据哈希和签名的标准。 2. 它使钱包能够在签名请求期间显示人类可读的域和消息字段,而不是原始的十六进制字符串。 3. 该规范通过域分隔符哈希引入域分离,防止跨不同 dApp 或链的签名重放。 4. 每个签名的有效...
如何通过新合约交互获得空投资格?
2026-01-24 21:00:23
了解合约交互要求1. 大多数空投活动都要求与部署在受支持的区块链(例如以太坊、Arbitrum 或 Base)上的智能合约进行直接交互。 2. 交互通常涉及使用连接到 dApp 接口的钱包执行诸如approve() 、 stake()或mint()之类的函数。 3. 某些协议需要多种交易类型,例如将...
如何监控智能合约的安全警报?
2026-01-21 07:59:57
链上监控工具1. Etherscan和Blockscout等区块链浏览器允许实时检查合约字节码、交易日志和内部调用。 2. 在信任任何链上数据之前必须确认合约验证状态——未经验证的合约存在高风险。 3. 事件日志解析可以检测异常状态变化,例如意外的代币转移或所有权修改。 4. 可以针对特定事件签名设...
如何建立自动支付合同并为其提供资金?
2026-01-26 08:59:35
了解智能合约部署1. 开发者必须根据gas效率和安全性要求选择兼容的区块链平台,例如以太坊、Polygon或Arbitrum。 2. Solidity 仍然是编写支付自动化逻辑的主要语言,特别是对于定期或有条件的转账。 3. 在主网部署之前,使用 Hardhat 或 Foundry 等本地开发环境来...
如何使用 OpenZeppelin 合约构建安全的 dApp?
2026-01-18 11:19:49
了解 OpenZeppelin 合约基础知识1. OpenZeppelin Contracts 是一个可重用、经过社区审核的智能合约组件库,专为以太坊和 EVM 兼容的区块链而构建。 2. 库中的每个合约都遵循严格的安全实践,包括遵守“检查-效果-交互”模式以及广泛使用访问控制修饰符。 3. 该库提...
查看所有文章














