-
bitcoin $102356.314698 USD
-0.84% -
ethereum $3449.512044 USD
0.11% -
tether $0.999980 USD
0.04% -
xrp $2.409617 USD
0.03% -
bnb $958.669452 USD
-0.37% -
solana $153.503386 USD
-1.06% -
usd-coin $1.000063 USD
0.03% -
tron $0.295130 USD
-1.03% -
dogecoin $0.171730 USD
-0.51% -
cardano $0.552057 USD
-1.14% -
hyperliquid $38.920663 USD
0.42% -
chainlink $15.343486 USD
0.00% -
bitcoin-cash $516.797331 USD
1.79% -
stellar $0.281339 USD
-0.45% -
zcash $518.569632 USD
16.46%
Solidity 中的視圖函數和純函數是什麼?它們對 Gas 有何影響?
View and pure functions in Solidity don’t modify state, enabling free, off-chain execution—ideal for reads and calculations without gas costs.
2025/11/12 18:20
了解 Solidity 中的視圖函數
1. Solidity 中的視圖函數是一種承諾不修改區塊鏈狀態的函數。它可以讀取合約的存儲變量,但不能更改它們、發出事件或調用更改狀態的函數。
- 由於這些函數不會改變狀態,因此它們可以在以太坊節點上本地執行,而無需向網絡廣播交易。這意味著用戶在外部調用時無需支付 Gas 費。
- 關鍵字view必須在函數簽名中顯式聲明。如果省略並且函數嘗試修改狀態,編譯器將拋出錯誤。
- 示例包括檢索用戶的餘額、檢查 ERC-20 代幣中的限額或讀取合約中存儲的配置參數。
- 儘管對外部調用者免費,視圖函數仍然消耗節點上的計算資源。因此,視圖函數內部過於復雜的邏輯可能會導致某些提供者超時或拒絕。
探索 Solidity 中的純函數
1. 純函數比視圖函數更進一步,承諾不讀取或寫入任何狀態變量。它僅對傳遞給它的輸入參數進行操作。
- 這些函數通常用於數學計算、編碼/解碼操作或不依賴於存儲數據的邏輯檢查。
- pure關鍵字在編譯時強制執行此限制。即使嘗試訪問單個狀態變量也會導致編譯失敗。
- 與視圖函數一樣,純函數在外部調用時不會產生任何 Gas 成本,因為它們不需要事務。他們使用本地節點資源在鏈外執行。
- 一個示例是基於輸入參數計算複利或驗證加密簽名而不引用合約存儲的函數。
非修改函數的氣體影響
1. 當智能合約函數被標記為view或pure時,對其的外部調用不會生成交易。因此,不會向調用者收取任何 Gas 費。
- 然而,在內部,如果視圖或純函數被事務中的另一個函數調用,其執行仍然會消耗gas。 EVM 必須處理每個操作,無論狀態是否發生變化。
- 此類函數內部的複雜計算(例如循環大型數組或執行多個算術運算)會增加內部調用時的 Gas 成本。
- 開發人員通常通過最小化視圖/純函數中的計算來優化性能,特別是當它們可能在狀態更改事務期間被調用時。
- 當函數實際修改狀態時將其錯誤標記為視圖或純函數會導致運行時異常或部署失敗,可能會浪費開發時間和測試網天然氣。
關於視圖和純函數的常見問題
問:視圖函數可以調用純函數嗎?答:是的,視圖函數可以安全地調用純函數。由於純函數不讀取或修改狀態,因此它們與視圖函數的約束完全兼容。
問:如果我嘗試修改純函數內的狀態變量會發生什麼?答:Solidity 編譯器會產生錯誤。純函數嚴格禁止訪問任何狀態變量,無論是讀取還是寫入。
問:從 web3.js 或 ethers.js 調用時,視圖和純函數是否使用 Gas?答:不需要,通過 JavaScript 庫調用這些函數不需要交易,因此不會產生任何 Gas 成本。執行發生在連接的以太坊節點本地。
問:視圖和純函數之間有性能差異嗎? A:從gas成本和執行速度的角度來看,外部調用並沒有本質上的區別。兩者都在本地執行,無需更改狀態。在內部,性能取決於計算複雜性而不是所使用的修飾符。
免責聲明:info@kdj.com
所提供的資訊並非交易建議。 kDJ.com對任何基於本文提供的資訊進行的投資不承擔任何責任。加密貨幣波動性較大,建議您充分研究後謹慎投資!
如果您認為本網站使用的內容侵犯了您的版權,請立即聯絡我們(info@kdj.com),我們將及時刪除。
- TRX 價格和 Tron 的彈性:EV2 預售是下一件大事嗎?
- 2025-11-13 17:00:02
- 炒作市場中的 Meme 幣:2025 年實用性與病毒式傳播
- 2025-11-13 16:55:01
- 電信幣 (TEL)、比特幣 (BTC) 和加密貨幣格局:紐約人的看法
- 2025-11-13 14:50:02
- 卡爾達諾 (ADA) 價格反彈:0.70 美元觸手可及嗎?
- 2025-11-13 15:15:01
- Blazpay 代幣:通過預售駕馭人工智能增長浪潮
- 2025-11-13 15:10:01
- 發現財富:那枚 2 便士硬幣可能價值 1,000 英鎊!需要注意的有價值的單詞
- 2025-11-13 15:25:02
相關知識
什麼是智能合約中的拒絕服務 (DoS) 攻擊?其常見形式有哪些?
2025-11-10 05:20:08
了解智能合約中的拒絕服務1. 智能合約中的拒絕服務(DoS)攻擊是指惡意行為者阻止合法用戶訪問或使用合約功能的情況。這通常是通過利用允許攻擊者阻止關鍵操作的設計缺陷來實現的。與針對 Web 服務器的傳統 DoS 攻擊不同,基於區塊鏈的 DoS 攻擊利用了智能合約的不可變和透明特性。 2. 這些攻擊的...
交易簽名中使用的加密隨機數是什麼?
2025-11-11 05:59:39
了解區塊鏈交易中的加密隨機數1. 加密隨機數是在區塊鍊網絡中的交易簽名上下文中僅使用一次的隨機數或偽隨機數。其主要功能是確保每筆交易都是唯一的並且不會被惡意行為者重播。如果沒有隨機數,相同的交易可能會被多次提交,從而導致意外的轉賬或餘額差異。 2. 在以太坊等系統中,隨機數直接與發送者的帳戶綁定,並...
Solidity 智能合約中的繼承是如何工作的?
2025-11-11 22:40:12
Solidity 的繼承:構建模塊化智能合約1. Solidity 中的繼承允許一個合約採用另一個合約的屬性和功能,從而實現代碼重用和結構化設計。派生合約可以從基礎合約繼承,獲得對其狀態變量、函數和修飾符的訪問權限,前提是它們沒有標記為私有。該機制支持邏輯的分層組織,減少多個合約之間的冗餘。 2. ...
外部擁有賬戶 (EOA) 和合約賬戶有什麼區別?
2025-11-13 04:00:32
了解外部擁有賬戶 (EOA) 1. 外部擁有的賬戶由私鑰直接控制,這意味著只有該密鑰的持有者才能從該賬戶發起交易。 EOA 沒有任何關聯代碼;它們是用於在區塊鏈上發送和接收交易的簡單地址。這些帳戶通常是在用戶使用 MetaMask 或 Ledger 等工俱生成錢包時創建的,從而產生公共地址和相應的私...
什麼是 ERC-2981 NFT 版稅標準以及它如何運作?
2025-11-13 05:39:54
了解 ERC-2981 NFT 版稅標準1. ERC-2981 標準是一項擬議的以太坊徵求意見稿,它引入了非同質代幣 (NFT) 的版稅機制。與 ERC-721 和 ERC-1155 等早期 NFT 標準缺乏對版稅的內置支持不同,ERC-2981 使創作者每次 NFT 在二級市場轉售時都能獲得補償。...
什麼是最小代理合約 (EIP-1167) 以及它如何在部署時節省 Gas?
2025-11-12 11:39:42
什麼是最小代理合同 (EIP-1167)? 1. 最小代理合約,根據以太坊改進提案 (EIP) 1167 進行標準化,是一種輕量級合約,旨在將調用委託給現有的實施合約。它充當代理,將所有函數調用和交易轉發到主合約,而無需在其內部存儲邏輯。 2. 核心機制依賴於低級SUCCESS、RETURNDATA...
什麼是智能合約中的拒絕服務 (DoS) 攻擊?其常見形式有哪些?
2025-11-10 05:20:08
了解智能合約中的拒絕服務1. 智能合約中的拒絕服務(DoS)攻擊是指惡意行為者阻止合法用戶訪問或使用合約功能的情況。這通常是通過利用允許攻擊者阻止關鍵操作的設計缺陷來實現的。與針對 Web 服務器的傳統 DoS 攻擊不同,基於區塊鏈的 DoS 攻擊利用了智能合約的不可變和透明特性。 2. 這些攻擊的...
交易簽名中使用的加密隨機數是什麼?
2025-11-11 05:59:39
了解區塊鏈交易中的加密隨機數1. 加密隨機數是在區塊鍊網絡中的交易簽名上下文中僅使用一次的隨機數或偽隨機數。其主要功能是確保每筆交易都是唯一的並且不會被惡意行為者重播。如果沒有隨機數,相同的交易可能會被多次提交,從而導致意外的轉賬或餘額差異。 2. 在以太坊等系統中,隨機數直接與發送者的帳戶綁定,並...
Solidity 智能合約中的繼承是如何工作的?
2025-11-11 22:40:12
Solidity 的繼承:構建模塊化智能合約1. Solidity 中的繼承允許一個合約採用另一個合約的屬性和功能,從而實現代碼重用和結構化設計。派生合約可以從基礎合約繼承,獲得對其狀態變量、函數和修飾符的訪問權限,前提是它們沒有標記為私有。該機制支持邏輯的分層組織,減少多個合約之間的冗餘。 2. ...
外部擁有賬戶 (EOA) 和合約賬戶有什麼區別?
2025-11-13 04:00:32
了解外部擁有賬戶 (EOA) 1. 外部擁有的賬戶由私鑰直接控制,這意味著只有該密鑰的持有者才能從該賬戶發起交易。 EOA 沒有任何關聯代碼;它們是用於在區塊鏈上發送和接收交易的簡單地址。這些帳戶通常是在用戶使用 MetaMask 或 Ledger 等工俱生成錢包時創建的,從而產生公共地址和相應的私...
什麼是 ERC-2981 NFT 版稅標準以及它如何運作?
2025-11-13 05:39:54
了解 ERC-2981 NFT 版稅標準1. ERC-2981 標準是一項擬議的以太坊徵求意見稿,它引入了非同質代幣 (NFT) 的版稅機制。與 ERC-721 和 ERC-1155 等早期 NFT 標準缺乏對版稅的內置支持不同,ERC-2981 使創作者每次 NFT 在二級市場轉售時都能獲得補償。...
什麼是最小代理合約 (EIP-1167) 以及它如何在部署時節省 Gas?
2025-11-12 11:39:42
什麼是最小代理合同 (EIP-1167)? 1. 最小代理合約,根據以太坊改進提案 (EIP) 1167 進行標準化,是一種輕量級合約,旨在將調用委託給現有的實施合約。它充當代理,將所有函數調用和交易轉發到主合約,而無需在其內部存儲邏輯。 2. 核心機制依賴於低級SUCCESS、RETURNDATA...
看所有文章














