-
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),我們將及時刪除。
- 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
- Kindred Labs 通過 KIN 代幣空投和公開上市推出 AI Companions:所有人都關注價格
- 2026-01-30 19:10:02
- 由於 SON 索賠的不確定性,Spur Protocol 上市徘徊,Coinstore 面臨審查
- 2026-01-30 19:00:02
相關知識
如何使用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. 該庫提...
看所有文章














