主頁 > 區塊鏈 > 為什么自定義密碼學原語對在區塊鏈上的開發至關重要?

為什么自定義密碼學原語對在區塊鏈上的開發至關重要?

2020-12-10 12:31:06 區塊鏈

區塊鏈是一個基于密碼學、經濟學和網路科學的新技術,對于一般的大眾來說,其中的密碼學并不是一門容易親近的學科,甚至是上面提到的三個學科中,大家覺得最有距離感的學科,但身處區塊鏈圈的朋友們一定會常常聽到「區塊鏈是一部 Trust Machine」這樣的說法,或者有人會說在區塊鏈的世界里是「In Math we Trust」,可見密碼學對于區塊鏈技術來說是根基一樣的重要存在,

好了,那么問題來了:

  • 區塊鏈究竟在哪些地方用到密碼學呢?
  • 密碼學為什么對區塊鏈技術至關重要?

區塊鏈的哪些地方用到了密碼學?

首先,如果你是一個區塊鏈用戶,可能在你房間里的某個角落,會有一張紙條,上面抄著十二個不知道怎么來的單詞,有的人還有很多張,甚至有些大 holder 會把這十二個英文單詞刻在鋼板上,然后鎖進保險箱里,

是的,為什么這十二個助記詞,或者像一長串亂碼般的私鑰能夠代表你對資產的所有權呢?

這背后的原理其實就是密碼學,

區塊鏈上的密鑰、地址和錢包都是通過密碼學去實作,利用非對稱加密技術——橢圓曲線演算法(ECC)可以驗證某人持有的私鑰是否是吻合某個公鑰,通過這個方式我們可以證明這個人是否是這筆加密資產的持有人,因為除了擁有私鑰的人之外,其他沒有該私鑰的人是沒有辦法解鎖這筆資產的,

我們在此用位元幣舉例私鑰、公鑰和地址生成的原理,一個位元幣錢包中包含一系列的密鑰對,每個密鑰對包括一個私鑰和一個公鑰,私鑰通常是一個隨機選出的 256 位的數字,基于私鑰,我們就可以使用 secp256k1 標準的橢圓曲線這個單向密碼函式產生一個公鑰,基于公鑰,我們又可以使用一個單向哈希函式 SHA256 和 RIPEMD160 生成位元幣地址,再通過 Base58 check 編碼將位元幣地址變成現在這較為簡潔的形式,而像我們比較常用的助記詞,則是通過基于 BIP 39 標準而生成的隨機英文單詞,如果沒有私鑰或助記詞的人,是無法使用這筆加密資產的,

當我們有了可以配對的密鑰對后,可以在各種型別的錢包或者客戶端上做驗證,確認資產的所有權,并且通過這個客戶端來進行各種資產的使用,例如最簡單 BTC 轉賬,或者再進階一點的用某個錢包去簽署智能合約的交易:比如用 Metamask、imToken 或者 Alphawallet 等錢包里的 ETH 去購買加密貓,或者在 DeFi 的平臺上面進行借貸,以及用 Uniswap 交換某些 ERC20 Token 等,

除了轉賬等基本的驗證外,現在甚至某些平臺的身份驗證都可以用公私鑰來做登錄驗證,或者通過驗證你是某筆資產的所有人來進行各種權益的證明,簡單來說,公私鑰驗證系統背后的密碼學就是用戶想暢游區塊鏈世界的通行證,

在區塊鏈中,還有另外一個不可忽視的密碼學使用場景,就是區塊中的交易排序,以及 Merkle Tree 等決定區塊排序的程序,位元幣就是將每筆交易用 SHA256 演算法進行加密,在這里加密演算法確保了區塊鏈的安全性,以及幾乎不可能被篡改的特性,光是在這兩個位元幣的基礎使用場景中就都用到了密碼學,于是乎甚至還有許多人在猜測,中本聰可能是個密碼學大佬,才能夠把密碼學在這個點對點的現金系統中使用的淋漓盡致,

當然,除了在區塊的生成和公私鑰驗證這兩大區塊鏈的核心功能上可以發揮用途之外,密碼學在隱私保護甚至擴容等方面都可以派上用場,

現在的公鏈如何使用密碼學?

Wow,這是一條新的公鏈嗎?
那它有沒有錢包啊 ?
又要多一組新地址和抄一組新的助記詞了,,,

