-
Bitcoin
$113500
-1.11% -
Ethereum
$3484
-3.49% -
XRP
$2.939
-0.37% -
Tether USDt
$0.9997
-0.01% -
BNB
$752.7
-2.25% -
Solana
$162.6
-3.38% -
USDC
$0.9998
-0.02% -
TRON
$0.3260
0.00% -
Dogecoin
$0.1979
-3.72% -
Cardano
$0.7090
-1.76% -
Hyperliquid
$38.21
-3.64% -
Sui
$3.402
-2.25% -
Stellar
$0.3793
-2.94% -
Chainlink
$15.90
-3.52% -
Bitcoin Cash
$533.2
-3.78% -
Hedera
$0.2361
-2.74% -
Avalanche
$21.32
-2.92% -
Ethena USDe
$1.000
-0.01% -
Toncoin
$3.585
3.24% -
UNUS SED LEO
$8.961
0.17% -
Litecoin
$106.3
1.48% -
Shiba Inu
$0.00001202
-0.69% -
Polkadot
$3.529
-2.64% -
Uniswap
$8.985
-1.29% -
Monero
$296.1
-2.63% -
Dai
$0.9999
-0.01% -
Bitget Token
$4.283
-1.79% -
Pepe
$0.00001032
-1.61% -
Cronos
$0.1307
-2.92% -
Aave
$252.6
-1.33%
Ethereumスマートコントラクトを書く方法は? Ethereumスマートコントラクトの例
Ethereumスマートコントラクトは、条件が満たされたときに条件を自動的に実施するコードで書かれた自己執行契約です。
2025/06/15 23:56

