-
bitcoin $103163.554157 USD
-3.05% -
ethereum $3440.538470 USD
-4.50% -
tether $0.999930 USD
0.00% -
xrp $2.408381 USD
-5.38% -
bnb $962.292695 USD
-3.83% -
solana $155.202339 USD
-7.60% -
usd-coin $1.000166 USD
0.01% -
tron $0.298210 USD
0.35% -
dogecoin $0.172672 USD
-5.44% -
cardano $0.558494 USD
-6.71% -
hyperliquid $38.819383 USD
-5.91% -
chainlink $15.335896 USD
-7.06% -
bitcoin-cash $507.908940 USD
-3.06% -
stellar $0.282633 USD
-6.38% -
unus-sed-leo $9.242665 USD
0.58%
Solidity でシンプルなスマート コントラクトを作成するにはどうすればよいですか?
Set up your Solidity dev environment with Node.js, Hardhat, and the Solidity compiler, then write, compile, and test a basic contract like Lock.sol locally.
2025/11/06 05:30
開発環境のセットアップ
1. Node.js と npm をインストールして依存関係を管理し、Solidity 開発に必要なローカル ツールを実行します。
2. npm を使用して、スマート コントラクトの作成、テスト、デプロイをサポートする強力な Ethereum 開発環境である Hardhat をインストールします。
3. 端末でnpx ハードハットを使用して新しいハードハット プロジェクトを初期化し、基本的なフォルダー構造と構成ファイルをセットアップします。
4. Hardhat のプラグイン システムを通じて依存関係として追加して Solidity コンパイラーをインストールし、ターゲット EVM バージョンとの互換性を確保します。
5. 最初の契約の作成を開始するには、契約ディレクトリ内にLock.solという名前の新しいファイルを作成します。
Solidity で基本的なスマート コントラクトを作成する
1. コンパイラのバージョンを指定するプラグマステートメントで Solidity ファイルを開始します ( pragma Solidity ^0.8.0;など)。 。
2.コントラクトキーワードの後に Lockなどの名前を付けてコントラクトを定義し、すべてのロジックを中括弧内にカプセル化します。
3.オンチェーンにデータを保存するための状態変数を宣言します。たとえば、次のようになります。支払い義務のある公的所有者に住所を指定します。 。
4. コントラクトのデプロイ時に 1 回実行されるコンストラクターを実装し、所有者やロック解除タイムスタンプなどの初期値を設定します。
5. 修飾子を使用したアクセス制御を含むdraw()のような関数を追加するか、一定時間後の実行を所有者に制限するrequireステートメントを追加します。
Solidity の修飾子機能を使用すると、開発者は複数の関数にわたって検証ロジックを再利用できるため、コードの可読性が向上し、冗長性が削減されます。
ローカルでのコントラクトのコンパイルとデプロイ
1. JavaScript または TypeScript を使用してスクリプト フォルダーに展開スクリプトを作成し、コントラクトをインスタンス化し、ローカル ネットワークに送信します。
2. Hardhat の内蔵ネットワークを使用して、テスト中に実際の資金を費やすことなくイーサリアム環境をシミュレートします。
3. コンパイル コマンドnpxhardhatcompile を実行して、構文エラーがないことを確認し、ABI アーティファクトを生成します。
4. npx ハードハット run scripts/deploy.js経由でデプロイメント スクリプトを実行し、コントラクトをローカル ノードにデプロイします。
5. 後続の手順での対話と検証のために、デプロイされたコントラクト アドレスを取得します。
スマートコントラクトの動作をテストする
1. 所有権や時間ベースの出金ルールなどのコア機能を検証するために、テスト ディレクトリにテスト ファイルを作成します。
2. テスト内で ethers.js を使用して、デプロイされたコントラクト インスタンスと対話し、ユーザー アクションをシミュレートします。
3. Mocha スタイルの記述を採用すると、テスト ケースを明確に整理し、Chai アサーションを使用して期待される結果をアサートできます。
4. 早期引き出しの試みや不正アクセスなどのエッジケースをシミュレートして、セキュリティ上の制約を検証します。
5. 外部展開を検討する前に、 npx ハードハット テストを使用して完全なテスト スイートを実行し、信頼性を確認します。
よくある質問
Solidity コードを快適に作成するにはどのようなツールを使用できますか?一般的なオプションには、Solidity 拡張機能を備えた Visual Studio Code、ブラウザーベースの編集用の Remix IDE、統合テストおよび展開ワークフロー用の Hardhat などがあります。
Solidity で整数オーバーフローを処理するにはどうすればよいですか? Solidity 0.8.0 以降では、算術演算でオーバーフローとアンダーフローが自動的にチェックされ、検出された場合はトランザクションが元に戻されます。古いバージョンを使用しない限り、SafeMath などの外部ライブラリに依存する必要はありません。
導入後にスマート コントラクトを変更できますか?いいえ、デプロイされたコントラクトは不変です。変更を行う場合は、新しいインスタンスを再デプロイする必要があります。開発者は多くの場合、データの継続性を維持しながらアップグレード可能性をシミュレートするためにプロキシ パターンを使用します。
Solidity プロジェクトにおける ABI の目的は何ですか?アプリケーション バイナリ インターフェイス (ABI) は、コントラクトと対話する方法を定義し、関数、パラメーター、戻り値の型をリストします。フロントエンドと外部ツールがコントラクト メソッドを正しく呼び出すことが重要です。
免責事項:info@kdj.com
提供される情報は取引に関するアドバイスではありません。 kdj.com は、この記事で提供される情報に基づいて行われた投資に対して一切の責任を負いません。暗号通貨は変動性が高いため、十分な調査を行った上で慎重に投資することを強くお勧めします。
このウェブサイトで使用されているコンテンツが著作権を侵害していると思われる場合は、直ちに当社 (info@kdj.com) までご連絡ください。速やかに削除させていただきます。
- DESK トークン、トークン化された不動産、ベンチャー ハブ: デジタル資産の新時代
- 2025-11-12 16:55:02
- JPMコイン、ブロックチェーン、パブリックトークン: 機関金融の未来?
- 2025-11-12 17:10:00
- イーサリアムのホエールウォッチ:アップグレードが登場!
- 2025-11-12 17:10:00
- DOGE: 価格と可能性を分析 – Dogecoin は 1 ドルに達するでしょうか?
- 2025-11-12 17:10:02
- JPMD、USDトークン、およびベースネットワーク: JPモルガンのブロックチェーンの飛躍
- 2025-11-12 17:10:02
- 財務プレイの進化: ブロックチェーン エンジニアリングで MSTR を超えて
- 2025-11-12 17:20:01
関連知識
スマート コントラクトにおけるサービス拒否 (DoS) 攻撃とは何ですか?また、その一般的な形式は何ですか?
2025-11-10 05:20:08
スマートコントラクトにおけるサービス拒否について理解する1. スマート コントラクトのコンテキストにおけるサービス拒否 (DoS) 攻撃とは、悪意のある攻撃者が正当なユーザーによるコントラクトの機能へのアクセスまたは使用を妨げるシナリオを指します。これは通常、攻撃者が重要な操作をブロックできるように...
トランザクション署名で使用される暗号化ナンスとは何ですか?
2025-11-11 05:59:39
ブロックチェーントランザクションにおける暗号化ナンスを理解する1. 暗号化ナンスは、ブロックチェーン ネットワーク内のトランザクション署名のコンテキストで 1 回だけ使用される乱数または擬似乱数です。その主な機能は、各トランザクションが一意であり、悪意のある行為者によって再実行できないことを保証する...
Solidity スマート コントラクトでは継承はどのように機能しますか?
2025-11-11 22:40:12
Solidity の継承: モジュール式スマート コントラクトの構築1. Solidity の継承により、あるコントラクトが別のコントラクトのプロパティと機能を採用できるようになり、コードの再利用と構造化設計が可能になります。派生コントラクトは、プライベートとしてマークされていない限り、基本コントラ...
Minimal Proxy Contract (EIP-1167) とは何ですか? また、導入時のガスをどのように節約しますか?
2025-11-12 11:39:42
最小プロキシ契約 (EIP-1167) とは何ですか? 1. イーサリアム改善提案 (EIP) 1167 に基づいて標準化されたミニマル プロキシ コントラクトは、呼び出しを既存の実装コントラクトに委任するように設計された軽量のコントラクトです。これは、ロジックを内部に保存せずに、すべての関数呼び出...
Solidity のライブラリとは何ですか? 基本コントラクトとの違いは何ですか?
2025-11-12 09:19:55
Solidity のライブラリを理解する1. Solidity のライブラリは、継承せずに複数のコントラクト間で共有できる再利用可能な関数を保持するように設計された特殊なタイプのコントラクトです。これらの関数はステートレスです。つまり、別のコントラクトのストレージと明示的にやり取りしない限り、独自に...
Ether を別のコントラクトに安全に送信するにはどうすればよいですか?
2025-11-09 18:40:05
スマート コントラクトへの Ether の送信: 重要な考慮事項1. 受信契約に、イーサを受け入れることができる支払い可能フォールバック機能または指定された支払い可能機能があることを確認します。これがないと、送金が元に戻り、資金が永久にロックされる可能性があります。 2. address(contr...
スマート コントラクトにおけるサービス拒否 (DoS) 攻撃とは何ですか?また、その一般的な形式は何ですか?
2025-11-10 05:20:08
スマートコントラクトにおけるサービス拒否について理解する1. スマート コントラクトのコンテキストにおけるサービス拒否 (DoS) 攻撃とは、悪意のある攻撃者が正当なユーザーによるコントラクトの機能へのアクセスまたは使用を妨げるシナリオを指します。これは通常、攻撃者が重要な操作をブロックできるように...
トランザクション署名で使用される暗号化ナンスとは何ですか?
2025-11-11 05:59:39
ブロックチェーントランザクションにおける暗号化ナンスを理解する1. 暗号化ナンスは、ブロックチェーン ネットワーク内のトランザクション署名のコンテキストで 1 回だけ使用される乱数または擬似乱数です。その主な機能は、各トランザクションが一意であり、悪意のある行為者によって再実行できないことを保証する...
Solidity スマート コントラクトでは継承はどのように機能しますか?
2025-11-11 22:40:12
Solidity の継承: モジュール式スマート コントラクトの構築1. Solidity の継承により、あるコントラクトが別のコントラクトのプロパティと機能を採用できるようになり、コードの再利用と構造化設計が可能になります。派生コントラクトは、プライベートとしてマークされていない限り、基本コントラ...
Minimal Proxy Contract (EIP-1167) とは何ですか? また、導入時のガスをどのように節約しますか?
2025-11-12 11:39:42
最小プロキシ契約 (EIP-1167) とは何ですか? 1. イーサリアム改善提案 (EIP) 1167 に基づいて標準化されたミニマル プロキシ コントラクトは、呼び出しを既存の実装コントラクトに委任するように設計された軽量のコントラクトです。これは、ロジックを内部に保存せずに、すべての関数呼び出...
Solidity のライブラリとは何ですか? 基本コントラクトとの違いは何ですか?
2025-11-12 09:19:55
Solidity のライブラリを理解する1. Solidity のライブラリは、継承せずに複数のコントラクト間で共有できる再利用可能な関数を保持するように設計された特殊なタイプのコントラクトです。これらの関数はステートレスです。つまり、別のコントラクトのストレージと明示的にやり取りしない限り、独自に...
Ether を別のコントラクトに安全に送信するにはどうすればよいですか?
2025-11-09 18:40:05
スマート コントラクトへの Ether の送信: 重要な考慮事項1. 受信契約に、イーサを受け入れることができる支払い可能フォールバック機能または指定された支払い可能機能があることを確認します。これがないと、送金が元に戻り、資金が永久にロックされる可能性があります。 2. address(contr...
すべての記事を見る














