怎麼基於以太坊開發代幣
『壹』 區塊鏈 --- FT、NFT、ERC-20協議和ERC-721協議
FT即同質化代幣,同質化的加密貨幣構成了目前市場上大部分的代幣。
FT以這樣的方式配置的數字資產——即每個代幣(或代幣的碎片)與下一個代幣等同。
可替代性是法定貨幣中的一個特徵。例如,一張20美元的鈔票可以兌換成任何其他20美元的鈔票,甚至可以兌換成零頭。即使不是絕對的20美元鈔票,它也可以是5美元鈔票的倍數,甚至更少,總之總量等於20美元。
NFT即非同質化代幣,非同質化代幣通常是指開發者在以太坊平台上根據 ERC-721 標准/協議所發行的代幣。用來描述一種獨特的數字資產,它的所有權是在區塊鏈上可以進行溯源的。
NFT 是唯一的、不可拆分的 token,所有的藝術品,不管是圖書文字、音樂或是影像…等各種形式,甚至是數字化的收藏品與線上游戲都可以通過 NFT 的特殊認證方式來驗證其獨特與稀有價值。
因此NFT 與傳統經濟體系中的收藏品相比具有不同的特徵:
官方說明文檔地址: https://github.com/ethereum/EIPs/blob/master/EIPS/eip-20.md
ERC20標准以太坊上的一個代幣協議,所有基於以太坊開發的代幣合約都遵守這個協議。
賬戶A有1000個ETH,想允許B賬戶隨意調用100個ETH。
官方說明文檔: https://github.com/ethereum/EIPs/blob/master/EIPS/eip-721.md
ERC-721兼容了ERC-20的一些特性,與ERC-20的主要區別是定義了token的owner, 即每個token都詳細記錄它歷史的擁有者,以及定義了token的Metadata, 即元數據。ERC-721還需要實現ERC165中的介面。
Metadata用於定義單個代幣的唯一特徵,為一個特定的代幣ID提供描述性信息 。以加密貓為例,每隻加密貓都有不同的顏色、形狀、名稱等。
• tokenId :在合約內唯一的 NFT ID,在NFT的生命周期中不可改變(要實現全鏈唯一的必須用(contractAddr, tokenId)組成的元組)
• name :名稱,類似於ERC-20的名稱
• symbol :符號,類似於ERC-20的符號
• uri :指向外部信息的鏈接,一般是一個JSON,而在JSON中有進一步更加具體的信息
如有不對,煩請指出,感謝~
『貳』 Metamask手機端:手把手教你注冊以太坊錢包
第一步:前面幾個安全提示,向下滾動到最底部表示全部閱讀,一步一步點擊「接受」就行了
2.下面是創建一個8位數的密碼,每次打開MetaMask可能都需要,如果忘記了密碼,可以用助記詞找回錢包
3.接下來是顯示的助記詞,可以直接點擊「我已妥善保存」,最好還是保存一下,以備不時之需。這里也可以不保存,之後在設置裡面,顯示助記詞,也能找到。
4.之後就進去了MetaMask錢包主頁面
5.點擊右上角小圓圈,點擊創建賬戶,可以創建更多的賬戶地址(所有創建的地址都可以通過剛剛的12個助記詞導入,比如你創建了10個地址,下次導入的時候初始顯示1個地址,你在點擊9次創建賬戶,之前的10個地址賬戶就完全不變的找回來了)
6.如果你在官方錢包,imtoken錢包,myetherwallet錢包已有賬戶可以導入,方法和創建錢包差不多
7.點擊「發送」,輸入你想轉賬的以太地址和數量,就可以轉賬了。(交易數據可以不填)
8.交易費限制,和氣體價格可以設置一下(如果不在乎交易時間,氣體價格可以設置低一些,如果想快速交易,氣體價格設高一些,如果是發送代幣或者部署合約,交易費限制建議填高一些以免交易氣體gas不足),之後點擊提交,就成功轉賬了。
9.成功發送交易後,會顯示交易概況。
10.點擊賬戶旁邊的三個小點,點擊「通過Etherscan查看賬戶"可以查看區塊鏈瀏覽器的詳情。
11、點擊三個點,點擊導出私鑰,可以導出該地址私鑰。
12、.點擊右上角三條杠,點擊設置,再點擊助記詞,可以查看你的助記詞,助記詞非常重要。
13.點擊添加代幣,可以添加其它基於以太坊的發幣,輸入縮寫即可。
14.如果沒有搜索到你需要的代幣,可以通過合約地址自動添加,輸入合約地址,代幣符號,小數位精度即可添加。
『叄』 以太坊智能合約是什麼
以太坊是一個分布式的計算平台。它會生成一個名為Ether的加密貨幣。程序員可以在以太坊區塊鏈上寫下「智能合約」,這些以太坊智能合約會根據代碼自動執行。
以太坊是什麼?
以太坊經常與比特幣相提並論,但情況卻有所不同。比特幣是一種加密貨幣和分布式支付網路,允許比特幣在用戶之間轉移。
相關:什麼是比特幣?它是如何工作的?
以太坊項目有更大的目標。正如Ethereum網站所說,「以太坊是一個運行智能合約的分布式平台」。這些智能合約運行在「以太坊虛擬機」上,這是一個由所有運行乙太網節點的設備組成的分布式計算網路。
「分布式平台」部分意味著任何人都可以建立並運行以太坊節點,就像任何人都可以運行比特幣節點一樣。任何想要在節點上運行「智能合約」的人都必須向Ether中的這些節點的運營商付款,這是一個與以太坊相關的加密貨幣。因此,運行乙太網節點的人提供計算能力,並在乙太網中獲得支付,這與運行比特幣節點的人提供哈希能力並以比特幣支付的方式類似。
換句話說,雖然比特幣僅僅是一個區塊鏈和支付網路,但以太坊是一個分布式計算網路,其區塊鏈可以用於許多其他事情。以太坊白皮書中提供了詳細信息。
以太是什麼?
乙太網是與以太坊區塊鏈相關的數字標記(或者說就是加密貨幣)。換句話說,以太是代幣,以太坊是平台。但是,現在人們經常交替使用這些術語。例如,Coinbase允許你購買以太坊代幣(Ethereum),即代表以太幣代幣。
這在技術上就是「altcoin」,這實際上意味著一個非比特幣加密貨幣。和比特幣一樣,Ether也受到分布式區塊鏈支持 - 在這種情況下是以太坊區塊鏈。
想要在以太坊區塊鏈上創建應用程序或以太坊 智能合約的開發人員需要乙太網代幣來支付節點來託管它,而基於以太坊的應用程序的用戶可能需要乙太網來支付這些應用程序中的服務費用。人們也可以在以太坊網路之外銷售服務,並接受乙太網支付,或者可以在交易所以現金形式出售以太幣代幣 - 就像比特幣一樣
『肆』 以太坊代幣標准簡介
絕大多數的區塊鏈創業團隊都在以太坊(Ethereum)上開發自己的項目,並使用以太坊網路發行自己的代幣(Token),代幣發行的標准需要遵從以太坊代幣標准(ERC-Token Standard),這篇文章就幫你梳理一下以太坊的各種代幣標准。
什麼是以太坊代幣標准(ERC-Token Standard)?
建立在以太坊網路上的區塊鏈項目代幣,需要遵從以下幾種代幣標准:ERC-20,ERC-223,ERC-621,ERC-721,ERC-827。其中 ERC 是 Ethereum Request for Comments 的簡稱,直譯過來是 以太坊注釋請求,本身這是一個包含結構化信息的網路指令。ERC-Standard 是由以太坊社區定義出來,用戶和以太坊網路進行交互的規則。但本身這個標准並不是一塵不變的,社區開發者可以提出自己定義的新標准,但是這個標准需要被整個以太坊社區接納才能應用在以太坊網路上。
『伍』 深入理解手裡的代幣——ZTH
ZTH是以太坊發行的代幣,以太坊是一個通用的虛擬貨幣平台,每個人都可以利用以太坊的工具開發出自己的虛擬貨幣體系或區塊鏈應用 。
以太坊2013年底由一個叫作 Vitalik Buterin 的90後小夥子提出來的技術。它強調自己是一個智能合約系統。它的本質和比特幣是一樣的,只不過可以在這個平台里自己生成任意多個不同的比特幣系統 。
2014年的7月至8月間,針對公眾銷售了以太坊系統上的貨幣——以太幣(Ether,簡稱ETH),共計銷售了1190萬枚以太幣(大約占以太幣總數的13%),當時1個以太幣不到3塊錢,如今這個價格是2100。以太幣,可以簡單理解成以太坊的股份 ,它把股份貨幣化 ,核心目的是通過發行自己的虛擬貨幣來融資 。以太坊是全球第一個用發行自己的虛擬貨幣的方式來融資的案例。這種方式現在被叫作首次貨幣發行(Initial Coin Offering,簡稱ICO),簡單說就是第一次對外發行自己的虛擬貨幣。
2015年7月30日,以太坊正式上線。為了讓以太坊生態能夠實現良性的發展,以太坊團隊專門成立了公益組織「以太坊基金會」,鼓勵別人尋找系統漏洞,這使得管理相比比特幣更加嚴密。以太坊通過成立聯盟,保證應用的開放和標准化,有很多大企業與大學參加,如微軟、英特爾、康奈爾大學等。另外,以太坊作為發行平台現在越來越熱,所以需要大量的以太幣。每個人都要買以太幣才能去買以太坊平台上發行的不同公司的虛擬貨幣,那麼,以太幣的需求就會隨著ICO熱度的劇增而迅速增加。
前哨王煜全判斷: 以太幣的價格有可能超過比特幣 。
『陸』 以太坊是如何挖礦的
以太坊的代幣是通過采礦過程中產生的,每塊采礦率為 5 個以太幣。以太坊的采礦過程幾乎與比特幣相同,對於每一筆交易,礦工都可以使用計算機通過散列函數運行該塊的唯一標題元數據,反復,快速地猜出答案,直到其中一人獲勝。
許多新用戶認為,采礦的唯一目的是以不需要中央發行人的方式生成醚(參見我們的指南「 什麼是以太? 」)。這是真的。以太坊的代幣是通過采礦過程中產生的,每塊采礦率為 5 個以太幣。但是,采礦還有至少同樣重要的作用。通常,銀行負責保持交易的准確記錄。他們確保資金不是憑空創造的,用戶不會多次欺騙和花錢。不過,區塊鏈引入了一種全新的記錄保存方式,整個網路而不是中介,驗證交易並將其添加到公共分類賬。
Ethereum Mining
盡管「無信任」或「信任最小化」貨幣體系是目標,但仍有人需要確保財務記錄的安全,確保沒有人作弊。采礦是使分散記錄成為可能的創新之一。礦工們在防止欺詐行為(特別是醚的雙重支出)方面達成了關於交易歷史的共識 – 這是一個有趣的問題,在分散化的貨幣未在工作區塊鏈之前解決。雖然以太坊正在研究其他方法來就交易的有效性達成共識,但采礦目前將平台保持在一起。
挖礦如何工作
今天,以太坊的采礦過程幾乎與比特幣相同。對於每一筆交易,礦工都可以使用計算機反復,快速地猜出答案,直到其中一人獲勝。更具體地說,礦工將通過散列函數(它將返回一個固定長度,亂序的數字和字母串,它看起來是隨機的)運行該塊的唯一標題元數據(包括時間戳和軟體版本),只改變』nonce 值』 ,這會影響結果散列值。
如果礦工發現與當前目標相匹配的散列,礦工將被授予乙醚並在整個網路上廣播該塊,以便每個節點驗證並添加到他們自己的分類賬副本中。如果礦工 B 找到散列,礦工 A 將停止對當前塊的工作,並為下一個塊重復該過程。礦工很難在這場比賽中作弊。沒有辦法偽造這項工作,並拿出正確的謎題答案。這就是為什麼解謎方法被稱為「工作證明」。
另一方面,其他人幾乎沒有時間驗證散列值是否正確,這正是每個節點所做的。大約每 12-15 秒,一名礦工發現一塊石塊。如果礦工開始比這更快或更慢地解決謎題,演算法會自動重新調整問題的難度,以便礦工回彈到大約 12 秒鍾的解決時間。
礦工們隨機賺取這些乙醚,他們的盈利能力取決於運氣和他們投入的計算能力。以太坊使用的具體工作量驗證演算法被稱為』ethash』,旨在需要更多的內存,使得使用昂貴的 ASIC 難以開采 – 特殊的采礦晶元,現在是唯一可以盈利的比特幣開采方式。
從某種意義上講,ethash 可能已經成功實現了這一目的,因為專用 ASIC 不可用於以太坊(至少目前還沒有)。此外,由於以太坊旨在從工作證明挖掘轉變為「股權證明」(我們將在下面討論),購買 ASIC 可能不是一個明智的選擇,因為它可能無法長久證明有用。
轉移到股權證明
不過,以太坊可能永遠不需要礦工。開發人員計劃放棄工作證明,即網路當前使用的演算法來確定哪些交易是有效的,並保護其免受篡改,以支持股權證明,網路由代幣所有者擔保。如果並且當該演算法推出時,股權證明可以成為實現分布式共識的一種手段,而該共識使用更少的資源。
『柒』 ERC-20 簡單介紹
ERC-20 是用於在以太坊區塊鏈上發行和實施代幣的技術標准。它是 由以太坊開發商 Fabian Vogelsteller 於 2015 年 11 月提出的。該標准描述了一套通用規則,令牌在以太坊生態系統中正常運行應遵循這些規則。因此,ERC-20 不應被視為一段代碼或軟體。相反,它可以被描述為技術指南或規范。
ERC-20 標准使開發人員更容易更准確地預測不同代幣和應用程序之間的交互。它還定義了 ERC-20 代幣如何在以太坊區塊鏈中傳輸,以及如何一致地記錄它們各自的供應和地址余額。
換句話說,ERC-20 為開發人員提供了一個要遵循的規則列表,從而可以在更大的以太坊平台內無縫運行。許多去中心化應用程序 (DApp)和服務支持 ERC-20 代幣,使社區成員和企業更容易在廣泛的應用程序(例如加密貨幣錢包、去中心化交易所、 游戲 等)上採用和使用它們。
以太坊區塊鏈上部署了多個符合 ERC20 的代幣,但具有獨特且獨特的實現方式。根據方法的不同,代幣可用於代表各種數字資產或可交易商品(例如硬幣、代金券、金券、忠誠度積分和借據)。此外,ERC-20 代幣可用作在選舉期間對投票權進行代幣化的手段。
ERC-20 標准大大減少了創建和發行數字代幣所需的工作量,這可能與ICO眾籌活動和整個區塊鏈技術的興趣增加有關 。有幾個項目已經在使用該技術標准,並且 ERC-20 代幣合約的數量在過去幾年中急劇增長。2017 年年中,以太坊網路上約有 5,500 個 ERC-20 智能合約。2018 年初,這個數字增長到 40,000 多個,現在超過 160,000。
盡管以太坊網路上的大多數代幣都遵循 ERC-20 標准,但也有一些例外。例如,以太 (ETH) 是在標准之前創建的,但尚未遵守。這導致了所謂的Wrapped Ether (WETH) 的誕生——它是一種 ERC-20 代幣,以 1:1 的比例(1 WETH = 1 ETH)代表以太。WETH 允許用戶在去中心化交易所將他們的 ETH 與其他 ERC-20 代幣進行交易。
從技術上講,ERC-20 標准描述了六個功能,它們維護基於以太坊的數字代幣的一些功能和特性。這些功能包括代幣在地址之間傳輸的方式以及與代幣智能合約相關的一些重要數據,例如符號、名稱和供應量。
這里是兔子社區,歡迎大家關注,我們會持續分享優質幣圈內容!科普區塊鏈知識!
『捌』 EOS怎麼發行
EOS有兩種不同的發行方式:眾籌和增發。
EOS在主網未上線前指代基於以太坊ERC20發布的臨時EOS代幣,通過眾籌方式發行,眾籌將從2017年6月26日13:00 UTC(世界協調時間)開始,歷時341天。
眾籌總共發行10億枚EOS,分為兩個階段,第一階段為2億枚EOS,將在2017年6月26日開始至2017年7月1日止;第二階段將7億枚EOS分為350份發售,即每23小時一份,每份200萬枚,剩餘1億枚由歸屬於Block.one, 並且不能在以太坊網路上進行交易。
在EOS主網上線後,將每年增發5%的EOS,其中1%將用於獎勵區塊生產者和備選節點。
在主網未映射前,現有的EOS是基於以太坊ERC20發布的臨時EOS代幣。當今年6月份EOS主網上線之後,這些臨時的EOS需要被轉換成真正的EOS平台通證,這個操作就是映射,相當於在以太坊和EOS主網直接建立一座橋梁。
在主網上線前,需要生成一個主鏈的EOS原生幣地址,並通過一系列的操作將其與以太坊錢包地址相關聯,在6月2日前,需要將臨時EOS代幣轉入以太坊錢包,之後的23小時內,EOS將會對錢包中的EOS進行快照,並在之後以空投的形式將EOS平台通證發到你的EOS地址上,48小時後,以太坊上的臨時EOS代幣則被凍結無法使用。若未做主網映射,則手上的臨時EOS代幣將無法被主網所認可,即所謂的不映射就歸零。充幣在火幣交易所的EOS,火幣將會幫用戶做自動映射,無需用戶做任何操作。
『玖』 以太坊是什麼丨以太坊開發入門指南
以太坊是什麼丨以太坊開發入門指南
很多同學已經躍躍欲試投入到區塊鏈開發隊伍當中來,可是又感覺無從下手,本文將基於以太坊平台,以通俗的方式介紹以太坊開發中涉及的各晦澀的概念,輕松帶大家入門。
以太坊是什麼
以太坊(Ethereum)是一個建立在區塊鏈技術之上, 去中心化應用平台。它允許任何人在平台中建立和使用通過區塊鏈技術運行的去中心化應用。
對這句話不理解的同學,姑且可以理解為以太坊是區塊鏈里的Android,它是一個開發平台,讓我們就可以像基於Android Framework一樣基於區塊鏈技術寫應用。
在沒有以太坊之前,寫區塊鏈應用是這樣的:拷貝一份比特幣代碼,然後去改底層代碼如加密演算法,共識機制,網路協議等等(很多山寨幣就是這樣,改改就出來一個新幣)。
以太坊平台對底層區塊鏈技術進行了封裝,讓區塊鏈應用開發者可以直接基於以太坊平台進行開發,開發者只要專注於應用本身的開發,從而大大降低了難度。
目前圍繞以太坊已經形成了一個較為完善的開發生態圈:有社區的支持,有很多開發框架、工具可以選擇。
智能合約
什麼是智能合約
以太坊上的程序稱之為智能合約, 它是代碼和數據(狀態)的集合。
智能合約可以理解為在區塊鏈上可以自動執行的(由事件驅動的)、以代碼形式編寫的合同(特殊的交易)。
在比特幣腳本中,我們講到過比特幣的交易是可以編程的,但是比特幣腳本有很多的限制,能夠編寫的程序也有限,而以太坊則更加完備(在計算機科學術語中,稱它為是「圖靈完備的」),讓我們就像使用任何高級語言一樣來編寫幾乎可以做任何事情的程序(智能合約)。
智能合約非常適合對信任、安全和持久性要求較高的應用場景,比如:數字貨幣、數字資產、投票、保險、金融應用、預測市場、產權所有權管理、物聯網、點對點交易等等。
目前除數字貨幣之外,真正落地的應用還不多(就像移動平台剛開始出來一樣),相信1到3年內,各種殺手級會慢慢出現。
編程語言:Solidity
智能合約的默認的編程語言是Solidity,文件擴展名以.sol結尾。
Solidity是和JavaScript相似的語言,用它來開發合約並編譯成以太坊虛擬機位元組代碼。
還有長像Python的智能合約開發語言:Serpent,不過建議大家還是使用Solidity。
Browser-Solidity是一個瀏覽器的Solidity IDE, 大家可以點進去看看,以後我們更多文章介紹Solidity這個語言。
運行環境:EVM
EVM(Ethereum Virtual Machine)以太坊虛擬機是以太坊中智能合約的運行環境。
Solidity之於EVM,就像之於跟JVM的關系一樣,這樣大家就容易理解了。
以太坊虛擬機是一個隔離的環境,在EVM內部運行的代碼不能跟外部有聯系。
而EVM運行在以太坊節點上,當我們把合約部署到以太坊網路上之後,合約就可以在以太坊網路中運行了。
合約的編譯
以太坊虛擬機上運行的是合約的位元組碼形式,需要我們在部署之前先對合約進行編譯,可以選擇Browser-Solidity Web IDE或solc編譯器。
合約的部署
在以太坊上開發應用時,常常要使用到以太坊客戶端(錢包)。平時我們在開發中,一般不接觸到客戶端或錢包的概念,它是什麼呢?
以太坊客戶端(錢包)
以太坊客戶端,其實我們可以把它理解為一個開發者工具,它提供賬戶管理、挖礦、轉賬、智能合約的部署和執行等等功能。
EVM是由以太坊客戶端提供的。
Geth是典型的開發以太坊時使用的客戶端,基於Go語言開發。 Geth提供了一個互動式命令控制台,通過命令控制台中包含了以太坊的各種功能(API)。Geth的使用我們之後會有文章介紹,這里大家先有個概念。
Geth控制台和Chrome瀏覽器開發者工具里的面的控制台是類似,不過是跑在終端里。
相對於Geth,Mist則是圖形化操作界面的以太坊客戶端。
如何部署
智能合約的部署是指把合約位元組碼發布到區塊鏈上,並使用一個特定的地址來標示這個合約,這個地址稱為合約賬戶。
以太坊中有兩類賬戶:
· 外部賬戶
該類賬戶被私鑰控制(由人控制),沒有關聯任何代碼。
· 合約賬戶
該類賬戶被它們的合約代碼控制且有代碼與之關聯。
和比特幣使用UTXO的設計不一樣,以太坊使用更為簡單的賬戶概念。
兩類賬戶對於EVM來說是一樣的。
外部賬戶與合約賬戶的區別和關系是這樣的:一個外部賬戶可以通過創建和用自己的私鑰來對交易進行簽名,來發送消息給另一個外部賬戶或合約賬戶。
在兩個外部賬戶之間傳送消息是價值轉移的過程。但從外部賬戶到合約賬戶的消息會激活合約賬戶的代碼,允許它執行各種動作(比如轉移代幣,寫入內部存儲,挖出一個新代幣,執行一些運算,創建一個新的合約等等)。
只有當外部賬戶發出指令時,合同賬戶才會執行相應的操作。
合約部署就是將編譯好的合約位元組碼通過外部賬號發送交易的形式部署到以太坊區塊鏈上(由實際礦工出塊之後,才真正部署成功)。
運行
合約部署之後,當需要調用這個智能合約的方法時只需要向這個合約賬戶發送消息(交易)即可,通過消息觸發後智能合約的代碼就會在EVM中執行了。
Gas
和雲計算相似,佔用區塊鏈的資源(不管是簡單的轉賬交易,還是合約的部署和執行)同樣需要付出相應的費用(天下沒有免費的午餐對不對!)。
以太坊上用Gas機制來計費,Gas也可以認為是一個工作量單位,智能合約越復雜(計算步驟的數量和類型,佔用的內存等),用來完成運行就需要越多Gas。
任何特定的合約所需的運行合約的Gas數量是固定的,由合約的復雜度決定。
而Gas價格由運行合約的人在提交運行合約請求的時候規定,以確定他願意為這次交易願意付出的費用:Gas價格(用以太幣計價) * Gas數量。
Gas的目的是限制執行交易所需的工作量,同時為執行支付費用。當EVM執行交易時,Gas將按照特定規則被逐漸消耗,無論執行到什麼位置,一旦Gas被耗盡,將會觸發異常。當前調用幀所做的所有狀態修改都將被回滾, 如果執行結束還有Gas剩餘,這些Gas將被返還給發送賬戶。
如果沒有這個限制,就會有人寫出無法停止(如:死循環)的合約來阻塞網路。
因此實際上(把前面的內容串起來),我們需要一個有以太幣余額的外部賬戶,來發起一個交易(普通交易或部署、運行一個合約),運行時,礦工收取相應的工作量費用。
以太坊網路
有些著急的同學要問了,沒有以太幣,要怎麼進行智能合約的開發?可以選擇以下方式:
選擇以太坊官網測試網路Testnet
測試網路中,我們可以很容易獲得免費的以太幣,缺點是需要發很長時間初始化節點。
使用私有鏈
創建自己的以太幣私有測試網路,通常也稱為私有鏈,我們可以用它來作為一個測試環境來開發、調試和測試智能合約。
通過上面提到的Geth很容易就可以創建一個屬於自己的測試網路,以太幣想挖多少挖多少,也免去了同步正式網路的整個區塊鏈數據。
使用開發者網路(模式)
相比私有鏈,開發者網路(模式)下,會自動分配一個有大量余額的開發者賬戶給我們使用。
使用模擬環境
另一個創建測試網路的方法是使用testrpc,testrpc是在本地使用內存模擬的一個以太坊環境,對於開發調試來說,更方便快捷。而且testrpc可以在啟動時幫我們創建10個存有資金的測試賬戶。
進行合約開發時,可以在testrpc中測試通過後,再部署到Geth節點中去。
更新:testrpc 現在已經並入到Truffle 開發框架中,現在名字是Ganache CLI。
Dapp:去中心化的應用程序
以太坊社區把基於智能合約的應用稱為去中心化的應用程序(DecentralizedApp)。如果我們把區塊鏈理解為一個不可篡改的資料庫,智能合約理解為和資料庫打交道的程序,那就很容易理解Dapp了,一個Dapp不單單有智能合約,比如還需要有一個友好的用戶界面和其他的東西。
Truffle
Truffle是Dapp開發框架,他可以幫我們處理掉大量無關緊要的小事情,讓我們可以迅速開始寫代碼-編譯-部署-測試-打包DApp這個流程。
總結
我們現在來總結一下,以太坊是平台,它讓我們方便的使用區塊鏈技術開發去中心化的應用,在這個應用中,使用Solidity來編寫和區塊鏈交互的智能合約,合約編寫好後之後,我們需要用以太坊客戶端用一個有餘額的賬戶去部署及運行合約(使用Truffle框架可以更好的幫助我們做這些事情了)。為了開發方便,我們可以用Geth或testrpc來搭建一個測試網路。
註:本文中為了方便大家理解,對一些概念做了類比,有些嚴格來不是准確,不過我也認為對於初學者,也沒有必要把每一個概念掌握的很細致和准確,學習是一個逐步深入的過程,很多時候我們會發現,過一段後,我們會對同一個東西有不一樣的理解。