比特幣交易所 比特幣交易所
Ctrl+D 比特幣交易所
ads

一文看懂比特幣的UTXO模型_OIN

Author:

Time:1900/1/1 0:00:00

1.目前的鏈用的都是哪些模型

以太坊,EOS,Solana這些大家所熟知的鏈都使用的是賬戶模型,甚至可以說90%以上的項目都使用的是賬戶模型,而只有一些老牌項目用的是UTXO模型,如,BTC,DOGE,LTC,當然也有一些比較新的項目也用的這個模型,如Layer2中使用OP方案的FUEL。2.什么是賬戶模型

簡單理解,就是銀行賬戶那套系統,比如銀行之間的轉賬,支付寶、微信的轉賬等等都屬于賬戶模型。下面我舉個栗子:假如A有100,B有100這時A給B轉賬50塊錢在系統中的表現形式就是A-50,B+50所以他們的余額A50,B150這是一筆轉賬。再假如,A還是有100,他要給100個新開戶的新人轉賬1元。這時需要A同時給100人轉賬1塊錢第1筆A-1,第1個人+1所以他們的余額A99,第1個人1第2筆A-1,第2個人+1所以他們的余額A98,第2個人1第3筆A-1,第3個人+1所以他們的余額A97,第3個人1以此類推......第100人A-1,第100個人+1所以他們的余額A0,第100個人1理論上要轉賬100次,而且下一次的轉賬都必須要先完成前一筆,不然賬戶余額就無法保證一致性,會混亂,有沒有多轉,余額夠不夠轉出等。理論上,隨著交易筆數的增長,執行所需要的時間就越多。3.什么是UTXO模型

Bitfinex投資智利加密貨幣交易所OrionX:5月24日消息,Bitfinex 投資智利加密貨幣交易所 OrionX,旨在布局拉丁美洲市場,本次投資金額未披露。OrionX 成立于 2017 年,在智利提供加密貨幣交易和錢包服務,并計劃擴展到秘魯、哥倫比亞和墨西哥。[2023/5/25 10:38:00]

前面也有提到,很多老牌主流用的是UTXO,而這個圈子的老祖宗比特幣也是用的UTXO模型,順便提一下,我們國家的發行的法定數字貨幣DCEP也是基于UTXO模型做的,所以這個模型必然有它的獨特之處。UTXO全稱UnspentTransactionOutput,意思是“未花費交易輸出”,他的模型簡單說有點像日常生活中的現金體系,舉個栗子:A有一個錢包,里面有1元面值,10元面值以及100元面值。A要給B、C、D分別1塊錢。A有三種方式第一種:拿出1元面值的錢給B第二種:拿出10元面值的錢給C,找回9元第三種:拿出100元面值的錢給D,找回99元這三種方式都可以把這次交易完成。再回到鏈上,想象一下這里每一個面值的錢其實就是一個鏈上UTXO,具體在使用過程中的UTXO并不是在轉移的,而是在不斷的銷毀和重建,例如:A用第二種方式給C轉錢,10元面值的UTXO會被銷毀,系統會重新印出一張1元面值和一張9元面值的UTXO,1元的給C,9元的還給A。第三種方式也同理,100元的銷毀,印出1張1元面值的和一張99元面值的UTXO,1元的給D,99元的還給A。這是UTXO和賬戶模型轉賬方式的不同,更牛逼的是,UTXO模型可以并行轉賬,因為余額是通過分散的UTXO存在的,所以每個面值其實可以同時轉賬給不同的人,上面三種方式是可以在一筆交易中同時完成的,因為不會涉及到賬戶一致性問題,每個UTXO都是單獨獨立計算的。我們在對比上面的賬戶模型,每一筆交易都必須依托于上一筆交易的完成,這其中的性能差距可想而知。這樣就理解為什么央行數字貨幣使用的是UTXO模型了,不然深圳怎么給5萬個錢包發送1000萬數字人民幣?再說回上面那個例子:A有100,他要給100個新開戶的新人轉賬1元。面值100的UTXO可以拆分成100個面值1塊錢的UTXO,然后在一筆交易中直接分給100個人,瞬間完成。總之,把UTXO的面值想象成更加靈活的現金,在鏈上不斷的銷毀和重建。想知道這個錢包地址到底有多少錢就需要統計底下有多少個余額的UTXO并求和。4.賬戶模型和UTXO的優缺點

美國銀行業存款連續第三周下降 貸款基本持平:金色財經報道,美國銀行業存款連續第三周下降,創近兩年來最低水平,延續為期一年的下滑態勢,因為客戶繼續轉向貨幣市場基金以求更高回報。貸款基本持平。美聯儲周五公布的數據顯示,截至5月10日當周,經季節性因素調整后的商業銀行存款減少264億美元,至17.1萬億美元。其下降主要集中在大型銀行。未經調整的存款下滑570億美元,前一周增加665億美元。經季節性因素調整后的商業銀行貸款減少33億美元。未經調整的貸款和租賃下降174億美元。(財聯社)[2023/5/20 15:14:54]

