市值: $2.812T -5.85%
成交额(24h): $186.0816B 66.46%
恐惧与贪婪指数:

38 - 恐惧

  • 市值: $2.812T -5.85%
  • 成交额(24h): $186.0816B 66.46%
  • 恐惧与贪婪指数:
  • 市值: $2.812T -5.85%
加密货币
话题
百科
资讯
加密话题
视频
热门加密百科

选择语种

选择语种

选择货币

加密货币
话题
百科
资讯
加密话题
视频

如何用 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. 按大小递减的顺序声明状态变量: uint256uint128uint64uint32uint16uint8 。 4. 如果存在具有链外索引的数组等替代方案,请避免对大型数据集使用映射。 5. 对于部署时已知但动态计算的值,更喜欢不可变而不是常量

最小化外部调用和循环

1. 外部调用比内部函数调用消耗明显更多的gas;尽可能将逻辑合并到单个事务中。 2. 切勿在链上函数内迭代无界数组——使用基于事件的分页或链下计算。 3. 当长度可预测时,将for (uint i = 0; i < array.length; i++)替换为固定长度循环。 4. 循环前将数组长度缓存在内存中: uint len = array.length; 5. 完全避免嵌套循环,除非两个维度都严格限制且很小。

利用关键路径的装配

1.内联汇编可以绕过Solidity的安全检查并减少算术和内存访问的开销。 2. 在性能至关重要的情况下,使用mstoremload代替高级内存分配。 3. 对预组装字节序列进行哈希处理时,将keccak256(abi.encodePacked(...))替换为keccak256(bytes) 。 4. 仅当您确定槽索引和可变性时,才可以直接通过sloadsstore访问存储槽。 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),我们将及时删除。

相关百科

如何使用LayerZero合约执行跨链消息?

如何使用LayerZero合约执行跨链消息?

2026-01-18 13:19:39

了解 LayerZero 架构1. LayerZero 作为一种轻量级、无需许可的互操作性协议运行,无需依赖可信中介或包装资产即可实现区块链之间的通信。 2. 它利用部署在每条链上的超轻节点(ULN)来验证消息的完整性和一致性,而无需存储完整的区块链状态。 3. 核心组件包括处理消息路由的 Endp...

如何实施EIP-712进行安全签名验证?

如何实施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?

如何使用 OpenZeppelin 合约构建安全的 dApp?

2026-01-18 11:19:49

了解 OpenZeppelin 合约基础知识1. OpenZeppelin Contracts 是一个可重用、经过社区审核的智能合约组件库,专为以太坊和 EVM 兼容的区块链而构建。 2. 库中的每个合约都遵循严格的安全实践,包括遵守“检查-效果-交互”模式以及广泛使用访问控制修饰符。 3. 该库提...

如何使用LayerZero合约执行跨链消息?

如何使用LayerZero合约执行跨链消息?

2026-01-18 13:19:39

了解 LayerZero 架构1. LayerZero 作为一种轻量级、无需许可的互操作性协议运行,无需依赖可信中介或包装资产即可实现区块链之间的通信。 2. 它利用部署在每条链上的超轻节点(ULN)来验证消息的完整性和一致性,而无需存储完整的区块链状态。 3. 核心组件包括处理消息路由的 Endp...

如何实施EIP-712进行安全签名验证?

如何实施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?

如何使用 OpenZeppelin 合约构建安全的 dApp?

2026-01-18 11:19:49

了解 OpenZeppelin 合约基础知识1. OpenZeppelin Contracts 是一个可重用、经过社区审核的智能合约组件库,专为以太坊和 EVM 兼容的区块链而构建。 2. 库中的每个合约都遵循严格的安全实践,包括遵守“检查-效果-交互”模式以及广泛使用访问控制修饰符。 3. 该库提...

查看所有文章

User not found or password invalid

Your input is correct