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

28 - 恐れ

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

言語を選択する

言語を選択する

通貨の選択

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

Solidity のビュー関数と純粋関数とは何ですか?また、それらのガスへの影響は何ですか?

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 のビュー関数は、ブロックチェーンの状態を変更しないことを約束する関数の一種です。コントラクトのストレージ変数から読み取ることはできますが、変数を変更したり、イベントを発行したり、状態を変更する関数を呼び出したりすることはできません。

  1. これらの関数は状態を変更しないため、トランザクションをネットワークにブロードキャストすることなく、イーサリアム ノード上でローカルに実行できます。これは、ユーザーが外部に電話をかけるときにガス料金を支払う必要がないことを意味します。
  2. キーワードview は関数シグネチャ内で明示的に宣言する必要があります。省略した場合、関数が状態を変更しようとすると、コンパイラはエラーをスローします。
  3. 例には、ユーザーの残高の取得、ERC-20 トークンの許容量の確認、契約に保存されている構成パラメーターの読み取りなどが含まれます。
  4. 外部呼び出し元にとってビュー関数は無料であるにもかかわらず、依然としてノード上の計算リソースを消費します。したがって、ビュー関数内のロジックが過度に複雑であると、一部のプロバイダーによるタイムアウトや拒否が発生する可能性があります。

Solidity での純粋な機能の探索

1. 純粋関数は、状態変数の読み取りも書き込みも行わないことを約束することで、ビュー関数よりも一歩進んでいます。これは、渡された入力パラメータに対してのみ動作します。

  1. これらの関数は通常、保存されたデータに依存しない数学的計算、エンコード/デコード操作、または論理チェックに使用されます。
  2. pureキーワードは、コンパイル時にこの制限を強制します。単一の状態変数にさえアクセスしようとすると、コンパイルが失敗します。
  3. ビュー関数と同様、純粋関数はトランザクションを必要としないため、外部から呼び出すときにガスコストがかかりません。これらは、ローカル ノード リソースを使用してオフチェーンで実行されます。
  4. 例としては、入力引数に基づいて複利を計算したり、コントラクト ストレージを参照せずに暗号署名を検証したりする関数が挙げられます。

非修飾関数のガスの影響

1. スマート コントラクト関数がviewまたはpureとしてマークされている場合、その関数への外部呼び出しはトランザクションを生成しません。その結果、発信者にガスが請求されることはありません。

  1. ただし、内部的には、ビューまたは純粋な関数がトランザクション内の別の関数によって呼び出された場合、その実行によって依然としてガスが消費されます。 EVM は、状態変化が発生したかどうかに関係なく、すべての操作を処理する必要があります。
  2. このような関数内の複雑な計算 (大規模な配列のループや複数の算術演算の実行など) を内部で呼び出すと、ガス コストが増加します。
  3. 開発者は多くの場合、特に状態が変化するトランザクション中に呼び出される可能性がある場合に、ビュー/純粋関数での計算を最小限に抑えてパフォーマンスを最適化します。
  4. 実際に状態を変更するときに関数をビューまたは純粋と誤ってラベル付けすると、実行時例外やデプロイメントの失敗につながり、開発時間とテストネット ガスが無駄になる可能性があります。

ビューと純粋関数に関するよくある質問

Q: ビュー関数は純粋な関数を呼び出すことができますか? A: はい、ビュー関数は純粋な関数を安全に呼び出すことができます。純粋関数は状態の読み取りや変更を行わないため、ビュー関数の制約と完全に互換性があります。

Q: 純粋関数内の状態変数を変更しようとするとどうなりますか? A: Solidity コンパイラーはエラーを生成します。純粋な関数は、読み取りまたは書き込みのいずれの場合でも、状態変数にアクセスすることを固く禁じられています。

Q: view 関数と pure 関数は、web3.js または ethers.js から呼び出されるときに Gas を使用しますか? A: いいえ、JavaScript ライブラリ経由でこれらの関数を呼び出すにはトランザクションは必要ないため、ガスコストは発生しません。実行は、接続された Ethereum ノード上でローカルに行われます。

Q: ビュー関数と純粋関数の間にパフォーマンスの違いはありますか? A: ガスコストと実行速度の観点からは、外部から呼び出す場合に本質的な違いはありません。どちらも状態を変更せずにローカルで実行されます。内部的には、パフォーマンスは使用される修飾子ではなく計算の複雑さに依存します。

免責事項: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