-
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%
スマート コントラクトからストレージ変数を読み取る方法は?
Ethereum smart contracts store state in 32-byte slots; layout depends on variable order, types, inheritance, and compiler version—critical for accurate off-chain reads via `eth_getStorageAt`.
2026/01/21 11:00
Ethereum スマート コントラクトのストレージ レイアウトを理解する
1. Ethereum にデプロイされたすべてのスマート コントラクトは、永続ストレージ スロットに状態を維持します。永続ストレージ スロットはそれぞれ 32 バイト幅で、スロット 0 から順にインデックスが付けられます。
2. コンパイラは、型のサイズと効率性を考慮したパッキング ルールを考慮して、状態変数の宣言順序に基づいて格納場所を割り当てます。
3. 構造体、配列、およびマッピングは複雑さをもたらします。動的配列はスロットに長さを格納し、keccak256 で計算されたオフセットにデータを格納します。マッピングでは、keccak256(キー、スロット) を使用してストレージ位置を導出します。
4. 0.8.0 より前の Solidity バージョンでは、変数境界を越えてより厳密なパッキングが可能でしたが、新しいバージョンではより厳密な位置合わせが強制され、手動スロット計算の精度に影響を及ぼします。
5. コントラクトの継承はレイアウトに影響します。基本コントラクトからの変数が下位のスロットを占有し、その後に線形順序で派生コントラクトからの変数が続きます。
eth_getStorageAt による直接オンチェーン読み取り
1. JSON-RPC メソッドeth_getStorageAt は、コントラクト アドレス、スロット インデックス、およびブロック識別子を使用して、特定のストレージ スロットから生の 32 バイト値を取得します。
2. スロット インデックスは手動で計算するか、コントラクトのメタデータ ファイルやビルド情報ファイルにある Solidity 生成のストレージ レイアウト JSON などのコンパイル アーティファクトから抽出する必要があります。
3.hardhat -storage-layoutやSrither-print-storageなどのツールは、AST とバイトコードを解析することでスロット マッピングを自動化し、人的エラーを削減します。
4. infura または Alchemy エンドポイントを使用してクエリを実行する場合、レート制限とアーカイブ ノード要件が適用されます。特に、契約のアップグレードまたは自己破壊前の履歴スロット値に適用されます。
5. 16 進数でエンコードされた応答にはデコードが必要です。uint256 値は左詰めで表示され、アドレスは最後の 20 バイトで右詰めされ、ブール値は 0x01 または 0x00 にマップされます。
複合型を手動でデコードする
1. 静的配列の場合、各要素は適合する場合は 1 つのスロットを占有します。それ以外の場合、要素は標準の配置ルールに従って連続するスロットにあふれます。
2. 動的配列データは keccak256(slot) で始まり、最初の 32 バイトが配列の長さを保持し、後続のスロットには keccak256(slot)+1 から始まる要素が連続して格納されます。
3. マッピングではキーごとに keccak256 を再計算する必要があります。mapping (address => uint256) 公的残高の場合、アドレス 0xAbc… のスロットは keccak256(abi.encodePacked(0xAbc…, slot_index)) です。
4. ネストされた構造は複雑さを増します。たとえば、構造体へのマッピングでは、最初にマッピング スロットを計算し、次にそのベースを基準とした構造体フィールド オフセットを適用する必要があります。
5. 構造体の内部のオフセットは、トップレベルの変数と同じルールに従います。uint128 + uint128 は 1 つのスロットにパックされますが、uint256 を追加すると、アライメントの制約により新しいスロットが強制的に作成されます。
鋳造と鋳造による実際の検査
1. Cast storageコマンドはコントラクト アドレスとスロット番号を受け入れ、ABI またはレイアウトが提供されている場合は値を自動的にフェッチし、オプションでデコードします。
2. --watch を使用すると、キャストはブロック全体でのストレージの変更を監視します。これは、リエントラントやフラッシュ ローンの副作用をリアルタイムで観察するのに役立ちます。
3. Foundry のforge Inspection は、変数名、タイプ、スロット番号、バイト オフセットを含む完全なストレージ レイアウトを出力します。手動による ABI 解析は必要ありません。
4. ソース コードが利用できない場合は、リバース エンジニアリングが必要になります。トランザクション トレース内の SSTORE オペコードを分析すると、どのスロットがいつ書き込まれたかが明らかになります。
5. web3.py または ethers.js を活用したカスタム スクリプトは、複数のスロットのバッチクエリ、テーブルとしての出力のフォーマット、Transparent や UUPS などの既知のプロキシ パターンとの相互参照が可能です。
よくある質問
Q: ソース コードを知らなくても、コントラクトからストレージを読み取ることはできますか? A: はい。バイトコード分析、オペコード トレース、または OpenZeppelin プロキシや ERC-20 天びんの一般的なスロット パターンなどのヒューリスティックを使用します。しかし、文脈がなければ解釈は曖昧なままです。
Q: 存在することがわかっているゼロ以外の値に対して eth_getStorageAt がゼロを返すのはなぜですか? A: 考えられる原因としては、間違ったスロットのクエリ、古いブロック番号の使用、実装に転送せずにプロキシをターゲットにする、初期化されていないメモリ (デフォルトはゼロ) の読み取りなどが挙げられます。
Q: ストレージ読み取りをオフチェーンで実行するとガスがかかりますか? A: いいえ。eth_getStorageAtは無料の RPC 呼び出しです。ガスコストは、トランザクションまたはビュー関数内で実行されるオンチェーン読み取りにのみ適用されます。
Q: コンパイラのバージョン間でストレージ スロット番号を信頼しても安全ですか? A: 保証されません。Solidity の更新により、レイアウト アルゴリズムが変更される可能性があります。展開中に使用されるコンパイラの正確なバージョンと最適化設定を常に確認してください。
免責事項: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 残高に直接影響します。利益があれ...
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 取引ボット マーケットプレイスを使用して収益性の高い先物戦略を見つけるにはどうすればよいですか?
2026-06-02 04:39:47
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の半減期の時点で...
Bybit で BTC 取引を行う場合、リニア永久契約とインバース永久契約のどちらを選択すればよいですか?
2026-06-06 02:54:55
契約決済の仕組み1. Bybit のリニア無期限契約は USDT で決済されます。これは、すべての損益計算、証拠金要件、清算閾値がステーブルコイン単位で表示されることを意味します。 2. 逆永久契約は BTC 自体で決済されるため、すべての取引はトレーダーの BTC 残高に直接影響します。利益があれ...
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 取引ボット マーケットプレイスを使用して収益性の高い先物戦略を見つけるにはどうすればよいですか?
2026-06-02 04:39:47
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の半減期の時点で...
すべての記事を見る














