ブロックチェーン開発(パート3)最初のイーサリアムスマートコントラクトの作成とデバッグ

ブロックチェーン開発(パート3)最初のイーサリアムスマートコントラクトの作成とデバッグ

1. スマートコントラクトIDEの紹介

現在、Ethereum はスマート コントラクトを記述するための 3 つの言語をサポートしています。

Solidity: JavaScript と同様に、これは Ethereum の公式推奨言語であり、最も人気のあるスマート コントラクト言語です。具体的な使用方法については、Solidity のドキュメント (https://solidity.readthedocs.io/en/latest/) を参照してください。

Serpent: Python スタイルに似ています。ドキュメント アドレス: https://github.com/ethereum/wiki/wiki/Serpent

LLL: Lisp のようなスタイルですが、現在は廃止されています。

さまざまな習慣に応じて、さまざまな高級言語を選択できます。最も人気があるのは Solidity です。この記事のすべてのスマート コントラクトは Solidity 言語で記述されています。

スマート コントラクトを記述できる一般的な IDE がいくつかあります。

Mix: 初期の頃は Ethereum の主な開発 IDE でした。完全なグラフィカル インターフェイスを使用して、スマート コントラクトと DAPP の作成、デバッグ、および展開をサポートします。しかし、最初の司会者ギャビン・ウッドが去ったことで、番組は徐々に衰退し、最終的には発展が止まってしまいました。チーム全体がリミックス プロジェクトに取り組みました。将来的なことを考慮すると、Mix を学習することはお勧めしません。

リミックス:オリジナルMixチームによる新作です。現在、シンプルなデバッグ機能のみがオンラインになっています。今後は特に注意していただければと思います。

browser-solidity: このプロジェクトは、スマート コントラクトのブラウザー バージョンの開発環境です。ブラウザでの直接的な開発、デバッグ、コンパイルをサポートできます。初心者にとってはインストールなしですぐに始められるのでとても便利です。次のアドレスに直接アクセスできます: https://ethereum.github.io/browser-solidity/。この記事では開発にこの IDE を使用します。

Ethereum Studio: サードパーティ企業によって開発されたスマート コントラクト オンライン IDE のエンタープライズ バージョン。強力で無料で使用できます。エンタープライズレベルの開発ツールとして使用できます。次のアドレスにアクセスしてください: https://live.ether.camp/

Visual Studio 2015: はい、Microsoft の VS 2015 です。Microsoft は Ethereum のスマート コントラクト書き込み機能を統合しており、Microsoft が Ethereum を重視していることがわかります。

2. 最初のスマートコントラクトを書く

1. スマートコントラクトの構文を学ぶ方法

スマート コントラクトの構文と例は、Solidity のドキュメント Web サイト http://solidity.readthedocs.io/en/latest/ で参照できます。基本的に、これらのオンライン ドキュメントを読んだ後は、それらを習得したことになります。残りは、コードの作成を練習するだけです。

2. サンプル契約コード

まず、サンプル コードを示し、次にこのコードを例にして、スマート コントラクトの作成とデバッグについて説明します。

————————————————————————————————————-

契約投票

構造体候補{

uint 投票数;

文字列名;

}

投票者構造体{

bool が投票しました。

}

マッピング(アドレス => Voter) 一般有権者;

候補者[] 公選候補者

関数Voter() {

候補者.push(候補者({

名前: "lihe",

投票数: 0

}));

候補者.push(候補者({

名前:「だんだん」

投票数: 0

}));

}

関数 Vote_candidate(uint8 numCandidate)

{

投票者[msg.sender].voted || numCandidate>candidates.length)の場合、戻り値:

候補者[候補者数].投票数+=1;

投票者[msg.sender].voted=true;

}

関数 Getcount() は(文字列、uint、文字列、uint) を返します{

戻り値: (候補者[0].名前、候補者[0].投票数、候補者[1].名前、候補者[1].投票数);

}

}

————————————————————————————————————–

このコードは、lihe と dandan という 2 人の候補者に投票する投票プログラムを作成します。投票できるのは一人につき一度だけであり、最終的にliheとdandanの投票結果がフィードバックされます。機能は次のように説明されます。

function Votelihe(): コンストラクタ、スマートコントラクトは1回だけ実行されます

関数 Vote_candidate(): 候補者に投票します。各有権者は 1 票しか投じることができません。

関数 Getcount(): 現在の候補者の投票数を返します

3. IDEを使用してスマートコントラクトを作成する

