-
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%
require、assert、revert によるエラーチェックをどのように処理しますか?
Solidity's `require`, `revert`, and `assert` ensure secure smart contracts: use `require` for input validation, `revert` for custom errors, and `assert` for internal invariants.
2025/11/14 17:19
Solidity のエラー処理メカニズムを理解する
ブロックチェーン開発の世界、特にイーサリアムエコシステム内では、安全で信頼性の高いスマートコントラクトを作成することが最も重要です。契約の整合性を確保するための中核的な側面の 1 つは、適切なエラー処理です。 Solidity には、エラーを管理するためのいくつかの組み込み関数 ( require 、 revert 、およびassert )が用意されています。それぞれが明確な目的を果たし、ロジックの正確性を維持し、意図しない動作を防ぐために特定の状況下で使用されます。
入力と条件の検証に require を使用する
requireステートメントは主に、重要な操作を実行する前に入力、外部条件、または状態要件を検証するために使用されます。これにより、十分な残高、正しい送信者の役割、有効なタイムスタンプなど、特定の前提条件が満たされることが保証されます。 require ステートメント内の条件が false と評価された場合、トランザクションは元に戻され、実行中に行われた変更はすべて元に戻されます。重要なのは、require は未使用のガスを呼び出し元に返金するため、ユーザー入力の検証が効率的になります。
- アドレスや数値などの関数の引数を確認するには、require を使用します。
- msg.sender に適切な役割があることを確認して、アクセス制御を検証します。
- block.timestamp を期限と照合するなど、時間ベースの条件が満たされていることを確認します。
- 資産を譲渡する前に、トークンの許容量または残高を確認してください。
- 失敗の理由を明確にするために、require ステートメントに説明的な文字列を含めます。
カスタマイズされたエラー処理に復帰を活用する
revert は、 require と比較して、エラー メッセージと条件をより詳細に制御できます。 require は条件が失敗したときに自動的に元に戻りますが、revert を使用すると、開発者はオプションのカスタム エラー メッセージを使用してコード内の任意の時点で元に戻すことができます。 Solidity 0.8.4 以降、開発者はerrorキーワードを使用してカスタム エラー タイプを定義できるようになり、文字列メッセージよりも効率的にエラーをエンコードすることでガスを節約できます。
- error キーワードを使用してカスタム エラーを定義し、復帰時のガス コストを削減します。
- 複雑なロジックが無効な状態と判断した場合は、明示的に revert を呼び出します。
- わかりやすくするために、InvalidAddress() や InsufficientFunds(uint) などの構造化エラー タイプを使用します。
- 要件でカバーされていない予期しないエッジケースを検出した後、復帰をトリガーします。
- revert と修飾子を組み合わせて、複数の関数にわたる検証ロジックを一元化します。
内部不変チェックのためのアサートの適用
assert は、内部不変条件、つまりコードが正しく実装されている場合に false にならない条件をチェックするために予約されています。トリガーされた場合は、コントラクト内のバグを示します。 require とは異なり、assert は失敗すると残りのガスをすべて消費するため、算術オーバーフロー (Solidity 0.8 以前) や保存されたデータの予期せぬ変更などの回復不可能なエラーを検出するためにのみ使用する必要があります。 Solidity の新しいバージョンでは、多くの算術問題が自動的に処理されるため、手動によるアサートの必要性が減ります。
- Assert を使用して、計算後に変数の値が予想範囲内に留まっていることを確認します。
- 実行中に重要なストレージ変数が破損していないことを確認してください。
- 到達不能なコード パスが実際に到達不能であることを、assert(false) を使用して確認します。
- 入力検証や外部条件には Assert を使用しないでください。これは内部一貫性を目的としています。
- アサートの失敗は、ユーザーによる修正ではなく、コードの修正が必要な重大なバグを示していることを理解してください。
よくある質問
require が失敗した場合、gas はどうなりますか? require ステートメントが失敗すると、トランザクションは元に戻され、すべての状態変更がロールバックされます。未使用のガスは呼び出し元に返されるため、無効な入力を送信するユーザーのコストが最小限に抑えられます。
require でカスタム エラーを使用できますか?いいえ、require はブール条件とオプションの文字列メッセージのみを受け入れます。 error キーワードで定義されたカスタム エラー タイプを使用するには、代わりに revert を使用する必要があります。
Solidity 0.8以降でもassertは必要ですか? Solidity 0.8 以降では自動オーバーフロー チェックが行われたため、その使用は減少しました。ただし、カスタムの不変条件や、プログラミング エラーを示す予期しない論理状態を検証する場合には依然として役立ちます。
なぜrequireではなくrevertを選択するのでしょうか? revert は、実行の中止を決定する前に複雑な評価を実行する必要がある場合、または可読性を高めてガスコストを削減するためにカスタム エラーを活用する場合に選択されます。これは、require によって提供される単純な条件チェックを超える柔軟性を提供します。
免責事項:info@kdj.com
提供される情報は取引に関するアドバイスではありません。 kdj.com は、この記事で提供される情報に基づいて行われた投資に対して一切の責任を負いません。暗号通貨は変動性が高いため、十分な調査を行った上で慎重に投資することを強くお勧めします。
このウェブサイトで使用されているコンテンツが著作権を侵害していると思われる場合は、直ちに当社 (info@kdj.com) までご連絡ください。速やかに削除させていただきます。
- ビットコイン、eCash フォーク、Airdrop のダイナミクス: 暗号通貨の最新の論争を深く掘り下げる
- 2026-05-03 12:55:01
- コンセンサス 2026 マイアミ: Web3、ブロックチェーン、暗号通貨、NFT、メタバース、カンファレンス、5 月 5 日 — ウォール街とデジタル フロンティアが出会う場所
- 2026-05-02 12:45:01
- FRBが金利を据え置き、地政学的な緊張の中、ビットコイン価格の下落を引き起こす
- 2026-05-01 06:45:01
- ビットコインマイナーが送電網を電化:オハイオ州のガス工場買収がデジタルゴールドの新時代を加速
- 2026-05-01 00:45:01
- MegaETH の MEGA トークンがビッグアップルに到達: リアルタイム ブロックチェーンの新しいパフォーマンス ベンチマークを設定
- 2026-05-01 00:55:01
- ソラナの滑りやすい坂道: 価格予測は抵抗力の損失とさらなる下落の可能性を示している
- 2026-05-01 06:45:01
関連知識
Bybit で BTC 取引を行う場合、リニア永久契約とインバース永久契約のどちらを選択すればよいですか?
2026-06-06 02:54:55
契約決済の仕組み1. Bybit のリニア無期限契約は USDT で決済されます。これは、すべての損益計算、証拠金要件、清算閾値がステーブルコイン単位で表示されることを意味します。 2. 逆永久契約は BTC 自体で決済されるため、すべての取引はトレーダーの BTC 残高に直接影響します。利益があれ...
ストップハントやなりすましなどの先物市場操作を特定して回避するにはどうすればよいでしょうか?
2026-06-07 14:20:10
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の半減期の時点で...
Bybit で 1 日の最大損失を制限するリスク管理ルールを設定するにはどうすればよいですか?
2026-06-04 16:40:15
アカウントレベルの損失制限の設定1. 2 要素認証を使用して、Web またはモバイル アプリケーション経由で Bybit アカウントにログインします。 2. 「資産」セクションに移動し、左側のメニューから「リスク管理」を選択します。 3. 「日次損失制限」を選択し、機能をオンに切り替えてコントロール...
Binance でポートフォリオ証拠金モードを有効にして証拠金要件を減らすにはどうすればよいですか?
2026-06-05 04:59:43
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、ブロックごとに流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の...
オープン先物ポジションをクローズせずに Binance から Bybit に移行するにはどうすればよいですか?
2026-06-04 03:59:47
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の半減期の時点で...
米国における仮想通貨先物取引の利益による税金への影響をどのように処理すればよいでしょうか?
2026-05-29 18:19:59
Bitcoin 半減力学1. Bitcoin のプロトコルでは、ブロック報酬を通じて新しいユニットが導入され、2,100 万コインの固定供給上限が強制されます。 2. 210,000 ブロックごと、つまり約 4 年ごとに、ブロック報酬は半分に減ります。これは半減として知られるプロセスです。 3. 最...
Bybit で BTC 取引を行う場合、リニア永久契約とインバース永久契約のどちらを選択すればよいですか?
2026-06-06 02:54:55
契約決済の仕組み1. Bybit のリニア無期限契約は USDT で決済されます。これは、すべての損益計算、証拠金要件、清算閾値がステーブルコイン単位で表示されることを意味します。 2. 逆永久契約は BTC 自体で決済されるため、すべての取引はトレーダーの BTC 残高に直接影響します。利益があれ...
ストップハントやなりすましなどの先物市場操作を特定して回避するにはどうすればよいでしょうか?
2026-06-07 14:20:10
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の半減期の時点で...
Bybit で 1 日の最大損失を制限するリスク管理ルールを設定するにはどうすればよいですか?
2026-06-04 16:40:15
アカウントレベルの損失制限の設定1. 2 要素認証を使用して、Web またはモバイル アプリケーション経由で Bybit アカウントにログインします。 2. 「資産」セクションに移動し、左側のメニューから「リスク管理」を選択します。 3. 「日次損失制限」を選択し、機能をオンに切り替えてコントロール...
Binance でポートフォリオ証拠金モードを有効にして証拠金要件を減らすにはどうすればよいですか?
2026-06-05 04:59:43
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、ブロックごとに流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の...
オープン先物ポジションをクローズせずに Binance から Bybit に移行するにはどうすればよいですか?
2026-06-04 03:59:47
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の半減期の時点で...
米国における仮想通貨先物取引の利益による税金への影響をどのように処理すればよいでしょうか?
2026-05-29 18:19:59
Bitcoin 半減力学1. Bitcoin のプロトコルでは、ブロック報酬を通じて新しいユニットが導入され、2,100 万コインの固定供給上限が強制されます。 2. 210,000 ブロックごと、つまり約 4 年ごとに、ブロック報酬は半分に減ります。これは半減として知られるプロセスです。 3. 最...
すべての記事を見る














