-
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 中的庫是什麼?它與基礎合約有何不同?
Libraries in Solidity enable reusable, gas-efficient code sharing via delegatecall, allowing functions to operate on calling contracts' storage without inheritance.
2025/11/12 09:19
了解 Solidity 中的庫
1. Solidity 中的庫是一種特殊類型的合約,旨在保存可重用的函數,這些函數可以在多個合約之間共享而無需繼承。這些函數是無狀態的,這意味著它們不會自行修改或存儲數據,除非顯式與另一個合約的存儲交互。庫對於實現數學計算、數組操作或編碼實用程序等常見操作特別有用。
2. 庫在區塊鏈上部署一次,可以使用library關鍵字被許多不同的合約引用。當合約使用庫時,它會鏈接到已經部署的庫地址,允許它通過 delegatecall 調用庫的函數。這意味著該函數在調用合約的上下文中執行,訪問其存儲,同時由於代碼重用而保持gas效率。
3. 庫的一個主要限制是它們不能擁有任何持久存儲變量,除非這些變量是調用合約狀態的一部分。他們也無法接收以太幣,除非標記為應付,即使如此,他們也無法在舊版本的 Solidity 中定義後備函數。與常規合同相比,這使得它們更加安全和可預測。
4. 庫的使用有助於減少字節碼重複。開發人員無需將實用程序邏輯嵌入到每個合約中,而是可以在庫中編寫一次並在需要時引用它。這會降低部署成本並簡化維護,因為對庫的更新(如果重新部署和重新鏈接)可以在所有依賴合約中傳播改進。
庫和基礎合約之間的差異
1. 繼承是基礎合約的核心特徵。當合約繼承基礎合約時,它吸收所有非私有函數和狀態變量,有效地將邏輯複製到自己的字節碼中。這會增加部署規模和 Gas 成本,但允許派生合約擴展和覆蓋行為。圖書館通過保持外部性來避免這種複制。
2.基礎合約可以維護自己的狀態並完全參與以太坊交易——它們可以持有以太幣、定義構造函數、發出事件和管理存儲。除非通過另一個合同專門進行交互,否則圖書館缺乏這些功能。它們的作用嚴格來說是功能性的而不是結構性的。
3. 對庫的函數調用通常通過delegatecall進行,它保留調用者的執行上下文,包括 msg.sender 和存儲佈局。相比之下,繼承期間調用基礎合約中的函數發生在同一合約空間內部,因此執行上下文沒有分離。
4. 庫支持using for指令,使開發人員能夠將庫函數附加到特定類型(例如數組或結構體),使語法感覺原生。例如,將排序函數附加到數組類型可以提高可讀性和可用性。基礎合約不提供這種語法增強。
用例和實際示例
1. 圖書館的一個常見應用是開發需要精確數學的去中心化交換。在內置檢查成為 Solidity 0.8+ 的標準之前,SafeMath 歷史上曾用於防止上溢/下溢錯誤。現代等價物包括用於處理小數令牌數量的定點算術庫。
2. NFT 項目通常依賴庫來管理所有權跟踪、枚舉和元數據處理。通過隔離庫中復雜的記賬邏輯,主要的 NFT 合約保持乾淨並專注於鑄造和轉移等核心功能。
3. 預言機和價格反饋可以利用封裝在庫中的散列和簽名驗證例程。由於加密操作成本高昂且頻繁重用,因此將它們集中化可確保一致性並減少錯誤面。
4. 構建可升級代理系統的開發人員可以從庫中受益,因為他們可以安全地鏈接穩定的實用程序模塊,而不會冒存儲衝突的風險——這是在透明代理或 UUPS 模式中將邏輯與狀態分離時的一個關鍵問題。
關於 Solidity 庫的常見問題
問:庫可以修改調用它的合約的存儲嗎?答:是的,當通過 delegatecall 調用庫函數時,它在調用合約的上下文中運行,並且可以修改其存儲,前提是該函數有權訪問正確的存儲指針(通常通過作為參數傳遞的結構引用)。
問:庫可以升級嗎?
答:庫本身一旦部署就不可更改。但是,如果項目在部署時使用鏈接機制,它可能會替換庫地址。這需要仔細規劃,並且並非所有開發環境都支持。
問:庫比直接嵌入函數消耗的gas更少嗎?
答:部署 Gas 成本降低了,因為庫代碼不會在合約之間重複。然而,由於 delegatecall 的開銷,對庫的每次外部調用都會消耗稍多的執行 Gas。這種權衡有利於大規模或頻繁更新邏輯的庫。
問:庫可以繼承另一個合約嗎?
答:不可以,庫不能繼承其他合約,其他合約也不能繼承庫。它們存在於繼承層次結構之外,純粹作為獨立的實用程序模塊,可通過直接調用或使用 for 聲明進行訪問。
免責聲明:info@kdj.com
所提供的資訊並非交易建議。 kDJ.com對任何基於本文提供的資訊進行的投資不承擔任何責任。加密貨幣波動性較大,建議您充分研究後謹慎投資!
如果您認為本網站使用的內容侵犯了您的版權,請立即聯絡我們(info@kdj.com),我們將及時刪除。
- 加密貨幣過山車:隨著市場的變化,比特幣經歷了激烈的清算狩獵
- 2026-02-01 00:40:02
- 隨著 2 月初的市場情緒變化,比特幣重新測試 75,000 美元
- 2026-02-01 01:20:03
- 不要錯過:一枚帶有隱藏錯誤的 1 英鎊稀有硬幣可能價值連城!
- 2026-02-01 01:20:03
- 罕見的 1 英鎊硬幣錯誤可能價值 2,500 英鎊:您攜帶財富嗎?
- 2026-02-01 00:45:01
- 探索加密貨幣格局:Solana 下跌中的風險與回報以及加密貨幣預售的吸引力
- 2026-02-01 01:10:01
- NVIDIA 首席執行官黃仁勳 (Jensen Huang) 的觀點:加密貨幣作為能源存儲以及科技首席執行官不斷變化的角色
- 2026-02-01 01:15:02
相關知識
首次如何在Bybit上交易加密合約?
2026-02-01 04:00:10
設置您的Bybit賬戶1.訪問Bybit官方網站,點擊首頁右上角的“註冊”按鈕。 2. 輸入有效的電子郵件地址並創建一個包含大寫字母、小寫字母、數字和特殊字符的強密碼。 3. 完成驗證碼驗證,點擊“註冊”提交信息。 4. 檢查您的收件箱中是否有來自 Bybit 的確認電子郵件,然後單擊激活鏈接以驗證...
如何使用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 等本地開發環境來...
首次如何在Bybit上交易加密合約?
2026-02-01 04:00:10
設置您的Bybit賬戶1.訪問Bybit官方網站,點擊首頁右上角的“註冊”按鈕。 2. 輸入有效的電子郵件地址並創建一個包含大寫字母、小寫字母、數字和特殊字符的強密碼。 3. 完成驗證碼驗證,點擊“註冊”提交信息。 4. 檢查您的收件箱中是否有來自 Bybit 的確認電子郵件,然後單擊激活鏈接以驗證...
如何使用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 等本地開發環境來...
看所有文章