まず、browser-solidity を開きます。 IDE の主な機能は次のとおりです。

サンプル コードを左側のコード編集ボックスにコピーすると、IDE は自動的に構文エラーを検出し、次に示すように右側のウィンドウに表示します。

ご覧のとおり、宣言されていないオブジェクトがあり、これは 14 行目のエラーです。明らかに、構造体オブジェクト candidates を candidates2 として誤って記述しました。修正することで検証に合格できます。

ブラウザでコードを記述すると、自動的にローカルブラウザキャッシュに保存されることに注意してください。ブラウザのキャッシュをクリアすれば、コードは失われません。

3. 最初のスマートコントラクトのデバッグ

現在、browser-solidity では 2 つの一般的なデバッグ方法が使用されています。 1 つはローカル仮想マシンのデバッグ モードを使用する方法であり、もう 1 つはデバッグのためにローカル プライベート チェーンに接続する方法です。

1. ローカル仮想マシンデバッグモード

ローカル仮想マシンのデバッグとは、どのノードにも接続せず、デバッグ用にメモリ内に仮想 Ethereum ノードを作成することを意味します。利点は、速度が速く、構成が簡単なことです。欠点は、仮想デバッグのみであるため、実際のブロックチェーンノードでスマートコントラクトを実行した結果が期待した結果と異なる可能性があることです。

まず、DEBUG 環境設定で、JavaScript VM を選択して、以下に示すようにローカル仮想デバッグ モードを設定します。

設定が成功すると、以下のようにアカウントステータスバーに利用可能なアカウントのリストが表示されます。

スマート コントラクト コードを記述したら、「作成」ボタンをクリックしてスマート コントラクトをメモリにデプロイし、デバッグします。デプロイが成功すると、スマート コントラクト機能の実行ボタンとパラメーター入力ボックスが表示され、以下に示すようにスマート コントラクトをデバッグできます。

関数を実行すると、対応するトランザクション データが表示され、スマート コントラクトのデバッグ全体が完了します。

スマート コントラクトを段階的にデバッグする場合は、バグ アイコンを選択し、段階的なデバッグ インターフェイスに切り替えて、スマート コントラクトを段階的に実行します。ここで実行されるシングルステップは、コードではなく、下の図に示すように、スマート コントラクトからコンパイルされた OPCODE を参照することに注意してください。

2. デバッグのためにローカルプライベートチェーンに接続する

デバッグのためにローカル プライベート チェーンに接続するということは、RPC インターフェイスを介してローカル Ethereum ノードに接続し、実際にスマート コントラクトをデプロイしてデバッグすることを意味します。欠点は、速度が遅く、構成が複雑なことです。利点は、実際にスマート コントラクトを実行し、エラーを最大限に防ぐことができることです。プライベートチェーンの構成については、私のオリジナル記事「ブロックチェーン開発(I)Ethereumをベースとしたプライベートチェーン環境の構築」を参照してください。

まず、DEBUG 環境設定で、Web3 プロバイダーを選択して、ローカル仮想デバッグ モードを設定します。デフォルトでは、接続アドレス http://localhost:8545 が指定されます。設定したプライベート チェーン RPC ポートが変更された場合は、次に示すように、対応するポートに変更することを忘れないでください。

次に、アカウント ステータス バーに切り替えます。この時点で表示される利用可能なアカウントはすべて、デプロイしたプライベート チェーン内のアカウントである必要があります。そうでない場合は、プライベート チェーンが正常に接続されていないことを意味します。考えられる理由は2つあります。 1 つは、プライベート チェーンによって提供されるポートは http 経由でアクセスされるのに対し、browser-solidity の Web アクセス アドレスは https であることです。解決策は、browser-solidity アクセス アドレスを http プロトコル アドレス http://ethereum.github.io/browser-solidity/ に変更することです。もう 1 つは、システム時刻がネットワークと同期されていないことです。 Windows システムに組み込まれている時刻同期機能を使用して同期することができます。

4. その他の一般的なスマートコントラクトリソース

次のサンプル Web サイトでは、迅速な反復学習を容易にするために、いくつかの成熟したコードを参照しています。一般的なウェブサイトの例は次のとおりです。

https://github.com/ethereum/wiki/wiki/Solidity-Collections

http://ether.fund/contracts/

https://github.com/chriseth/solidity-examples

出典: ethereum

https://github.com/fivedogit/solidity-baby-steps