如果一個用戶真的愿意自己好好地保管自己的資產,也勤于投資不同的公鏈,我相信他們一定也會有類似的經驗和好幾組不同的助記詞或私鑰,但到最后,他們能夠保存好的,可能只剩下那些最主要的持倉資產,有些人甚至忘記備份某些資產的助記詞,

長期下來,區塊鏈資產管理的問題也導致區塊鏈的門檻越來越高,所以一些錢包為了解決這個問題,已經提出了很多的優化方案,有些錢包甚至可以做到一個身份錢包的單一助記詞,可以管理多種資產等功能,但仍然有許多組不同的地址必須要由用戶來做管理,這樣的問題對于很多新公鏈而言可能更為嚴重,因為如果用戶要去通過他們的網頁或手機錢包,去嘗試鏈上的應用,用戶就會增加許多管理公私鑰的成本,更何況他們不像郵箱的密碼一樣可以任由用戶自己定義,既不滑順也不香,

但為什么區塊鏈會有這樣的限制?

這樣的限制是因為目前許多的公鏈,都將很多密碼學原語的使用場景寫入了共識層,因此在這些公鏈中,像公私鑰簽名、客戶端驗證,以及區塊生成的哈希和常用的加密演算法,基本上都是鑲嵌在共識層中的,例如地址所使用的驗證、交易使用的簽名等,其實都寫在底層協議中,因此會變得非常難以改動,另外,許多公鏈的虛擬機性能都不足以支持靈活的密碼學原語部署,因此對于這樣的公鏈而言,如果底層的虛擬機不預先支持某個密碼學原語,那么基于該密碼學原語的場景可能很難直接被開發者使用,

如果要更動,唯一的辦法就是硬分叉!

拿以太坊為例,以太坊的共識層寫入了哪些密碼學的場景呢?

除了區塊的加密簽名和 Merkle Tree 的哈希外,還有交易簽名和客戶端的驗證,如果有任何人想要在這些點上做改動,例如將以太坊公私鑰的哈希演算法 keccak-256 換成其他簽名演算法,那么唯一的辦法就是提一個 EIP (Ethereum Improvement Proposal),然后等待、祈禱這個提案被排入硬分叉之中,因為寫在協議層的內容,就是全網的所有用戶都必須遵從的規則,

然而硬分叉往往需要非常長的時間,以 EIP 152 為例,這是一個 2016 年就提出的提案,希望將簽名演算法 BLAKE2 加入以太坊中,但直到 2019 年底的伊斯坦布爾提案中才被加入到升級的內容當中,整整歷時 3 年之久

從剛才 EIP 152 的例子中我們還會發現另一個限制,那就是在以太坊上如果要使用虛擬機不支持的密碼學原語,幾乎是不可能的,因為對于以太坊虛擬機而言性能是一大限制,光是簡單的運算,就能夠消耗大量的 gas,

因此我們如果回顧以太坊上歷次的分叉,就可以發現從家園(HomeStead)的硬分叉升級開始,以太坊就不斷地把所有可能常用到的密碼學原語,例如 sha256 hash、ripenmd160hash 等持續的通過預編譯(precompiled)的方式,加入到底層的虛擬機中,這點在拜占庭(Byzantium)或者伊斯坦布爾(Istanbul)的升級中也可以看到,以太坊通過硬分叉的形式,來預編譯密碼學原語以及這些密碼學原語運算的 gas 定價,

如果不通過預編譯合約在節點先進行實作,那么許多簽名演算法的智能合約部署將花費非常非常高的 gas 費,導致其根本無法部署,例如 EIP 196、 EIP 197 之所以被采納,就是預見了 zkSNARK 需要大量的 gas 進行鏈上的運算,因此預先將這些加密演算法,如橢圓曲線加法、乘法和配對驗證等編譯進了底層的 EVM 中,好讓這些計算成本可以節省下來,所以,我們可以說在以太坊上除了已經做了預編譯的簽名演算法外,其余的加密演算法基本上是沒辦法使用的,

上述這些固化的密碼學使用方式,對于開發者而言是一個很大的限制,

由于交易和客戶端的簽名驗證都被寫入共識層,因此驗證工具和流程都必須按照規定的加密演算法進行,例如在位元幣或以太坊中,如果我們要創建一個賬戶,那么我們依舊需要管理一組新的密鑰對,

