-
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 provides `require`, `revert`, and `assert` for error handling, ensuring secure and predictable smart contract execution.
2025/07/20 05:00
堅牢性でのエラー処理の理解
Ethereumスマートコントラクトの主要なプログラミング言語であるSolidityは、エラー処理のためのいくつかのメカニズムを提供します。これらのメカニズムは、予期しない条件または無効な条件が発生した場合に契約が予測可能かつ安全に動作することを保証するために重要です。堅牢性でエラー処理に利用できる主なツールは、 require 、 revert 、およびassertます。これらの各機能は異なる目的を果たし、状況に基づいて適切に使用する必要があります。
入力検証にrequireを使用します
require関数は、主に関数のコアロジックを実行する前に入力と条件を検証するために使用されます。評価requireために提供された条件がfalseになると、トランザクションが戻り、状態に加えられた変更は後退します。さらに、開発者はカスタムエラーメッセージを提供できるようにしrequire 。
function transfer(address to, uint amount) public {require(amount > 0, 'Amount must be greater than zero'); require(balance[msg.sender] >= amount, 'Insufficient balance'); balance[msg.sender] -= amount; balance[to] += amount;
}
この例では、送信者のバランスが十分にあり、転送される金額が有効であることをrequire 。いずれかの条件が失敗した場合、トランザクションは明確なエラーメッセージで戻ります。
カスタムエラー条件にrevert
revert関数は、開発者が関数内の任意のポイントで実行を戻すことを許可することで、 requireよりも多くの柔軟性を提供します。複雑なロジックまたは単一のrequireステートメントで簡単に処理されない可能性のある複数の条件を扱う場合に特に役立ちます。
function withdraw(uint amount) public {if (amount > balance[msg.sender]) { revert('Insufficient funds for withdrawal'); } if (block.timestamp < lockTime[msg.sender]) { revert('Funds are locked until a later time'); } balance[msg.sender] -= amount; payable(msg.sender).transfer(amount);
}
このシナリオでは、 revertを使用して、撤退を防ぐことができる2つの異なる条件を処理します。各条件は個別に評価され、条件が故障したときに特定のメッセージが返されます。
内部エラー検出のためにassertを利用します
assert関数は、不変剤をチェックし、通常の状況では決して発生しない内部エラーをキャッチすることを目的としています。 requireとrevertは異なり、 assertを使用すると、トリガーされたときにトランザクションで提供されるすべてのガスが消費されます。したがって、重要なバグが疑われる状況のために予約する必要があります。
function calculateSum(uint a, uint b) internal pure returns (uint) {uint sum = a + b; assert(sum >= a); return sum;
}
この関数では、 assert 、追加操作がアンダーフローやオーバーフローをもたらさないことを保証します。そのような異常が発生した場合、トランザクションは戻り、コードの潜在的なバグを示します。
require 、 revert 、およびassertの違い
堅牢性での効果的なエラー処理のために、 require 、 revert 、およびassertの区別を理解することが不可欠です。
- ガス消費:エラーのポイントまでガスのみを
require、revert、assertは提供されたすべてのガスを消費します。 - ユースケース:
require、入力検証に最適であり、カスタム条件にrevert、内部ロジックチェックをassert。 - エラーメッセージ:カスタムエラーメッセージ
requireとrevert両方が許可されます。assert、古いバージョンのSolidity(0.8.0以前)でカスタムメッセージを返す方法を提供しません。
適切なエラー処理方法を選択すると、スマートコントラクトが安全で効率的であることが保証されます。
堅牢性のカスタムエラー
Solidity 0.8.0から始めて、開発者は、文字列ベースのエラーメッセージよりもガス効率が高く読みやすいカスタムエラータイプを定義できます。カスタムエラーはerrorキーワードを使用して定義され、 revertと組み合わせて使用できます。
error InsufficientBalance(uint requested, uint available); error FundsLocked(uint releaseTime, uint currentTime);関数撤回(UINT量)public {if (amount > balance[msg.sender]) { revert InsufficientBalance(amount, balance[msg.sender]); } if (block.timestamp < lockTime[msg.sender]) { revert FundsLocked(lockTime[msg.sender], block.timestamp); } balance[msg.sender] -= amount; payable(msg.sender).transfer(amount);}
カスタムエラーを使用することにより、開発者は、ガス使用量の点で理解しやすく効率的な構造化されたエラー情報を提供できます。
よくある質問
Q:入力検証にassert使用できますか? A:いいえ、入力検証にはassertを使用しないでください。内部チェック用に設計されており、到達不可能なコードまたは重要なバグを検出するためにのみ使用する必要があります。
Q:文字列メッセージと比較して、カスタムエラーはガスをどのように保存しますか? A:カスタムエラーは、フル文字列メッセージよりもはるかに短く、安価な関数署名と同様の4バイトセレクターとしてエンコードされます。これにより、エラーがトリガーされるとガスコストが削減されます。
Q:契約のエラーを処理しないとどうなりますか? A:エラーが適切に処理されていない場合、無効または予期しない条件が、攻撃者が悪用する可能性のある状態の変更、資金の喪失、または脆弱性に誤った変化につながる可能性があります。
Q:同じ関数でrequireを組み合わせてrevertはできますか? A:はい、同じ関数でrequireとrevert必要があります。通常、単純な条件チェックにはrequireが使用されますが、 revert 、関数の後半でより複雑なまたは条件付き戻りに使用されます。
免責事項:info@kdj.com
提供される情報は取引に関するアドバイスではありません。 kdj.com は、この記事で提供される情報に基づいて行われた投資に対して一切の責任を負いません。暗号通貨は変動性が高いため、十分な調査を行った上で慎重に投資することを強くお勧めします。
このウェブサイトで使用されているコンテンツが著作権を侵害していると思われる場合は、直ちに当社 (info@kdj.com) までご連絡ください。速やかに削除させていただきます。
- ヘンリー 8 世、愛のトークン、大英博物館: 黄金の心の不朽の物語
- 2026-02-10 22:15:01
- 仮想通貨市場のボラティリティと規制に関する話題の中でビットコイン価格が急騰
- 2026-02-10 22:15:01
- Wintermute が警鐘を鳴らす:AI の流動性枯渇が仮想通貨情勢の進化の中でビットコインを揺るがす
- 2026-02-10 22:10:01
- サム・バンクマン・フリードの刑務所ショッカー:FTX「決して破産しない」と主張、進行中の佐賀で弁護士を標的に
- 2026-02-10 21:50:02
- オリンピック 50 ペンス コインの熱狂: 珍しい掘り出し物を求めるイギリスのコレクター
- 2026-02-10 22:10:01
- 精査中のCEX台帳:2000BTCの不具合と信頼の基本的な問題
- 2026-02-10 21:50:02
関連知識
デイトレード暗号通貨のレバレッジを安全に最大化するにはどうすればよいですか?
2026-02-08 01:19:53
暗号デリバティブにおけるレバレッジの仕組みを理解する1. レバレッジにより、トレーダーは必要な資金の一部でより大きなポジションをコントロールできるようになり、潜在的な利益と損失の両方が倍増します。 2. ほとんどの暗号通貨取引所は、資産ペアとアカウント検証レベルに応じて、2 倍から 125 倍までの...
スキャルピング用の「ワンクリック」取引インターフェイスを設定するにはどうすればよいですか?
2026-02-09 22:59:56
コアアーキテクチャ要件1. 50 ミリ秒未満の間隔でリアルタイムの買値更新を受信するには、取引所の注文帳フィードとの低遅延 WebSocket 接続を直接確立する必要があります。 2. インターフェイスは、ルーティング遅延を引き起こす外部バックエンド プロキシへの依存を避けるために、WebAssem...
メジャーアップグレードの前後でイーサリアム先物を取引するにはどうすればよいですか?
2026-02-08 09:40:26
イーサリアム先物の仕組みを理解する1. イーサリアム先物契約は、CME やバイナンス先物などの規制された取引所で、あらかじめ決められた価格と日付で ETH を売買するための標準化された契約です。 2. レバレッジは重要な役割を果たします。トレーダーは最小限の資金で大きなポジションを管理でき、変動期間...
大規模契約取引用の流動性の高いペアを見つけるにはどうすればよいですか?
2026-02-08 18:20:09
大規模契約取引向けの流動性の高いペアを見つける大規模な契約注文を実行するトレーダーは、スリッページや価格への影響を避けるために流動性を優先する必要があります。流動性の低い環境では、特に資金調達率とベーシスの乖離によりボラティリティが増大する無期限先物やインバース契約において、実行リスクが増幅されます...
清算を防ぐために「マーク価格」と「最終価格」を使用する方法は?
2026-02-07 17:39:59
マーク価格の仕組みを理解する1. マーク価格は、複数のスポット為替指数と資金調達率の調整から導出される複合価値であり、永久契約の公正な市場価値を反映するように設計されています。 2. Binance、Coinbase、Kraken、Bybit などの主要なスポット市場からのリアルタイム データを組み...
レバレッジ取引における「自己資本利益率(ROE)」の計算方法は?
2026-02-08 04:39:45
レバレッジ取引における自己資本利益率を理解する1. レバレッジ取引における自己資本利益率 (ROE) は、ポジションの合計サイズではなく、トレーダーの自己資金と比較して生み出される収益性を測定します。これは、トレーダーが取引所やブローカーから資金を借りる際に、自分の株式をどれだけ効率的に利用するかを...
デイトレード暗号通貨のレバレッジを安全に最大化するにはどうすればよいですか?
2026-02-08 01:19:53
暗号デリバティブにおけるレバレッジの仕組みを理解する1. レバレッジにより、トレーダーは必要な資金の一部でより大きなポジションをコントロールできるようになり、潜在的な利益と損失の両方が倍増します。 2. ほとんどの暗号通貨取引所は、資産ペアとアカウント検証レベルに応じて、2 倍から 125 倍までの...
スキャルピング用の「ワンクリック」取引インターフェイスを設定するにはどうすればよいですか?
2026-02-09 22:59:56
コアアーキテクチャ要件1. 50 ミリ秒未満の間隔でリアルタイムの買値更新を受信するには、取引所の注文帳フィードとの低遅延 WebSocket 接続を直接確立する必要があります。 2. インターフェイスは、ルーティング遅延を引き起こす外部バックエンド プロキシへの依存を避けるために、WebAssem...
メジャーアップグレードの前後でイーサリアム先物を取引するにはどうすればよいですか?
2026-02-08 09:40:26
イーサリアム先物の仕組みを理解する1. イーサリアム先物契約は、CME やバイナンス先物などの規制された取引所で、あらかじめ決められた価格と日付で ETH を売買するための標準化された契約です。 2. レバレッジは重要な役割を果たします。トレーダーは最小限の資金で大きなポジションを管理でき、変動期間...
大規模契約取引用の流動性の高いペアを見つけるにはどうすればよいですか?
2026-02-08 18:20:09
大規模契約取引向けの流動性の高いペアを見つける大規模な契約注文を実行するトレーダーは、スリッページや価格への影響を避けるために流動性を優先する必要があります。流動性の低い環境では、特に資金調達率とベーシスの乖離によりボラティリティが増大する無期限先物やインバース契約において、実行リスクが増幅されます...
清算を防ぐために「マーク価格」と「最終価格」を使用する方法は?
2026-02-07 17:39:59
マーク価格の仕組みを理解する1. マーク価格は、複数のスポット為替指数と資金調達率の調整から導出される複合価値であり、永久契約の公正な市場価値を反映するように設計されています。 2. Binance、Coinbase、Kraken、Bybit などの主要なスポット市場からのリアルタイム データを組み...
レバレッジ取引における「自己資本利益率(ROE)」の計算方法は?
2026-02-08 04:39:45
レバレッジ取引における自己資本利益率を理解する1. レバレッジ取引における自己資本利益率 (ROE) は、ポジションの合計サイズではなく、トレーダーの自己資金と比較して生み出される収益性を測定します。これは、トレーダーが取引所やブローカーから資金を借りる際に、自分の株式をどれだけ効率的に利用するかを...
すべての記事を見る