出典: http://dapps.ethercasts.com

http://ether.fund/contracts

一般的に使用される開発フレームワークは次の 3 つです。

Truffle: 取扱説明書 http://truffle.readthedocs.io/en/latest/

Ethereum の人気の開発フレームワークである Truffle のマニュアル。このフレームワークは非常に人気があります。

Dapple: 取扱説明書 http://dapple.readthedocs.io/en/master/

この開発フレームワークはGitterチャートで見ました。あまり使う人はいないと思います。まずは観察してみましょう。

Meteor: 手順のアドレス: https://github.com/ethereum/wiki/wiki/Dapp-using-Meteor

この開発フレームワークは Ethereum によって公式に推奨されており、Ethereum の公式 wiki に含まれています。学ぶ価値はあります。もちろん、公式のイーサリアムは方向性を変えることが多いので、将来的に何か別のものに変わる可能性もあります。


<<:  iOS 10 に Circle Pay 機能が追加されました。Apple はビットコインへの道を切り開いているのでしょうか?

>>:  コインゾーントレンド: 今週のビッグデータに基づくビットコインの価格動向 (2016-09-13)

推薦する

マイクロソフトのIONデジタルIDネットワークがビットコインメインネットで稼働開始

中国ブロックチェーンニュース (ID: ChinaBlockchainNews)翻訳 |ピン兄弟編集...

Zaineng - 分散型マイニングの最高の実践者

ビットコインが将来的に国際通貨になるトレンドであれば、Zaineng は将来のビットコインマイニング...

Coinbaseは激しい競争に直面し、Robinhoodは手数料無料の暗号通貨取引サービスを追加する予定

手数料無料の株式取引アプリ「ロビンフッド」は、2月にビットコインとイーサリアムの取引を開始すると発表...

図解ブロックチェーン第5号 – あなたは何人の人の顔を覚えていますか?

図解ブロックチェーンは第5号になりました。今回は、「何人の人の顔を覚えていますか?」というテーマにつ...

[上級ミニ教室] Filecoin に投資したトップ機関はどれですか?

2017年8月、Filecoinは2億5,700万米ドルの資金調達を完了し、当時の初期のブロックチ...

ビットメインの機密データが流出:半年で60万台の新型マイニングマシンを生産、評価額は120億ドルに達する

数日前、TSMCに近いサプライチェーン関係者がブロックチェーンウェブサイトに、Bitmainが最近、...

[Filecoinウィークリーレポート-74] Filecoin Plusのルール詳細が発表され、コンピューティングパワーの10倍の重み付け

この記事は元々IPFS Force Zoneによって書かれましたプロジェクト紹介 [プロジェクト紹介...

江門市開平市の男性が仮想通貨投機で20万4000元をだまし取られた

記者は10月19日、江門市開平警察署から、最近開平市の住民がオンラインの仮想通貨投機で巨額の金をだま...

メディア:暗号ハッキング攻撃は深刻な脅威となっている

nulltx によると、暗号化されたハッキン​​グ攻撃はますます深刻な脅威になっており、毎月 10 ...

Bitwise: 2024年第2四半期の13F提出書類は、機関投資家がビットコインの購入を継続していることを示唆している

現在、暗号通貨業界における最大の疑問は、機関投資家やプロの投資家が暗号通貨を大規模に割り当てるかどう...

EUIPO: ビットコインは著作権侵害対策に対する2つの大きな脅威の1つ

欧州連合知的財産庁(EUIPO)は最近、ビットコインとTorは「犯罪収益の隠蔽」に利用される可能性が...

Visa、ナスダックなどの大手企業がブロックチェーン企業Chainに3000万ドルを投資

ウォール街は、かつては単なる流行に過ぎないと見られていた技術に、さらに多くの資金を注ぎ込んでいる。金...

ビットコインのマイニングは本当に電気の無駄なのでしょうか?

ビットコインは分散型のピアツーピアシステムです。ネットワークには「中央」サーバーや制御ポイントは存在...

CoinfirmとBillonが提携し、ブロックチェーンとデジタル通貨取引ソリューションを提供

クレイジーな解説:ブロックチェーンのスタートアップ企業 Coinfirm.io とフィンテック企業の...

開発動向と要因は、ビットコインが金の急騰の歴史を繰り返し、13,000ドルを突破すると予想されることを示している。

ウェブボット[1]の作成者であるクリフ・ハイ氏は以前、来年の今頃にはビットコインの価格が3オンスの金...