賬戶模型優點:合約以代碼形式保存在Account中,并且Account擁有自身狀態。這種模型具有更好的可編程性,容易開發人員理解,場景更廣泛。批量交易的成本較低。設想礦池向礦工支付手續費,UTXO中因為每個Input和Out都需要單獨Witnessscript或者Lockingscript,交易本身會非常大,簽名驗證和交易存儲都需要消耗鏈上寶貴的資源。而Account模型可以通過合約的方式極大的降低成本。賬戶模型缺點:Account模型交易之間沒有依賴性,需要解決重放問題。Ethereum是怎么解決的,我們清楚Ethereum是采用的是唯一的Nonce值的方法,每個交易Tx中有一個Nonce字段,對于每個用戶來說,這個Nonce都不能重復,從而避免了重放攻擊。對于實現閃電網絡/雷電網絡,Plasma等,用戶舉證需要更復雜的Proof證明機制,子鏈向主鏈進行狀態遷移需要更復雜的協議。UTXO優點:計算是在鏈外的,交易本身既是結果也是證明。節點只做驗證即可,不需要對交易進行額外的計算,也沒有額外的狀態存儲。交易本身的輸出UTXO的計算是在錢包完成的,這樣交易的計算負擔完全由錢包來承擔,一定程度上減少了鏈的負擔。除Coinbase交易外,交易的Input始終是鏈接在某個UTXO后面。交易無法被重放,并且交易的先后順序和依賴關系容易被驗證,交易是否被消費也容易被舉證。UTXO模型是無狀態的,更容易并發處理。對于P2SH類型的交易,具有更好的隱私性。交易中的Input是互不相關聯的,可以使用CoinJoin這樣的技術,來增加一定的隱私性。UTXO缺點:無法實現一些比較復雜的邏輯,可編程性差。對于復雜邏輯,或者需要狀態保存的合約,實現難度大,且狀態空間利用率比較低。當Input較多時,見證腳本也會增多。而簽名本身是比較消耗CPU和存儲空間的。5.賬戶模型和UTXO簡要區別有哪些

1inch與NEAR生態EVM擴容網絡Aurora集成:8月16日消息,DEX聚合器1inch宣布與NEAR生態EVM擴容網絡Aurora集成。Aurora是基于NEAR的以太坊Layer2擴展解決方案,與以太坊EVM兼容,通過彩虹橋,用戶可以在Aurora、NEAR和以太坊之間自由轉移資產。[2022/8/16 12:29:18]

賬戶余額賬戶模型:可以簡單明了的看到賬戶底下有多少錢。UTXO模型:統計該地址底下有多少個UTXO,把他們匯總起來的結果才是余額。當交易筆數指數級上升時賬戶模型:會越來越吃力。UTXO模型:天然支持高并發。從智能合約/開發者角度出發賬戶模型符合開發者的邏輯習慣,相對容易寫邏輯UTXO腳本編程較為復雜

VEB研究員建議俄羅斯發行黃金支持的Stablecoin:6月24日消息,俄羅斯國家發展公司(VEB)研究員建議俄羅斯發行由黃金支持的Stablecoin用于國際支付。據悉,VEB前身為國家開發銀行。(CoinDesk)[2022/6/24 1:27:56]

Tags:OINCOINPUTCOIcoinwatch手表價格nav-coinintelligencefogcomputerchainRockwood Coin

以太坊交易
DAOrayaki:DAO民主投票源頭與孔多塞悖論_MAKE

"民主必須是比兩只狼和一只羊投票決定晚餐吃什么更重要的東西"。拉斐爾·斯潘諾基——詹姆斯·博瓦德,《失去的權利:美國自由的毀滅》民主意味著參與投票.

1900/1/1 0:00:00
星球日報 | Gemini聯創致信DCG索要9億欠款;幣安完成對Gopax收購盡調(1月3日)_DAILY

頭條 Gemini聯創致信DCG創始人,要求其償還Earn用戶逾9億美元Odaily星球日報訊Gemini聯合創始人CameronWinklevoss代表其Earn產品超過34萬名用戶.

1900/1/1 0:00:00
2023年值得我們關注的10大潛力敘事_區塊鏈

現在有足夠多的項目在價格最底部,市值低得離譜。這使其有可能在2023年完成比較大的漲幅。另一方面,還有許多具有創新性未發幣的項目也將上線.

1900/1/1 0:00:00
GBTC將如何拖垮“DCG帝國”?_BTC

Odaily星球日報訊|Moni 2023新年伊始,加密貨幣交易所Gemini聯合創始人CameronWinklevoss就代表其平臺用戶向數字貨幣集團DigitalCurrencyGroup創.

1900/1/1 0:00:00
熊市之下cvxCRV出現負溢價,Convex為救場向cvxCRV分配更多權益_CVX

Curve的代幣模型非常具有代表性,各種聚合器、穩定幣項目方競爭性的將CRV代幣鎖定為veCRV,以確保與自身利益相關的礦池獲得更高的CRV挖礦獎勵,造成“CurveWar”.

1900/1/1 0:00:00
Uniswap在開發V4?可能為DeFi帶來什么變化?_UNI

原文作者:LincolnMurr、MaryLiu原文來源:比推BitpushNews最近,加密社區盛傳頂級去中心化交易所Uniswap正在開發其協議的下一版本UniV4.

1900/1/1 0:00:00
ads