時価総額: $2.8313T 0.35%
ボリューム(24時間): $138.9602B -22.27%
恐怖と貪欲の指数:

28 - 恐れ

  • 時価総額: $2.8313T 0.35%
  • ボリューム(24時間): $138.9602B -22.27%
  • 恐怖と貪欲の指数:
  • 時価総額: $2.8313T 0.35%
暗号
トピック
暗号化
ニュース
暗号造園
動画
トップクリプトスペディア

言語を選択する

言語を選択する

通貨の選択

暗号
トピック
暗号化
ニュース
暗号造園
動画

Solidity における call、delegatecall、staticcall の違いは何ですか?

Understanding `call`, `delegatecall`, and `staticcall` is crucial for secure Solidity development, as each alters execution context, state access, and security risks differently.

2025/11/14 18:59

Solidity での安全かつ効率的なスマート コントラクト開発には、call、delegatecall、staticcall の違いを理解することが不可欠です。これらの低レベル関数により、他のコントラクトまたは外部アカウントとの対話が可能になりますが、コンテキスト、状態変更、および実行環境に関しては動作が異なります。

電話

1.呼び出し関数は、指定された量の Ether を転送し、呼び出されたコントラクトのコンテキストでコードを実行しながら、別のコントラクトの関数を呼び出します。

  1. これは呼び出し先のストレージ、コード、残高を使用します。つまり、状態の変更はターゲット コントラクトのスコープ内で発生します。
  2. このメソッドは、コンパイル時に ABI が不明な外部コントラクトと対話するときによく使用されます。
  3. 呼び出しは成功または失敗を示すブール値とオプションの戻りバイトを返すため、開発者は戻りデータを慎重に処理する必要があります。
  4. 適切なチェック、効果、相互作用のパターンに従わない場合、誤用するとリエントランシーの脆弱性が発生する可能性があります。

デリゲートコール

1. delegatecall は、別のコントラクトのコードを実行しますが、呼び出し元のストレージ、コンテキスト、残高は保持します。

  1. これは、ロジックがデータから分離されているプロキシ パターンでよく使用され、アップグレード可能なコントラクトを可能にします。
  2. 状態の変更は呼び出し側コントラクトのストレージに影響するため、プロキシと実装の間でストレージ レイアウトを調整する場合には細心の注意が必要です。
  3. callとは異なり、追加のメカニズムを介して明示的に送信されない限り、 delegatecall中に Ether は転送されません。
  4. セキュリティ リスクには、プロキシ内の所有権や残高などの重要な変数を変更する悪意のある実装契約が含まれます。

静的呼び出し

1. staticcallは、ブロックチェーンの状態を変更しない関数を呼び出すように設計されています。

  1. ストレージへの書き込み、イベントの発行、または状態を変更する操作の実行を試みると、呼び出しが元に戻ります。
  2. この関数は、予期しない副作用の危険を冒さずに、外部コントラクトからデータを安全に読み取る場合に役立ちます。
  3. callと同様に、ターゲット コントラクトのコード内で動作しますが、実行時には読み取り専用モードが強制されます。
  4. その主な使用例には、トークン残高のクエリ、許容量の確認、またはサードパーティの契約からの不変値の取得が含まれます。

よくある質問

ストレージ レイアウトが一致しないコントラクトをデリゲートコールがターゲットにするとどうなりますか?呼び出し側コントラクトのストレージ スロットが、呼び出されるコントラクトのロジックで予期されるストレージ スロットと一致しない場合、変数が誤って上書きされる可能性があります。たとえば、1 つのスロットに格納されているアドレスが uint256 として解釈される可能性があり、データの破損や不正アクセスにつながる可能性があります。

staticcall を使用して支払い可能な関数と対話できますか?はい、 staticcall は、実際に状態を変更しない限り、ペイ可能な関数をターゲットにすることができます。ただし、値の転送には本質的に状態の変更が含まれており、呼び出しが失敗する可能性があるため、 staticcallを介して Ether を送信することは冗長です。

特定のシナリオでは、呼び出しが静的呼び出しよりもリスクが高いと考えられるのはなぜですか?コールでは状態変更とイーサ転送の両方が許可されるため、再入攻撃などの攻撃ベクトルが可能になります。厳密な入力検証と制御フロー管理がなければ、外部コントラクトによってコールバック中に再帰的に資金が枯渇する可能性があります。

delegatecall はあらゆるタイプの契約アップグレードと互換性がありますか? delegatecallではアップグレードが可能ですが、慎重な設計が必要です。ストレージの衝突、関数セレクターの衝突、初期化の問題により、機能が中断される可能性があります。透過的プロキシと UUPS パターンはこれらのリスクの軽減に役立ちますが、厳格なテストと監査が必要です。

免責事項:info@kdj.com

提供される情報は取引に関するアドバイスではありません。 kdj.com は、この記事で提供される情報に基づいて行われた投資に対して一切の責任を負いません。暗号通貨は変動性が高いため、十分な調査を行った上で慎重に投資することを強くお勧めします。

このウェブサイトで使用されているコンテンツが著作権を侵害していると思われる場合は、直ちに当社 (info@kdj.com) までご連絡ください。速やかに削除させていただきます。

関連知識

LayerZero コントラクトを使用してクロスチェーン メッセージを実行するにはどうすればよいですか?

LayerZero コントラクトを使用してクロスチェーン メッセージを実行するにはどうすればよいですか?

2026-01-18 13:19:39

LayerZero アーキテクチャを理解する1. LayerZero は、信頼できる仲介者やラップされた資産に依存せずにブロックチェーン間の通信を可能にする、軽量で許可のない相互運用性プロトコルとして動作します。 2. 各チェーンに展開されたウルトラ ライト ノード (ULN) を利用して、ブロック...