對于想要帶來良好用戶體驗的開發者而言,這樣會產生很多的限制,并且需要通過其他方式,去彌補固化的底層設施帶來的不友善的用戶體驗,比如在創建助記詞之后,我們可以在某些錢包中使用 FaceID(如 imToken),比如在 ABC Wallet 中,用戶起初只需要靠像手機里的六字驗證碼就能夠登入,等你真的覺得你需要把私鑰或助記詞匯出了,再進行匯出和備份,

這些都是開發者試圖提升用戶體驗所想出來的好辦法,但對于每一條新的公鏈,密鑰對管理的本質都是需要有一組新地址和密鑰,這個問題是一直存在的,

上述的公私鑰驗證方式不夠靈活的問題,在位元幣、以太坊等較為先發的公鏈上或許還不明顯,因為他們已經有既有的用戶,這些用戶也被折磨習慣了,但對于近期興起的公鏈而言,如果還存在和先前公鏈同樣的進入摩擦成本,那么就是給用戶設定了障礙,也會影響開發者是否想要在這個公鏈上開發的意愿,

一個對用戶有學習成本的公鏈,在獲取用戶上就存在著先天的壁壘,即使這些公鏈有其他的亮點,可能對于開發者而言,也不會那么有吸引力,因為他們知道很多的用戶可能都被這些不友善的用戶體驗給嚇走了,

另外,密碼學原語不能夠靈活使用的問題,影響的層面還不止于公私鑰的保存,對于開發者而言,如果以后他們想用更先進的密碼學原語來保證隱私及安全,一樣會面臨到底層的虛擬機能不能部署,以及支持簽名驗證的挑戰,當然還會影響目前大家討論的很熱的話題:跨鏈,因為不同的鏈使用的密碼學原語也會有所不同,在虛擬機驗證交易時就會遇到這個難題,這也是為什么目前許多同構跨鏈的解決方案(Cosmos / Polkadot )可行,但對于異構跨鏈的方案卻停滯不前的原因,

Nervos 的設計有何不同?

在 Nervos CKB 中,除了交易排序外,沒有其他硬編碼的密碼學原語,資產所有權的驗證是通過 cell 中的 lock script 來做驗證,其中的驗證規則和使用的密碼學原語都是可以自定義的,因此幾乎所有的密碼學原語都可以被開發者靈活的使用,

套用一句 Nervos 研究員 Cipher 老師的話來說,就是:「在 CKB 上除了最基礎的交易排序以外,其余都是應用層的內容,」這讓開發者擁有了非常大的開發彈性,去進行各式各樣的開發,例如更自由的賬戶驗證方法等,

因為在基于 RISC-V 的 CKB-VM 中,要求的就是一套能夠符合 RISC-V 編碼的驗證規則而已,開發者有很多能夠自由揮灑的空間,下圖可以看出 Nervos 和其他可以支持智能合約的公鏈在靈活度上的差異,應用層的內容表示的是可以去做自定義的,協議層代表的是需要經過「分叉」才能改動的內容,

在這里插入圖片描述

以目前 Nervos 的 Grnats 團隊 Lay2 為例,為什么他們開發的 pw-sdk 能夠用以太坊的地址,甚至是 ENS 來接收 CKB?是因為在 CKB 上,地址是開發者可以任意把玩的應用層內容,理論上只要鏈上有已經有驗證規則的 cell 和非對稱加密的加密演算法庫,這種地址生成規則就能夠被驗證,例如我們可以把以太坊的 Keccak-256 (SHA-3)的簽名演算法和驗證規則和位元幣的 SHA-256 都部署在鏈上,那么未來的其他開發者就可以用 cell deps 進行呼叫,

也因此,任何的開發者未來如果想在 CKB 上 ,為他的資產添加更先進的加密演算法做為解鎖的規則,是完全可行的,因為任何人都可以部署各種密碼學原語庫在 CKB 上,并且可以通過優化去節省存盤空間以及減少驗證所需的 cycle 去降低部署的成本,讓任何先進的密碼學原語不用等到硬分叉也能夠被使用,

在 CKB 上可能看見的區塊鏈未來:直逼互聯網的用戶體驗

基于靈活的密碼學原語,我們可以說在未來,很多互聯網上用戶非常習慣的驗證規則,也完全可能被寫成 RISC-V 可以讀取的形式,并且被部署到鏈上,例如 PGP Key 驗證或者指紋解鎖等功能,如果在鏈上有一個能夠對應他們所使用的驗證標準的腳本,并且有可以支援這種驗證的可信環境,那么如此方便的使用方式在未來是真的可能實作的,