Ethereum Smart Contractsの理解
Ethereumスマート契約は、コードのラインに直接書かれた契約の条件との自己執行契約です。これらの契約は、Ethereum Virtual Machine(EVM)で実行され、所定の条件が満たされたときに自動的に実行されます。スマートコントラクトを作成するには、ソリティなどの特定のプログラミング言語を使用することが含まれます。これは、イーサリアム開発に最も一般的に使用される言語です。
スマートコントラクトは展開すると不変です。つまり、ブロックチェーンに公開された後に変更することはできません。この特性により、展開前にコードが徹底的にテストされるようにすることが重要になります。また、開発者は、スマートコントラクトを書く際に、ガスコスト、機能の可視性、セキュリティベストプラクティスを考慮する必要があります。
開発環境を設定します
Ethereumスマートコントラクトを書く前に、適切な開発環境を設定する必要があります。方法は次のとおりです。
- まだインストールされていない場合は、 node.jsとnpmをインストールします。
- NPMを使用して、人気のあるイーサリアム開発フレームワークであるトリュフをインストールします。
npm install -g truffle
- Ethereum開発のための個人的なブロックチェーンであるGanacheをインストールして、トランザクションをシミュレートし、契約をローカルでテストします。
- ブラウザ拡張ウォレットであるメタマスクをセットアップして、テストネットまたはメインネットで展開した契約と対話します。
- Visual Studioコードなどのコードエディターを選択し、構文の強調表示とエラー検出用のSolidity拡張機能をインストールします。
これらのツールが整ったら、スマートコントラクトの書き込みとテストを開始できます。
最初のスマートコントラクトを堅実さで書く
番号を保存および取得する簡単なストレージ契約を作成しましょう。以下は、堅実さで書かれた基本的な例です。
pragma solidity ^0.8.0;
契約simplestorage {uint storedData; function set(uint x) public { storedData = x; } function get() public view returns (uint) { return storedData; }
}
この例では:
-
pragma solidity ^0.8.0;
行は、使用される堅牢性のバージョンを指定します。 - 状態変数の
storedData
、署名されていない整数を保持すると宣言されています。 -
set()
関数を使用すると、誰でもstoredData
の値を更新できます。 -
get()
関数は、契約状態を変更せずに現在の値を返すビュー関数です。
各関数と変数は、パブリック、プライベート、または内部などの適切な可視性修飾子で明確に定義する必要があります。
スマートコントラクトのコンパイルと展開
トリュフとガナッシュを使用して上記の契約をコンパイルして展開するには、次の手順に従ってください。
新しいトリュフプロジェクトを作成します:
truffle init
Solidityファイルを
contracts
ディレクトリ内に配置します。migrations
フォルダーで、次のコンテンツで移行スクリプト(2_deploy_contracts.js
)を作成します。const SimpleStorage = artifacts.require('SimpleStorage');
module.exports = function(deplayer){
deployer.deploy(simplestorage);
};契約を編集します:
truffle compile
Ganacheを起動し、
truffle-config.js
でネットワーク設定を構成します。契約をローカルブロックチェーンに展開します。
truffle migrate
展開後、 Truffle Consoleを使用して、またはFrontendアプリケーションでWeb3.jsまたはEthers.jsライブラリを使用して契約と対話できます。
スマートコントラクトのテスト
テストにより、さまざまなシナリオで契約が予想どおりに動作するようになります。 Truffleは、JavaScriptまたはSolidity自体を使用した単体テストの組み込みサポートを提供します。
これは、 test
ディレクトリにあるJavaScriptベースのテストの例です。
const SimpleStorage = artifacts.require('SimpleStorage');
契約( 'Simplestorage'、Accounts => {
それ( '値42'を保存する必要があります、async()=> {const instance = await SimpleStorage.deployed(); await instance.set(42, { from: accounts[0] }); const result = await instance.get.call(); assert.equal(result, 42);
});
});
このテスト:
- 契約インスタンスを展開します。
- 値42で
set()
関数を呼び出します。 - 使用して、保存された値が予想される出力と一致することを確認するために
assert
。
特に複雑なロジック、アクセス制御、または財務業務を扱う場合は、常にエッジケースのテストを作成します。
よくある質問
Q:イーサリアムスマートコントラクト開発のためにトリュフ以外にどのようなツールが必要ですか?
契約を編集、展開、テストするために、トリュフの代替としてHardhatを使用できます。さらに、 Remix IDEは、ローカル環境をセットアップせずに小さな契約をすばやく書き、テストしたい初心者に最適なブラウザベースのツールです。
Q:展開されたEthereumスマートコントラクトを変更できますか?
いいえ、イーサリアムスマートコントラクトは展開すると不変です。変更が必要な場合は、開発者は契約の新しいバージョンを展開し、必要に応じてデータを移行する必要があります。ただし、プロキシ契約のようなパターンを使用して、アップグレード可能な動作を実現できます。
Q:イーサリアムにスマートコントラクトを展開するのにどれくらいの費用がかかりますか?
コストは、契約の複雑さとネットワーク上の現在のガス価格に依存します。 Remix IDEなどのツールを使用して、または展開中にメタマスクのトランザクションの詳細を確認することにより、ガスコストを見積もることができます。より複雑な契約はより多くのガスを消費するため、より多くの費用がかかります。
Q:生産用に私自身のスマートコントラクトを書いても安全ですか?
スマートコントラクトを書くことを学ぶことは貴重ですが、それらを生産に展開するには、徹底的なセキュリティ監査と広範なテストが必要です。ベストプラクティスに従い、 Openzeppelinなどの定評のあるライブラリを使用し、実際の資金を処理する契約を開始する前に経験豊富な監査人に相談することをお勧めします。
免責事項:info@kdj.com
提供される情報は取引に関するアドバイスではありません。 kdj.com は、この記事で提供される情報に基づいて行われた投資に対して一切の責任を負いません。暗号通貨は変動性が高いため、十分な調査を行った上で慎重に投資することを強くお勧めします。
このウェブサイトで使用されているコンテンツが著作権を侵害していると思われる場合は、直ちに当社 (info@kdj.com) までご連絡ください。速やかに削除させていただきます。
- Defi Token Summer Gains:Mutuum Financeは本当の取引ですか?
- 2025-08-02 18:30:12
- ビットコイン、実現価格、そしてトップ:私たちはまだそこにいますか?
- 2025-08-02 18:30:12
- フィッシング、財布、盗まれた資金:暗号の野生の西に安全にとどまる
- 2025-08-02 16:30:12
- レアコインアラート:ポケットの50pは£10,000の価値がありますか?
- 2025-08-02 16:30:12
- Arbitrum(ARB)価格予測:過剰な信号またはブレイクアウトが差し迫っていますか?
- 2025-08-02 16:55:36
- Arbitrum(ARB):価格ディップ、ペイパルの特典、および先の道路のナビゲート
- 2025-08-02 17:00:12
関連知識

オンチェーントランザクションとオフチェーントランザクションの違いは何ですか?
2025-08-02 16:22:04
オンチェーントランザクションの理解オンチェーントランザクションは、ブロックチェーン台帳に直接記録されるデジタル資産転送を指します。これらのトランザクションは永久に保存され、公開されているため、ネットワーク内のすべてのノードがトランザクションデータのコピーを検証および維持することを意味します。ユーザー...

