[爆卦]solidity語言是什麼?優點缺點精華區懶人包

雖然這篇solidity語言鄉民發文沒有被收入到精華區:在solidity語言這個話題中,我們另外找到其它相關的精選爆讚文章

在 solidity語言產品中有40篇Facebook貼文,粉絲數超過3,832的網紅每日幣研,也在其Facebook貼文中提到, 【升級過後的 ETH2.0 代表著什麼?】 除了今年備受矚目的以太坊柏林升級以及 EIP-1559 提案之外,以太坊 2.0 的重大升級也是許多人一直以來引頸期盼的重點👀 究竟 ETH 2.0 升級代表著什麼呢?整體區塊鏈產業又有可能會有什麼樣的影響,讓幣研來告訴你 #cryptonewbie ...

  • solidity語言 在 每日幣研 Facebook 的最讚貼文

    2021-09-28 18:10:27
    有 9 人按讚

    【升級過後的 ETH2.0 代表著什麼?】
    除了今年備受矚目的以太坊柏林升級以及 EIP-1559 提案之外,以太坊 2.0 的重大升級也是許多人一直以來引頸期盼的重點👀

    究竟 ETH 2.0 升級代表著什麼呢?整體區塊鏈產業又有可能會有什麼樣的影響,讓幣研來告訴你

    #cryptonewbie #cryptoanalysis #eth2.0

    🟡 以太坊2.0的改進主要有以下重點

    - 以太坊支援 Solidity 以外的程式語言做開發
    - 透過分片技術大大提高交易速率
    - 共識機制由工作量證明(PoW 轉為 PoS)

    今年以太坊的柏林、倫敦以及預計十月分登場的上海硬分叉都是為了讓以太坊能夠進入2.0階段的預備措施,最終以太坊會進入代號「寧靜」(Serenity)的發展階段

    以太坊2.0 的升級過程不是慢慢推進更新而成的,而是先把以太坊 2.0 的信標鏈建構好,再將以太坊1.0、2.0 合併而成

    🟡 以太坊從 1.0 升級到 2.0 主要會經歷三大階段:

    1. 信標鏈主網(Beacon Chain):於 2020 年 12 月 1 日上線
    2. 對接(The merge):2021 年底
    3. 分片鏈(Shard chains)2022 年

    🟡 以太坊2.0 能夠解決什麼問題

    - 進一步解決先前規模性的問題(scalability),提升整體運作效能
    - 降低礦工門檻,只要質押32 ETH 就能夠成為驗證節點,使整體區塊鏈網路更加去中心化
    - 同時提升安全性,因為驗證者違規將有可能失去抵押的以太幣

    目前抵押於2.0智能合約的以太幣超過750萬枚,佔以太幣總流通量6.5%以上

    雖然我們不能確定以太坊2.0 什麼時候才能升級完成,除了技術開發之外,也需要透過經濟手段迫使礦工逐漸轉往 PoS 模式,但是不管是在鏈上的運作效率以及整體的通縮手段上都有非常大的轉變,日後的推進必然也會是整體幣圈的焦點
    -------------------------------------------------------------
    🥳Avalanche 香港交流群上線了!🥳
    想知道AVAX最新空投幣、AMA等市場動態及最新優惠?立刻加入 Avalanche 香港交流群,與一眾用家互相討論見解,Desmond也會不定期在這裡優先分享DeFi生態的項目分析,不想錯過的話就按這裡加入
    👉🏻https://bit.ly/3hksa7z

    【Bybit 獨家開戶優惠🎉】
    新用戶幣研獨家優惠,只要充值1000USDT即可獲取高達125 USD體驗金(優惠碼【21515】)
    註冊及入金教學👉🏻:https://bit.ly/3DPMY0e

    「每日幣研|幣市分析&最新優惠」TG Channel 🔍
    想了解更多加密貨幣最新市場資訊及優惠的話,歡迎追蹤我們「每日幣研|幣市分析&最新優惠」TG Channel,我們會在群內發佈幣圈第一手消息及分享投資小技巧!馬上加入頻道和我們一起發掘幣圈隱藏商機吧!
    立即加入頻道👉🏻:https://bit.ly/2YzVK2p

  • solidity語言 在 軟體開發學習資訊分享 Facebook 的精選貼文

    2021-09-03 09:46:57
    有 3 人按讚

    基於 Solidity 和其它工具來編寫一款有趣的遊戲吧!打磨自己的以太坊開發技術,變得更加純熟!

    從這 5.5 小時的課程,你會學到

    1 掌握基礎的Solidity語言,包括檔案結構、型別、事件、陣列等等

    2 學會使用Truffle、Web3/Truffle合約等開發工具

    3 深入理解不同型別區塊鏈、節點以及它們的操作方式

    4 學會如何安全儲存,通過智慧合約收發以太幣等

    5 測試和釋出這款有趣的黑白棋遊戲到鏈上

    6 每章都配有作業和作業講解,確保你能隨時驗證自己是否掌握

    https://softnshare.com/ethereum-chinese/

  • solidity語言 在 Taipei Ethereum Meetup Facebook 的最佳貼文

    2021-06-29 02:57:14
    有 9 人按讚

    📜 [專欄新文章] [zkp 讀書會] Cairo 語言介紹

    ✍️ NIC Lin

    📥 歡迎投稿: https://medium.com/taipei-ethereum-meetup #徵技術分享文 #使用心得 #教學文 #medium

    Cairo 是 STARK 證明系統的其中一個編程語言,讓開發者能透過 Cairo 來使用 STARK,撰寫效能更高的 Dapp

    Photo by Simon Berger on Unsplash

    Warning:本篇會保持在 high level 的介紹,實際深入的部分請見文內附上的文檔或是官方開發者文件

    背景介紹

    建構於密碼學的零知識證明能提供計算的隱私性,但同時在區塊鏈生態系也被用來提升 Scalability — 我可以用 10 秒的運算資源來驗證原本耗費 1000 秒運算資源的計算過程

    如同更多人熟悉的 SNARK,STARK 也是一個零知識證明的證明系統,但當前的 STARK 著重的是在 Scalability ,而非大家比較習以為常零知識證明提供的隱私性特質

    其實目前基於 SNARK 的 Rollup 項目,例如 zkSync、Loopring、Aztec、zkopru,除了 Aztec 外,其他都是利用 SNARK 來增加 Scalability — 這些 Rollup 上資料都還是公開、沒有隱私性的

    StarkWare 是目前唯一基於 STARK 的開發團隊

    STARK 要加上隱私保護不會太難,只是 StarkWare 還沒有把這項功能放在未來規劃中

    Cairo 簡介

    標榜為圖靈完備的零知識證明系統語言,Cairo 對原本熟悉 Solidity 的開發者來說還是會感到比較難上手和陌生的。再加上套件庫還不夠充足,目前支援的雜湊函式是 Pedersen,數位簽章演算法是 ECDSA(相對於 SNARK,EdDSA 的效能反而比較差所以沒有支援)。
    但 Cairo 還在早期開發的階段,相信開發體驗會越來越好的。

    另外需要注意的是作為一個證明系統,會有 Prover 和 Verifier 的角色。而 STARK 的 Verifier 是公開的,但 Prover 軟體預計會有 License 保護。Prover 一般情況下不得用於商業用途,除非將 proof 上傳至官方的 Verifier。

    最後要提及的是,第一版的 Cairo 是設計來方便開發者將 Dapp 的運算遷移至鏈下。不同於 Rollup,這個鏈下只會有它自己一個 Dapp。這個 Dapp 的項目方自己維護自己 Dapp 的 state。( Rollup 則是 operator 維護所有 Dapp 的 state,Dapp 開發者不需自己操煩)
    這可能有點難懂。如果你有在寫 Solidity,想像一下今天你在合約要用到合約裡宣告的 storage 變數時,你要自己提供 merkle proof 上來,證明這個storage 變數真的是這個值。這個就是開發者要自己維護 state 的意思。

    而第二版的 Cairo 則是 StarkNet 裡使用的 Cairo(第一和第二版是不同編譯器),這版的 Cairo 就是作為 Dapp 在 Rollup 開發所使用 — 開發者可以在合約裡宣告變數,變數的值不需開發者維護,可以直接假設存在。
    註1:StarkWare 不喜歡 Rollup 這個詞,他們覺得 Data Availability 的需求是一段光譜:不一定得要把 data 全都送上 L1,中間有其他方式可以做不同層級的 Data Availability。
    註2:第一版和第二版實際上在官方版本裡是 0.0.1 及 0.0.2,在撰文當前最新版即是 0.0.2

    官方網站:https://www.cairo-lang.org
    開發者文件:https://www.cairo-lang.org/docs/

    開發環境

    Cairo 有提供像是 Remix 的瀏覽器 IDE:playground。裡面提供各種範例練習和挑戰,除了可以編譯,還可以直接生成並上傳 proof。
    註:但有些功能還是沒辦法在 playground 裡使用,例如要給你的程式 custom input 時。這時候只能在本地端開發才能使用這個功能。

    開發 Cairo 要先安裝python,我將開發者文件整理出來的資料統整在這個 hackmd 文檔裡:https://hackmd.io/w690dpAQTsKeKZv3oikzTQ
    裡面包含簡介、設置本地開發環境以及 Cairo 基礎(因為篇幅原因,所以不將內容複製到這裡)
    註:我把開發者文件裡的代碼整理到這裡:https://github.com/NIC619/cairo_practice/tree/master/practices
    如果不想在研究開發者文件過程中,還要自己手動拼湊裡面例子的話,可以直接用整理好的代碼來執行。同時 repo 裡還有包含一些額外自己測試 Cairo 功能的範例。

    深入 Cairo

    在那份 hackmd 文檔裡的開頭,可以連結到第二部分 — 深入 Cairo 的部分。裡面也是從開發者文件裡擷取出來我覺得比較重要的部分。如果你要讀開發者文件的話,我建議從 Hello Cairo 開始,它會從例子切入,會比較好知道 Cairo 怎麼使用。接著如果要更深入了解,再去讀 How Cairo Works。

    StarkNet Cairo

    第二版的 Cairo 其實功能和第一版的 Cairo 是差不多的,所以不必擔心在開發者文件裡學到的 Cairo 在 StarkNet 版本會不能用或差很多。在讀完 Hello Cairo/How Cairo works 後,就可以接著看 Hello StarkNet。會很順利的切換到 StarkNet 版本的 Cairo。
    註1:我整理的文檔裡是按照第一版 Cairo 所寫的
    註2:如果你從開發者文件一路看下來,體驗過非 StarkNet 版的 Cairo,那你在體驗 StarkNet 版的 Cairo 時一定會發現這更像一般智能合約的使用方式 — 你可以用 view 函式查詢 storage 變數,可以用 external 函式去執行合約(非 StarkNet 版本不是這樣操作 Dapp 的,這邊因為篇幅原因沒有詳細介紹)。

    非常建議嘗試兩種版本的 Cairo,你會知道 1. 操作一個單獨在 L2 的 Dapp 和2. 操作與其他 Dapp 共存在 Rollup 上的 Dapp 的不同。這對了解 L2 怎麼運行、需要哪些資料、為什麼需要這些資料非常有幫助。

    0.0.2 版的 StarkNet Cairo 目前還缺少一些功能:

    函式還沒辦法宣告陣列或 struct 型態的參數

    合約和合約之間還沒辦法互動

    L1 沒有辦法讀取到 L2 的資料,L2 也沒辦法讀取到 L1 的資料。如果要建立跨 L2 Bridge,這個功能非常重要。

    補充及個人心得

    STARK 的 proof size 相比於 SNARK 系列的 proof size 大很多,又其證明所包含的交易數量對 proof size 和驗證時間的影響不大,所以把很多筆交易一併做一個 proof 會是對 STARK 非常有利、節省成本的方式(SNARK、STARK 比較表)。但這同時也是一個缺點,如果你的 Dapp 或 Rollup 的 TPS 不高,那就只能等更久時間搜集多一點的交易,要不然就只能提高成本來維持驗證 proof 的頻率。

    StarkWare和 zkSync 一樣都有 Rollup 宇宙的概念( Rollup 宇宙的用詞並不精確,因為在他們的宇宙中不會所有子鏈都是 Rollup,而是會有依照 Data Availability 程度不同所區分的子鏈,像是 Validium、zk Porter 的設計),個人覺得能夠有(針對 Data Availability 程度的)選擇是會比只有一個選擇(完全 Data Available) 還好的方式,但實際上的可行性就要等其團隊釋出更多的資訊。

    在 Rollup 越趨成熟的情況下,能夠提供快速跨 Rollup 服務的流動性提供者的角色會越來越重要。zk Rollup(StarkNet、zkSync、etc…)比 Optimistic Rollup (Optimism、Arbitrum、etc…)有著短上許多的 finalize 時間,這對降低流動性提供者的風險有很大的幫助,但目前 zk Rollup 支援合約功能甚至 L1 <-> L2 互動的完成度都比 Optimistic Rollup 還低上許多。短期內快速跨 Rollup 的服務應該還是侷限在 Optimitic Rollup 之間。

    abbrev

    [zkp 讀書會] Cairo 語言介紹 was originally published in Taipei Ethereum Meetup on Medium, where people are continuing the conversation by highlighting and responding to this story.

    👏 歡迎轉載分享鼓掌

你可能也想看看

搜尋相關網站