市值: $2.796T -1.10%
體積(24小時): $128.341B -31.92%
恐懼與貪婪指數:

28 - 害怕

  • 市值: $2.796T -1.10%
  • 體積(24小時): $128.341B -31.92%
  • 恐懼與貪婪指數:
  • 市值: $2.796T -1.10%
加密
主題
加密植物
資訊
加密術
影片
頂級加密植物

選擇語言

選擇語言

選擇貨幣

加密
主題
加密植物
資訊
加密術
影片

Solidity 中的映射是什麼?它如何存儲鍵值對?

Mappings in Solidity enable efficient, gas-optimized key-value storage using keccak256 hashing, ideal for balances, access control, and lookup-heavy smart contract use cases.

2025/11/10 12:20

了解 Solidity 中的映射

1. Solidity中的映射是一種引用類型,用於以鍵值對的形式存儲數據,類似於其他編程語言中的哈希表或字典。它允許開發人員將唯一鍵與特定值關聯起來,從而實現高效的查找和更新。

2. 聲明映射的語法是mapping(keyType => valueType) ,其中 keyType 幾乎可以是任何基本類型,例如 uint、地址或字節,但不能是數組或其他映射等引用類型。 valueType 可以是任何類型,包括結構體、數組,甚至其他映射。

3. 映射在合約內聲明,通常用於維護狀態變量。由於它們存儲在存儲中,因此它們的值在函數調用和事務中持續存在。

4. 映射的一個定義特徵是它們不能迭代。沒有內置機制來檢索鍵或值列表。這種限制源於以太坊存儲模型的工作方式——映射是為通過鍵而不是枚舉來快速訪問而設計的。

5. 創建映射時,所有可能的鍵均使用 valueType 的默認值進行初始化(例如,整數為 0,布爾值為 false)。這意味著訪問不存在的鍵會返回默認值而不是拋出錯誤。

映射背後的存儲機制

1. 映射不以傳統的表格格式存儲數據。相反,Solidity 使用 keccak256 哈希函數來動態計算存儲槽。每個鍵都使用 keccak256 以及映射變量的存儲槽位置進行哈希處理。

2. 對於位於存儲槽n 的狀態變量映射,與給定鍵關聯的值存儲在keccak256(key . slot)中,其中 '.'表示串聯。這可確保每個鍵映射到存儲中唯一的、確定性的位置。

3. 由於哈希函數是單向的,因此在計算上無法對已設置的密鑰進行逆向工程。這導致無法迭代映射。

4. 嵌套映射遵循相同的原則。在像映射(地址=>映射(uint=>bool))這樣的映射中,內部映射的槽是通過對外部鍵和外部映射的槽進行散列確定的,然後使用該結果作為內部鍵查找的基礎。

5. 這種基於散列的存儲佈局使讀取和寫入操作的映射非常高效,這兩種操作都在恆定時間內執行,而與條目數量無關。

智能合約的實際用例

1. 映射的一種常見用途是跟踪 ERC-20 代幣中的用戶餘額。像mapping(address => uint256) private _balances這樣的映射允許快速檢索和更新任何錢包地址的代幣持有量。

2. 訪問控制系統通常使用映射來識別角色或權限。例如,mapping(address => bool) public isAdmin可以有效地驗證地址是否具有管理權限。

3. 在去中心化交易所或 NFT 市場中,映射將訂單 ID 或代幣 ID 鏈接到結構化數據,例如價格、所有者或列表狀態。這使得無需掃描大型數據集即可即時查找交易詳細信息。

4. 映射還用於通過在函數執行期間標記地址來防止重入攻擊。輸入的簡單映射(地址 => bool)私有可以充當鎖定機制。

5. 由於其gas效率高的訪問模式,當需要通過標識符頻繁查找時,尤其是在高吞吐量協議中,映射比數組更受青睞。

常見問題解答

映射可以完全刪除嗎?是的,在映射上使用刪除關鍵字會通過將每個寫入的槽重置為其默認值來清除所有條目。但是,由於映射實際上是使用所有鍵的默認值進行初始化的,因此此操作僅影響顯式分配的鍵。

是否可以從函數返回映射?不,映射不能直接從函數返回,因為它們不是 Solidity 中的有效返回類型。只能返回通過鍵訪問的特定值。

字符串或動態數組可以用作映射鍵嗎?字符串和動態字節數組不能用作映射鍵。僅允許固定大小的數據類型,例如 bytes32、uint 和地址。如果需要,字符串必須轉換為固定大小的格式,例如 bytes32。

映射如何影響天然氣成本?從具有未初始化鍵的映射中讀取消耗的氣體較少,因為它返回默認值而不修改存儲。由於以太坊的狀態增長成本規則,寫入或更新值會產生更高的gas,特別是如果將零值更改為非零值。

免責聲明:info@kdj.com

所提供的資訊並非交易建議。 kDJ.com對任何基於本文提供的資訊進行的投資不承擔任何責任。加密貨幣波動性較大,建議您充分研究後謹慎投資!

如果您認為本網站使用的內容侵犯了您的版權,請立即聯絡我們(info@kdj.com),我們將及時刪除。

相關知識

首次如何在Bybit上交易加密合約?

首次如何在Bybit上交易加密合約?

2026-02-01 04:00:10

設置您的Bybit賬戶1.訪問Bybit官方網站,點擊首頁右上角的“註冊”按鈕。 2. 輸入有效的電子郵件地址並創建一個包含大寫字母、小寫字母、數字和特殊字符的強密碼。 3. 完成驗證碼驗證,點擊“註冊”提交信息。 4. 檢查您的收件箱中是否有來自 Bybit 的確認電子郵件,然後單擊激活鏈接以驗證...

如何找到低滑點的高槓桿加密合約?

如何找到低滑點的高槓桿加密合約?

2026-02-01 04:19:41

尋找高槓桿加密貨幣合約1. 交易者經常掃描去中心化和中心化交易所,尋找槓桿率超過 50 倍的永續期貨合約。 Binance、Bybit 和 OKX 列出了多個 BTC、ETH 和 SOL 對,在逐倉保證金模式下槓桿率高達 125 倍。 2. 合約規格必須直接在交易所網站上查看——槓桿級別因頭寸規模和...

如何使用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. 可以針對特定事件簽名設...

首次如何在Bybit上交易加密合約?

首次如何在Bybit上交易加密合約?

2026-02-01 04:00:10

設置您的Bybit賬戶1.訪問Bybit官方網站,點擊首頁右上角的“註冊”按鈕。 2. 輸入有效的電子郵件地址並創建一個包含大寫字母、小寫字母、數字和特殊字符的強密碼。 3. 完成驗證碼驗證,點擊“註冊”提交信息。 4. 檢查您的收件箱中是否有來自 Bybit 的確認電子郵件,然後單擊激活鏈接以驗證...

如何找到低滑點的高槓桿加密合約?

如何找到低滑點的高槓桿加密合約?

2026-02-01 04:19:41

尋找高槓桿加密貨幣合約1. 交易者經常掃描去中心化和中心化交易所,尋找槓桿率超過 50 倍的永續期貨合約。 Binance、Bybit 和 OKX 列出了多個 BTC、ETH 和 SOL 對,在逐倉保證金模式下槓桿率高達 125 倍。 2. 合約規格必須直接在交易所網站上查看——槓桿級別因頭寸規模和...

如何使用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. 可以針對特定事件簽名設...

看所有文章

User not found or password invalid

Your input is correct