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

28 - 恐れ

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

言語を選択する

言語を選択する

通貨の選択

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

Solidity のマッピングとは何ですか?また、キーと値のペアはどのように保存されますか?

Mappings in Solidity enable efficient, gas-optimized key-value storage using keccak256 hashing, ideal for balances, access control, and lookup-heavy smart contract use cases.

2025/11/10 12:20

Solidity でのマッピングを理解する

1. Solidity のマッピングは、他のプログラミング言語のハッシュ テーブルや辞書と同様に、キーと値のペアの形式でデータを格納するために使用される参照タイプです。これにより、開発者は一意のキーを特定の値に関連付けることができ、効率的な検索と更新が可能になります。

2. マッピングを宣言するための構文は、mapping(keyType => valueType)です。ここで、keyType には、uint、address、bytes などのほぼすべての基本型を指定できますが、配列やその他のマッピングのような参照型は指定できません。 valueType には、構造体、配列、または別のマッピングを含む任意の型を指定できます。

3. マッピングはコントラクト内で宣言され、通常は状態変数を維持するために使用されます。これらはストレージに保存されるため、その値は関数呼び出しやトランザクションにわたって保持されます。

4. マッピングの特徴の 1 つは、反復できないことです。キーまたは値のリストを取得する組み込みメカニズムはありません。この制限は、イーサリアムのストレージ モデルの仕組みに由来します。つまり、マッピングは列挙ではなくキーによって高速にアクセスできるように設計されています。

5. マッピングが作成されると、すべての可能なキーが valueType のデフォルト値 (たとえば、整数の場合は 0、ブール値の場合は false) で初期化されます。これは、存在しないキーにアクセスすると、エラーがスローされるのではなく、デフォルト値が返されることを意味します。

マッピングの背後にあるストレージメカニズム

1. マッピングでは、データを従来のテーブル形式で保存しません。代わりに、Solidity は keccak256 ハッシュ関数を使用してストレージ スロットを動的に計算します。各キーは、マッピング変数のストレージ スロットの位置とともに keccak256 を使用してハッシュされます。

2. ストレージ スロットnにある状態変数マッピングの場合、特定のキーに関連付けられた値はkeccak256(key . slot)に格納されます。連結を表します。これにより、各キーがストレージ内の固有の決定的な場所にマッピングされることが保証されます。

3. ハッシュ関数は一方向であるため、どのキーが設定されているかをリバース エンジニアリングすることは計算上不可能です。これにより、マッピングを反復できなくなります。

4. ネストされたマッピングも同じ原則に従います。マッピング(address => マッピング(uint => bool)) のようなマッピングでは、内部マッピングのスロットは、外部キーと外部マッピングのスロットをハッシュし、その結果を内部キー検索のベースとして使用することによって決定されます。

5. このハッシュ ベースのストレージ レイアウトにより、読み取りおよび書き込み操作のマッピングが非常に効率的になり、どちらの操作もエントリの数に関係なく一定時間で実行されます。

スマートコントラクトの実用的な使用例

1. マッピングの一般的な用途の 1 つは、ERC-20 トークンのユーザー残高を追跡することです。 mapping (address => uint256) private _balancesのようなマッピングを使用すると、任意のウォレット アドレスのトークン保有を迅速に取得および更新できます。

2. アクセス制御システムは、役割や権限を識別するためにマッピングを使用することがよくあります。たとえば、mapping(address => bool) public isAdmin は、アドレスに管理者権限があるかどうかを効率的に検証できます。

3. 分散型取引所または NFT マーケットプレイスでは、マッピングにより注文 ID またはトークン ID が価格、所有者、出品ステータスなどの構造化データにリンクされます。これにより、大規模なデータセットをスキャンすることなく、取引詳細を即座に検索できるようになります。

4. マッピングは、関数の実行中にアドレスをマークすることで再入攻撃を防ぐためにも使用されます。入力された単純なマッピング(アドレス => ブール値) プライベートは、ロック メカニズムとして機能します。

5. ガス効率の高いアクセス パターンのため、特に高スループット プロトコルで識別子による頻繁な検索が必要な場合は、マッピングがアレイよりも優先されます。

よくある質問

マッピングを完全に削除できますか?はい、マッピングで delete キーワードを使用すると、書き込まれた各スロットがデフォルト値にリセットされ、すべてのエントリがクリアされます。ただし、マッピングはすべてのキーのデフォルト値で仮想的に初期化されるため、この操作は明示的に割り当てられたキーにのみ影響します。

関数からマッピングを返すことはできますか?いいえ、マッピングは Solidity では有効な戻り値の型ではないため、関数から直接返すことはできません。キーを介してアクセスされた特定の値のみを返すことができます。

文字列または動的配列をマッピングキーとして使用できますか?文字列および動的バイト配列はマッピング キーとして使用できません。 bytes32、uint、address などの固定サイズのデータ​​型のみが許可されます。必要に応じて、文字列を bytes32 などの固定サイズ形式に変換する必要があります。

マッピングはガス料金にどのような影響を与えますか?初期化されていないキーを使用してマッピングから読み取ると、ストレージを変更せずにデフォルト値が返されるため、ガスの消費が少なくなります。値の書き込みまたは更新では、イーサリアムの状態成長コスト ルールにより、特にゼロ値をゼロ以外に変更する場合、より多くのガスが発生します。

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