什么是Soilidity?
Solidity是一種面向合約的高級編程語言,用于實現智能合約。Solidity已經被設計用于以太坊虛擬機。
Solidity===智能合約。
Solidity的代碼封裝在合約中。合約是以太坊應用程序的基本構建塊——所有變量和函數都屬于一個合約,這將是所有項目的起點。
pragmasolidity>=0
studentpublicstudents;//createsanarraynamedstudentsofstudenttypeobjects
函數聲明
functioneatHamburgers(stringmemory_name,uint_amount)public{}
函數的可見性是公開的。有兩種方式可以傳遞參數給Solidity函數:
按值和按引用
eatHamburgers(“vitalik”,100);
私人/公共函數
在Solidity中,函數默認是公共的,因此任何人都可以在網絡中調用公共函數。然而,出于安全考慮,我們將函數設為私有,這樣只有所有者才能調用函數。
function_eatHamburgers(stringmemory_name,uint_amount)private{?
}
按照慣例,私有函數的開頭帶有下劃線。
內部/外部關鍵字
火幣推出《一分鐘讀懂DeFi》系列科普視頻:據官方消息,8月24日,火幣推出《一分鐘讀懂DeFi》系列科普視頻,并與微博財經合作冠名播出,布道DeFi認知,助力行業發展《一分鐘讀懂DeFi》是由火幣成長學院打造的業內首個系統全面講解DeFi的系列科普動畫,繼推出《區塊鏈100問》后的再續佳作。《一分鐘讀懂DeFi》系列動畫對DeFi的發展進行系統梳理,適合想要由淺入深、全面系統了解區塊鏈DeFi的人們輕松了解DeFi。目前視頻已由火幣網官方微博發布。[2020/8/24]
還有兩種類型的函數可見性。內部類似于私有,除了它可以被繼承的合約訪問,即繼承。
外部類似于公共。除了聲明了這個函數的聯系人之外,所有的合約都可以調用這個函數。
在函數中返回
函數聲明包含返回值的類型。
functionsayHi()publicview/purereturns(stringmemory){?
return“Hi”;
}
這些函數可以標記為pure/view。當我們甚至沒有訪問傳遞的數據時,我們就將函數標記為pure。如果函數不修改數據,只查看數據,那么它將被標記為view。
類型轉換
數據類型之間的轉換稱為類型轉換。
uint8a=5;?
uintb=6;
//linebelowthrowsanerrorbecausea*breturnsauint,notuint8:?
IMF今日發布的加密貨幣科普視頻實為兩年前舊聞,且存在諸多疏漏:國際貨幣基金組織IMF今日在推特上發布了一條關于加密貨幣的科普視頻,這段時長兩分鐘的視頻最初發布于2018年6月。該視頻稱加密貨幣是“貨幣進化的下一步”,但沒有特別提到DLT、區塊鏈,甚至是代幣名稱等術語。BTC、XRP和ETH只出現在說明加密交易的圖形中。盡管這段視頻到目前為止已經獲得了超過13.7萬的點擊量和2900個贊,但來自加密社區的許多反應都是批評的,他們指出了信息中的漏洞和似乎具有誤導性的措辭。
Reddit用戶nanooverbtc稱:“他們犯了很多錯誤,比如把私鑰稱為密碼。”該視頻也沒有討論挖礦或加密貨幣供應。Kraken策略師Pierre Rochard等知名人士表示:“可證明的稀缺性是比特幣有趣的原因,你忘了提這一點。”(Cointelegraph)[2020/8/24]
uint8c=a*b;
//wehavetotypecastbasauint8tomakeitwork:?
uint8c=a*uint8(b);
事件
事件用于向前端傳達后端區塊鏈網絡上發生了一些事情。
//declaretheevent?
eventNotifyOnFrontend(uintx);?
functionadd(uint_x,uint_y)publicreturns(uint){?
uintresult=_x+_y;?
//fireaneventtoletthefrontendknowthefunctionwascalled?
人民數字FINTECH推出區塊鏈科普動畫:人民日報數字傳播發布微博稱,人民數字FINTECH出品《趣味科普|區塊鏈動畫》。[2020/3/31]
emitNotifyOnFrontend(result);?
returnresult;?
}
我們的前端代碼應該已經安裝了web3,并且應該監聽“NotifyOnFrontend”事件,這樣才能工作。我們的JavaScript框架或普通JS將不得不監聽這個事件來接收它:
YourContract
functiongetUserInfo(string?name)publicviewreturns(uint,string){?
return(allusers.age,allusers.dob);?
}?
}
現在,如果可以用不同的值多次調用setUserInfo,比如:
setuserInfo("Vivek",26,25/05/1995)setuserInfo("Supu",23,01/09/1998)
要獲得這些值,只需傳遞名稱:
getUserInfo("Vivek");//2625/05/1995?
getuserInfo("Supu");//2401/09/1998
全局變量
這些變量可用于像msg.sender這樣的所有函數。我們所編寫的任何Solidity程序,都應該由所有者調用。發送者的地址存儲在msg.sender全局變量中。
聲音 | ETC Labs主管:科普教育是未來幾年公鏈面臨的巨大挑戰:ETCLabs主管Darin Kotalik認為,科普教育是未來幾年公鏈面臨的巨大挑戰,人們必須要對區塊鏈有基本的認識,分清楚公鏈和私鏈的區別。[2019/8/25]
require
require用于驗證這兩個語句,并據此做出決定。如果條件為真,則代碼成功運行,否則就拋出錯誤
functionsayHi(stringmemory?name)publicreturns(stringmemory){/Comparesif_nameequals“Vivek”Throwsanerrorandexitsifnottrue.Soliditydoesn’thavenativestringcomparison,sowecomparetheirkeccak256hashestoseeifthestringsareequaq?/?
require(keccak256(abi.encodePacked(name))==keccak256(abi.encodePacked(“Vivek”)));
//Ifit’strue,proceedwiththefunction:?
return“Hi!”;
}?
sayHi(“Vivek”)//executessuccessfully?
sayHi(“Supu”)//throwsanerror
因此,require對于在運行函數之前驗證某些條件必須為真非常有用。
財政部副部長朱光耀:數字經濟還處在發展的過程中,要以科普、推動的態度來推進數字經濟發展:今日,在中國發展高層論壇2018年會上,財政部副部長朱光耀表示:“數字經濟還處在發展的過程中,要以科普、推動的態度來推進數字經濟發展。也要關注數字經濟的其他影響,包括稅收征管、反洗錢監管措施等要跟上。”[2018/3/25]
繼承
有時候,與其制定一個非常長的合約,還不如將代碼邏輯拆分為多個合約來組織代碼。
contractAnimal{
functioncatchphrase()publicreturns(stringmemory){?
return“Animal”;
}?
}contractCatisAnimal{
functionanotherCatchphrase()publicreturns(stringmemory){?
return“CatisanAnimal”;
}
}
import
將代碼拆分為多個文件,并使用import來使用另一個文件中的功能。
這通常是在Solidity項目中處理長代碼庫的方式。
存儲和內存
存儲是指永久存儲在區塊鏈上的變量。內存變量是臨時的,在對合約的外部函數調用之間會被刪除。可以把它想象成電腦的硬盤與內存。
與區塊鏈網絡中的其他合約交互
關于這一點,我將寫一篇單獨的文章。現在,保持簡短:
為了與其他合約交互,我們聲明了一個類似object的接口。我們創建了一個合約,并在里面聲明了一個函數,我們想要從另一個合約調用或使用它。函數只是骨架,它不包含主體。
contractGetNumber{?
functiongetNum(uint_num)publicreturns(uint){?
return_num;?
}
假設有一個合約,我們想要使用上面的getNum函數。為此,我們將在項目中創建一個合約,并聲明一個getNum函數框架(沒有函數體)。
contractNumberInterface{?
functiongetNum(uint_num)publicreturns(uint);?
}
現在我們可以從NumberInterface合約中調用getNum函數。
在將合約部署到以太坊后,它就變成了不可變的,也就是說它不能被修改。部署到合約中的初始代碼將永久地停留在區塊鏈上。這就是安全性在Solidity中如此重要的原因之一。如果我們的合約代碼中有一個缺陷,就沒有辦法在以后修補它。必須告訴我們的用戶開始使用具有修復功能的不同智能合約地址。
函數修飾符
函數修飾符看起來就像函數,但是使用關鍵字修飾符而不是關鍵字函數。這些用于特殊情況,例如當您只希望您的所有者而不是所有人做某事時。
這有助于更新DApp的關鍵部分,同時防止其他用戶破壞我們的合約。我處理過的一個用例是——當我們想在執行任何用例之前驗證語句時。
gas
用戶支付gas費來在以太坊網絡上運行合約。gas以以太(以太坊上的貨幣)為單位計算。我們的函數的總gas成本等于它所有單獨操作的總gas成本。
更多關于存儲的內容
存儲內存被永久寫入到區塊鏈中。全世界成千上萬的節點需要將這些數據存儲在它們的硬盤上,并且隨著區塊鏈的增長,這些數據量也會隨著時間的推移而增長。所以這樣做是有代價的。
為了降低成本,我們希望避免將數據寫入存儲,除非絕對必要。有時,這涉及到看似低效的編程邏輯——比如每次調用函數時都要在內存中重新構建數組,而不是簡單地將該數組保存在全局存儲變量中以便快速查找。
因此,建議盡可能使用內存類型,這樣數據就不會永久存儲,從而節省成本。循環在Solidity中將比使用存儲更便宜。所以盡可能for循環中使用內存。這與Java、Python等語言中所做的完全相反,因為for循環的計算成本更高。
For循環
Syntax類似于Javascript。
for(uinti=1;i<=10;i++){//body}
應付修飾符
支付功能是使Solidity和以太坊如此酷的部分原因——它們是一種可以接收以太坊的特殊類型的功能。當我們在一個普通的web服務器上調用一個API函數時,我們不能在調用函數的同時發送美元——也不能發送比特幣。
但在以太坊中,因為貨幣(以太坊)、數據(交易有效載荷)和合約代碼本身都在以太坊上,所以我們可以同時調用一個函數并向合約支付費用。
這允許一些非常有趣的邏輯,比如為了執行一個函數,需要向合約支付一定的費用。
注意:
在以太坊中,當我們在合約上調用一個函數時,我們將其作為交易廣播到網絡上的一個或多個節點。節點在網絡上收集一些交易,試圖成為第一個解決計算密集型數學問題的“工作證明”,然后將這組交易連同他們的工作證明發布為一個塊到網絡的其余部分。
代幣
所以基本上,代幣只是一個合約,它記錄了誰擁有多少代幣,以及一些函數,以便這些用戶可以將他們的代幣轉移到其他地址。
assert與require的差異
Assert類似于require,如果為false則拋出錯誤。assert和require之間的區別是,當一個函數失敗時,require會退還用戶剩余的gas,而assert不會。
Metamask
這是Chrome和Firefox的瀏覽器擴展,允許用戶安全地管理他們的以太坊賬戶和私鑰,并使用這些賬戶與使用Web3.js的網站進行交互。
應用程序二進制接口。
在部署的合約之后,它會在以太坊上得到一個固定的地址,在那里它將永遠存在。在以太坊網絡中部署智能合約后,還會生成一個ABI。基本上,它是以JSON格式表示的合約方法,告訴Web3.js如何以我們的合約能夠理解的方式格式化函數調用。
Web3Js
以太坊的JS前端庫被稱為web3.js。
Source:https://medium.com/coinmonks/learn-all-about-solidity-ethereum-45d709c4de77
據CoinDesk12月6日消息,國際清算銀行在其最新的季度評論中表示,去中心化金融有集中化的問題,政策制定者應該利用它來監管該行業.
1900/1/1 0:00:00文章作者:VitalikButerin文章翻譯:Blockunicorn原標題:《VitalikButerin:以太坊終局之戰》特別感謝來自Optimism和Flashbots的一大批人對本文的.
1900/1/1 0:00:00DFINITY基金會歷經6年研發的InternetComputer主網于2021年5月正式上線,InternetComputer是一種基于新型分散協議構建的全新區塊鏈計算機.
1900/1/1 0:00:00原文:秉燭的夜談 原文作者:吳桐、王龍 北京時間12月8日23時,美國眾議院金融服務委員會在國會山舉行了“數字資產和金融的未來:了解美國金融創新的挑戰和利益”為題的聽證會.
1900/1/1 0:00:001.a16z宣布投資去中心化自治組織PleasrDAO,具體金額暫未透露2.美國財長耶倫被要求與國會合作實施加密貨幣條款KaJ Labs為Lithosphere與Jot Art開發者推出10億美.
1900/1/1 0:00:00“一切都會出錯”是任何規劃都應該遵循的主要原則之一。 不穩定是事實 在解決密碼問題時,會出現不可抗力的情況。多年來,許多科學家都在考慮每一個細節,但現實往往會讓你感到驚訝.
1900/1/1 0:00:00