再更深入一點地看,未來的應用層,會有更多的場景會使用到密碼學的各種演算法,

近兩年在分層擴容的領域(Layer 2),除了原先的閃電網路、狀態通道以及其他的側鏈解決方案之外,又出現了一種新興的密碼學擴容應用:Rollup,也就是利用簽名演算法來壓縮交易,

目前在 Rollup 上最主流的壓縮交易的方式是零知識證明 (zkp),也就是所謂的 zkRollup,未來如果在 Rollup 上有其他更先進的零知識證明解決方案,或者利用其他去簽名演算法(如 BLS 等),對于 CKB 而言,只要開發者可以想到低成本的實作方法,都可以直接讓 CKB-VM 驗證,而不需要通過硬分叉,因為這并不涉共識層的內容,而且 CKB-VM 相較于 EVM 而言也更加地高效,目前安比實驗室也在開發在 CKB 上可使用的零知識證明庫,未來可供開發者任意使用,

另外,CKB 因為可以支持靈活的密碼學原語,也在區塊鏈跨鏈資產轉移方面,比其它的公鏈有更大的先天優勢進行來自不同鏈的交易驗證,讓 CKB 更有機會完成異構跨鏈的資產流通與轉移,

打從中本聰的位元幣白皮書問世開始,區塊鏈就是一個可以在中心化的環境下用密碼學去證明共識的新技術,這是在互聯網上無法完成的事情,但要大規模的使用區塊鏈,我們要做的不是讓用戶在體驗上委曲求全,而是像 Lay2 團隊的 Frank 說的那樣:「我們需要一個能夠有能力去支持開發者‘開門迎客’的基礎設施」,讓區塊鏈不會因為底層設施的不靈活,而成為少數極客或圈內人的玩物,

公鏈如果能夠靈活的支持各種密碼學原語,讓開發者可以有更高的彈性,那么就更可以跳過「教育用戶」的這個緩慢的程序,因為就和互聯網一樣,雖然現在大家都是無網不歡的人,但對于純粹的 C 端用戶而言,他們依舊不需要知道互聯網到底分了幾層,或者 P2P 網路是怎么回事,

同樣的,區塊鏈的純 C 端用戶在使用區塊鏈技術時也不需要知道區塊鏈的底層知識,我們要做的是打造一個可以擁有互聯網體驗,又有區塊鏈的憑證,以及安全和去中心化等加成效果的基礎設施,而具有高度編程靈活性的 Nervos CKB 正在這條道路上奮勇向前!

在這里插入圖片描述

感謝 Lay2 的知縣,SECBIT 的志鵬,史迪仔等人對本篇文章的意見和啟發

Source:
https://ethresear.ch/t/when-do-we-need-cryptography-in-blockchain-space/7450
https://github.com/ethereum/go-ethereum/blob/a5eee8d1dc61352c29b9800eaf96609ba4184fd6/core/vm/contracts.go#L39-L78
https://medium.com/cryptocow/%E4%BB%A5%E5%A4%AA%E5%9D%8A-istanbul-%E7%A1%AC%E5%88%86%E5%8F%89%E5%85%A7%E5%AE%B9%E4%BB%8B%E7%B4%B9-4e0a37fa420c

// 如果你喜歡 Nervos 并且喜歡開發
// 你可以關注并私信我哦~
if (you like Nervos && you like dev) {
	println("you can follow me and private letter for me~");
}

轉載請註明出處,本文鏈接:https://www.uj5u.com/qukuanlian/232504.html

標籤:區塊鏈

上一篇:適用于ubuntu18的Hyperledger-fabric2020年最新版2.3.0環境搭建