安全な署名検証のために EIP-712 を実装するにはどうすればよいですか?

安全な署名検証のために EIP-712 を実装するにはどうすればよいですか?

2026-01-20 22:20:26

EIP-712 の概要と主な目的1. EIP-712 は、イーサリアム アプリケーションにおける型付き構造化データのハッシュと署名の標準を定義します。 2. これにより、ウォレットは、署名リクエスト中に未加工の 16 進文字列の代わりに人間が判読できるドメインおよびメッセージ フィールドを表示できる...

新しい契約を交わしてエアドロップの資格を得るにはどうすればよいですか?

新しい契約を交わしてエアドロップの資格を得るにはどうすればよいですか?

2026-01-24 21:00:23

契約のやり取りの要件を理解する1. ほとんどのエアドロップ キャンペーンでは、Ethereum、Arbitrum、Base などのサポートされているブロックチェーンにデプロイされたスマート コントラクトとの直接対話が義務付けられています。 2. インタラクションには通常、dApp インターフェースに...

スマート コントラクトのセキュリティ アラートを監視するにはどうすればよいですか?

スマート コントラクトのセキュリティ アラートを監視するにはどうすればよいですか?

2026-01-21 07:59:57

オンチェーン監視ツール1. Etherscan や Blockscout などのブロックチェーン エクスプローラーを使用すると、コントラクト バイトコード、トランザクション ログ、内部呼び出しをリアルタイムで検査できます。 2. オンチェーンデータを信頼する前に、契約の検証ステータスを確認する必要が...

自動支払いのための契約を設定して資金を調達するにはどうすればよいですか?

自動支払いのための契約を設定して資金を調達するにはどうすればよいですか?

2026-01-26 08:59:35

スマートコントラクトの展開を理解する1. 開発者は、ガス効率とセキュリティ要件に基づいて、Ethereum、Polygon、Arbitrum などの互換性のあるブロックチェーン プラットフォームを選択する必要があります。 2. Solidity は、特に定期的な送金や条件付き送金の場合、支払い自動化...

OpenZeppelin コントラクトを使用して安全な dApp を構築するにはどうすればよいですか?

OpenZeppelin コントラクトを使用して安全な dApp を構築するにはどうすればよいですか?

2026-01-18 11:19:49

OpenZeppelin コントラクトの基礎を理解する1. OpenZeppelin Contracts は、イーサリアムおよび EVM 互換ブロックチェーン用に構築された、再利用可能なコミュニティ監査済みのスマート コントラクト コンポーネントのライブラリです。 2. ライブラリ内の各コントラクト...

LayerZero コントラクトを使用してクロスチェーン メッセージを実行するにはどうすればよいですか?

LayerZero コントラクトを使用してクロスチェーン メッセージを実行するにはどうすればよいですか?

2026-01-18 13:19:39

LayerZero アーキテクチャを理解する1. LayerZero は、信頼できる仲介者やラップされた資産に依存せずにブロックチェーン間の通信を可能にする、軽量で許可のない相互運用性プロトコルとして動作します。 2. 各チェーンに展開されたウルトラ ライト ノード (ULN) を利用して、ブロック...

安全な署名検証のために EIP-712 を実装するにはどうすればよいですか?

安全な署名検証のために EIP-712 を実装するにはどうすればよいですか?

2026-01-20 22:20:26

EIP-712 の概要と主な目的1. EIP-712 は、イーサリアム アプリケーションにおける型付き構造化データのハッシュと署名の標準を定義します。 2. これにより、ウォレットは、署名リクエスト中に未加工の 16 進文字列の代わりに人間が判読できるドメインおよびメッセージ フィールドを表示できる...

新しい契約を交わしてエアドロップの資格を得るにはどうすればよいですか?

新しい契約を交わしてエアドロップの資格を得るにはどうすればよいですか?

2026-01-24 21:00:23

契約のやり取りの要件を理解する1. ほとんどのエアドロップ キャンペーンでは、Ethereum、Arbitrum、Base などのサポートされているブロックチェーンにデプロイされたスマート コントラクトとの直接対話が義務付けられています。 2. インタラクションには通常、dApp インターフェースに...

スマート コントラクトのセキュリティ アラートを監視するにはどうすればよいですか?

スマート コントラクトのセキュリティ アラートを監視するにはどうすればよいですか?

2026-01-21 07:59:57

オンチェーン監視ツール1. Etherscan や Blockscout などのブロックチェーン エクスプローラーを使用すると、コントラクト バイトコード、トランザクション ログ、内部呼び出しをリアルタイムで検査できます。 2. オンチェーンデータを信頼する前に、契約の検証ステータスを確認する必要が...

自動支払いのための契約を設定して資金を調達するにはどうすればよいですか?

自動支払いのための契約を設定して資金を調達するにはどうすればよいですか?

2026-01-26 08:59:35

スマートコントラクトの展開を理解する1. 開発者は、ガス効率とセキュリティ要件に基づいて、Ethereum、Polygon、Arbitrum などの互換性のあるブロックチェーン プラットフォームを選択する必要があります。 2. Solidity は、特に定期的な送金や条件付き送金の場合、支払い自動化...

OpenZeppelin コントラクトを使用して安全な dApp を構築するにはどうすればよいですか?

OpenZeppelin コントラクトを使用して安全な dApp を構築するにはどうすればよいですか?

2026-01-18 11:19:49

OpenZeppelin コントラクトの基礎を理解する1. OpenZeppelin Contracts は、イーサリアムおよび EVM 互換ブロックチェーン用に構築された、再利用可能なコミュニティ監査済みのスマート コントラクト コンポーネントのライブラリです。 2. ライブラリ内の各コントラクト...

すべての記事を見る

User not found or password invalid

Your input is correct