二重の支出の問題は何ですか、そしてブロックチェーンはそれをどのように防ぐのですか?
2025-08-02 13:07:57
二重の支出の問題を理解する二重の支出の問題は、同じデジタルトークンを複数回費やすことができるデジタル通貨システムの基本的な課題です。同時に2人の異なる人に渡すことができない物理的な現金とは異なり、デジタルファイルをコピーして再利用できます。これにより、悪意のあるアクターがデジタルコインを複製して複数...

ブロックチェーンとデータベースの違いは何ですか?
2025-08-01 21:36:31
ブロックチェーンのコア構造を理解するブロックチェーンは、暗号化されたハッシュを使用してリンクされた一連の不変のブロックにデータを記録する分散型デジタル元帳です。各ブロックには、トランザクションまたはレコードのリスト、タイムスタンプ、およびハッシュを介した前のブロックへの参照が含まれています。この構造...

ブロックチェーンはスケーラビリティをどのように処理しますか?
2025-08-02 14:58:45
ブロックチェーンのスケーラビリティの課題を理解するブロックチェーンのスケーラビリティとは、速度、コスト、またはセキュリティを損なうことなく、増加する量のトランザクションを処理するネットワークの能力を指します。より多くのユーザーがブロックチェーンネットワークに参加すると、トランザクションの数が増加し、...

ブロックチェーンのハッシュとは何ですか?
2025-08-02 05:28:45
ブロックチェーンでのハッシュの概念を理解するブロックチェーンテクノロジーのコンテキストでのハッシュとは、暗号化ハッシュ関数によって生成される独自のデジタル指紋を指します。この指紋は、あらゆるサイズの入力データから派生していますが、常に固定長の出力を生成します。 Bitcoinのようなブロックチェーン...

ブロックチェーンのハッシュとは何ですか?
2025-08-02 04:43:10
ブロックチェーンでのハッシュの概念を理解するブロックチェーンテクノロジーのコンテキストでのハッシュとは、あらゆるサイズの入力データから暗号化ハッシュ関数によって生成される一意のデジタル指紋を指します。この出力は、元のデータのサイズに関係なく、常に固定長の文字列の文字列です。 Bitcoinのようなブ...

オンチェーントランザクションとオフチェーントランザクションの違いは何ですか?
2025-08-02 16:22:04
オンチェーントランザクションの理解オンチェーントランザクションは、ブロックチェーン台帳に直接記録されるデジタル資産転送を指します。これらのトランザクションは永久に保存され、公開されているため、ネットワーク内のすべてのノードがトランザクションデータのコピーを検証および維持することを意味します。ユーザー...

二重の支出の問題は何ですか、そしてブロックチェーンはそれをどのように防ぐのですか?
2025-08-02 13:07:57
二重の支出の問題を理解する二重の支出の問題は、同じデジタルトークンを複数回費やすことができるデジタル通貨システムの基本的な課題です。同時に2人の異なる人に渡すことができない物理的な現金とは異なり、デジタルファイルをコピーして再利用できます。これにより、悪意のあるアクターがデジタルコインを複製して複数...

ブロックチェーンとデータベースの違いは何ですか?
2025-08-01 21:36:31
ブロックチェーンのコア構造を理解するブロックチェーンは、暗号化されたハッシュを使用してリンクされた一連の不変のブロックにデータを記録する分散型デジタル元帳です。各ブロックには、トランザクションまたはレコードのリスト、タイムスタンプ、およびハッシュを介した前のブロックへの参照が含まれています。この構造...

ブロックチェーンはスケーラビリティをどのように処理しますか?
2025-08-02 14:58:45
ブロックチェーンのスケーラビリティの課題を理解するブロックチェーンのスケーラビリティとは、速度、コスト、またはセキュリティを損なうことなく、増加する量のトランザクションを処理するネットワークの能力を指します。より多くのユーザーがブロックチェーンネットワークに参加すると、トランザクションの数が増加し、...

ブロックチェーンのハッシュとは何ですか?
2025-08-02 05:28:45
ブロックチェーンでのハッシュの概念を理解するブロックチェーンテクノロジーのコンテキストでのハッシュとは、暗号化ハッシュ関数によって生成される独自のデジタル指紋を指します。この指紋は、あらゆるサイズの入力データから派生していますが、常に固定長の出力を生成します。 Bitcoinのようなブロックチェーン...

ブロックチェーンのハッシュとは何ですか?
2025-08-02 04:43:10
ブロックチェーンでのハッシュの概念を理解するブロックチェーンテクノロジーのコンテキストでのハッシュとは、あらゆるサイズの入力データから暗号化ハッシュ関数によって生成される一意のデジタル指紋を指します。この出力は、元のデータのサイズに関係なく、常に固定長の文字列の文字列です。 Bitcoinのようなブ...
すべての記事を見る