下一篇:【完整版】區塊鏈錢包開發之monero(XMR)門羅幣踩坑經驗

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • JAVA使用 web3j 進行token轉賬

    最近新學習了下區塊鏈這方面的知識,所學不多,給大家分享下。 # 1. 關于web3j web3j是一個高度模塊化,反應性,型別安全的Java和Android庫,用于與智能合約配合并與以太坊網路上的客戶端(節點)集成。 # 2. 準備作業 jdk版本1.8 引入maven <dependency> < ......

    uj5u.com 2020-09-10 03:03:06 more
  • 以太坊智能合約開發框架Truffle

    前言 部署智能合約有多種方式,命令列的瀏覽器的渠道都有,但往往跟我們程式員的風格不太相符,因為我們習慣了在IDE里寫了代碼然后打包運行看效果。 雖然現在IDE中已經存在了Solidity插件,可以撰寫智能合約,但是部署智能合約卻要另走他路,沒辦法進行一個快捷的部署與測驗。 如果團隊管理的區塊節點多、 ......

    uj5u.com 2020-09-10 03:03:12 more
  • 谷歌二次驗證碼成為區塊鏈專用安全碼,你怎么看?

    前言 谷歌身份驗證器,前些年大家都比較陌生,但隨著國內互聯網安全的加強,它越來越多地出現在大家的視野中。 比較廣泛接觸的人群是國際3A游戲愛好者,游戲盜號現象嚴重+國外賬號安全應用廣泛,這類游戲一般都會要求用戶系結名為“兩步驗證”、“雙重驗證”等,平臺一般都推薦用谷歌身份驗證器。 后來區塊鏈業務風靡 ......

    uj5u.com 2020-09-10 03:03:17 more
  • 密碼學DAY1

    目錄 ##1.1 密碼學基本概念 密碼在我們的生活中有著重要的作用,那么密碼究竟來自何方,為何會產生呢? 密碼學是網路安全、資訊安全、區塊鏈等產品的基礎,常見的非對稱加密、對稱加密、散列函式等,都屬于密碼學范疇。 密碼學有數千年的歷史,從最開始的替換法到如今的非對稱加密演算法,經歷了古典密碼學,近代密 ......

    uj5u.com 2020-09-10 03:03:50 more
  • 密碼學DAY1_02

    目錄 ##1.1 ASCII編碼 ASCII(American Standard Code for Information Interchange,美國資訊交換標準代碼)是基于拉丁字母的一套電腦編碼系統,主要用于顯示現代英語和其他西歐語言。它是現今最通用的單位元組編碼系統,并等同于國際標準ISO/IE ......

    uj5u.com 2020-09-10 03:04:50 more
  • 密碼學DAY2

    ##1.1 加密模式 加密模式:https://docs.oracle.com/javase/8/docs/api/javax/crypto/Cipher.html ECB ECB : Electronic codebook, 電子密碼本. 需要加密的訊息按照塊密碼的塊大小被分為數個塊,并對每個塊進 ......

    uj5u.com 2020-09-10 03:05:42 more
  • NTP時鐘服務器的特點(京準電子)

    NTP時鐘服務器的特點(京準電子) NTP時鐘服務器的特點(京準電子) 京準電子官V——ahjzsz 首先對時間同步進行了背景介紹,然后討論了不同的時間同步網路技術,最后指出了建立全球或區域時間同步網存在的問題。 一、概 述 在通信領域,“同步”概念是指頻率的同步,即網路各個節點的時鐘頻率和相位同步 ......

    uj5u.com 2020-09-10 03:05:47 more
  • 標準化考場時鐘同步系統推進智能化校園建設

    標準化考場時鐘同步系統推進智能化校園建設 標準化考場時鐘同步系統推進智能化校園建設 安徽京準電子科技官微——ahjzsz 一、背景概述隨著教育事業的快速發展,學校建設如雨后春筍,隨之而來的學校教育、管理、安全方面的問題成了學校管理人員面臨的最大的挑戰,這些問題同時也是學生家長所擔心的。為了讓學生有更 ......

    uj5u.com 2020-09-10 03:05:51 more
  • 位元幣入門

    引言 位元幣基本結構 位元幣基礎知識 1)哈希演算法 2)非對稱加密技術 3)數字簽名 4)MerkleTree 5)哪有位元幣,有的是UTXO 6)位元幣挖礦與共識 7)區塊驗證(共識) 總結 引言 上一篇我們已經知道了什么是區塊鏈,此篇說一下區塊鏈的第一個應用——位元幣。其實先有位元幣,后有的區塊 ......

    uj5u.com 2020-09-10 03:06:15 more
  • 北斗對時服務器(北斗對時設備)電力系統應用

    北斗對時服務器(北斗對時設備)電力系統應用 北斗對時服務器(北斗對時設備)電力系統應用 京準電子科技官微(ahjzsz) 中國北斗衛星導航系統(英文名稱:BeiDou Navigation Satellite System,簡稱BDS),因為是目前世界范圍內唯一可以大面積提供免費定位服務的系統,所以 ......

    uj5u.com 2020-09-10 03:06:20 more
最新发布
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:46:47 more
  • Hyperledger Fabric 使用 CouchDB 和復雜智能合約開發

    在上個實驗中,我們已經實作了簡單智能合約實作及客戶端開發,但該實驗中智能合約只有基礎的增刪改查功能,且其中的資料管理功能與傳統 MySQL 比相差甚遠。本文將在前面實驗的基礎上,將 Hyperledger Fabric 的默認資料庫支持 LevelDB 改為 CouchDB 模式,以實作更復雜的資料... ......

    uj5u.com 2023-04-16 07:28:31 more
  • .NET Core 波場鏈離線簽名、廣播交易(發送 TRX和USDT)筆記

    Get Started NuGet You can run the following command to install the Tron.Wallet.Net in your project. PM> Install-Package Tron.Wallet.Net 配置 public reco ......

    uj5u.com 2023-04-14 08:08:00 more
  • DKP 黑客分析——不正確的代幣對比率計算

    概述: 2023 年 2 月 8 日,針對 DKP 協議的閃電貸攻擊導致該協議的用戶損失了 8 萬美元,因為 execute() 函式取決于 USDT-DKP 對中兩種代幣的余額比率。 智能合約黑客概述: 攻擊者的交易:0x0c850f,0x2d31 攻擊者地址:0xF38 利用合同:0xf34ad ......

    uj5u.com 2023-04-07 07:46:09 more
  • Defi開發簡介

    Defi開發簡介 介紹 Defi是去中心化金融的縮寫, 是一項旨在利用區塊鏈技術和智能合約創建更加開放,可訪問和透明的金融體系的運動. 這與傳統金融形成鮮明對比,傳統金融通常由少數大型銀行和金融機構控制 在Defi的世界里,用戶可以直接從他們的電腦或移動設備上訪問廣泛的金融服務,而不需要像銀行或者信 ......

    uj5u.com 2023-04-05 08:01:34 more
  • solidity簡單的ERC20代幣實作

    // SPDX-License-Identifier: GPL-3.0 pragma solidity >=0.7.0 <0.9.0; import "hardhat/console.sol"; //ERC20 同質化代幣,每個代幣的本質或性質都是相同 //ETH 是原生代幣,它不是ERC20代幣, ......

    uj5u.com 2023-03-21 07:56:29 more
  • solidity 參考型別修飾符memory、calldata與storage 常量修飾符C

    在solidity語言中 參考型別修飾符(參考型別為存盤空間不固定的數值型別) memory、calldata與storage,它們只能修飾參考型別變數,比如字串、陣列、位元組等... memory 適用于方法傳參、返參或在方法體內使用,使用完就會清除掉,釋放記憶體 calldata 僅適用于方法傳參 ......

    uj5u.com 2023-03-08 07:57:54 more
  • solidity注解標簽

    在solidity語言中 注釋符為// 注解符為/* 內容*/ 或者 是 ///內容 注解中含有這幾個標簽給予我們使用 @title 一個應該描述合約/介面的標題 contract, library, interface @author 作者的名字 contract, library, interf ......

    uj5u.com 2023-03-08 07:57:49 more
  • 評價指標:相似度、GAS消耗

    【代碼注釋自動生成方法綜述】 這些評測指標主要來自機器翻譯和文本總結等研究領域,可以評估候選文本(即基于代碼注釋自動方法而生成)和參考文本(即基于手工方式而生成)的相似度. BLEU指標^[^?88^^?^]^:其全稱是bilingual evaluation understudy.該指標是最早用于 ......

    uj5u.com 2023-02-23 07:27:39 more
  • 基于NOSTR協議的“公有制”版本的Twitter,去中心化社交軟體Damus

    最近,一個幽靈,Web3的幽靈,在網路游蕩,它叫Damus,這玩意詮釋了什么叫做病毒式營銷,滑稽的是,一個Web3產品卻在Web2的產品鏈上瘋狂傳銷,各方大佬紛紛為其背書,到底發生了什么?Damus的葫蘆里,賣的是什么藥? 注冊和簡單實用 很少有什么產品在用戶注冊環節會有什么噱頭,但Damus確實出 ......

    uj5u.com 2023-02-05 06:48:39 more