摘要:本文解釋了比特幣交易的內(nèi)容,目的和結(jié)果。本文底部的信息圖提供了從錢包到區(qū)塊鏈的整個比特幣交易流程的全面說明。在文本中使用的任何地方是比特幣交易的縮寫。目的比特幣交易的目的是將一定數(shù)量的比特幣的所有權(quán)轉(zhuǎn)移到比特幣地址。
本文解釋了比特幣交易的內(nèi)容,目的和結(jié)果。下面的解釋適用于新手和中級比特幣用戶。
作為加密貨幣用戶,你需要熟悉交易雛形——為了你對這種不斷發(fā)展的創(chuàng)新有信心,以及作為理解新興多簽名交易和合約的基礎(chǔ),這兩者都將在本系列的后期進行探討。這不是純技術(shù)文章,解釋將集中在你需要了解的標準比特幣交易——我們通常做的支出交易——并且我們將掩蓋你可以安全忽略的內(nèi)容。
本文底部的信息圖提供了從錢包到區(qū)塊鏈的整個比特幣交易流程的全面說明。
注意:即使是核心開發(fā)人員也承認,用于描述交易及其組件的某些語言可能導(dǎo)致人們誤解了實際發(fā)生的事情。在下面的解釋中避免了這些誤解。因此,在嘗試盡可能簡單的描述的同時,借助一些圖表,讓我們直接開始。
術(shù)語和縮寫的定義Bitcoin:具有大寫B的比特幣指的是協(xié)議——代碼,節(jié)點,網(wǎng)絡(luò)及其對等交互。
bitcoin:用小寫字母b表示貨幣——我們通過比特幣網(wǎng)絡(luò)發(fā)送和接收的加密貨幣。
tx:在文本中使用的任何地方——是比特幣交易‘Bitcoin transaction的縮寫。
txid:是transaction id的縮寫——這是人和協(xié)議引用交易的哈希。
Script:是比特幣協(xié)議的腳本系統(tǒng)的名稱,用于處理和驗證交易——腳本是一個聰明的,基于堆棧的指令引擎,它使得從簡單支付到復(fù)雜的oracle監(jiān)督合約的所有交易成為可能。
UTXO:Unspent Transaction Output的縮寫,也稱為“輸出”。
satoshi:1 BTC = 100,000,000 satoshi
什么是比特幣交易?為什么?1.定義
比特幣交易是一個經(jīng)過簽名的數(shù)據(jù),它被廣播到網(wǎng)絡(luò)上,如果有效,最終會進入?yún)^(qū)塊鏈的一個區(qū)塊。
2.目的
比特幣交易的目的是將一定數(shù)量的比特幣的所有權(quán)轉(zhuǎn)移到比特幣地址。
3.結(jié)果
當(dāng)你發(fā)送比特幣時,你的錢包客戶端會創(chuàng)建一個單一的數(shù)據(jù)結(jié)構(gòu),即比特幣交易,然后廣播到網(wǎng)絡(luò)。網(wǎng)絡(luò)上的比特幣節(jié)點將中繼和重新廣播交易,如果交易有效,節(jié)點將把它包含在他們正在挖掘的塊中。通常,在10-20分鐘內(nèi),交易將與區(qū)塊鏈中的一個區(qū)塊中的其他交易一起被包括在內(nèi)。此時接收者能夠看到他們錢包中的交易金額。
4.例子
以下是今年早些時候區(qū)塊鏈中包含的示例交易:
此標準交易的主要組成部分采用顏色編碼:
交易ID(以黃色突出顯示)
描述符和元數(shù)據(jù)(藍色花括號在右邊詳細說明)
輸入(粉色區(qū)域)
輸出(綠色區(qū)域)
比特幣交易輸入和輸出首先,關(guān)于交易的四個公理:
我們發(fā)送的任何比特幣金額總是發(fā)送到一個地址。
我們收到的任何比特幣金額都被鎖定在接收地址——這通常與我們的錢包相關(guān)聯(lián)。
每當(dāng)我們花費比特幣時,我們花費的金額將始終來自之前收到的并且目前存在于我們錢包中的資金。
地址接收比特幣,但他們不發(fā)送比特幣——比特幣是從錢包發(fā)送的。
進入我們錢包的金額并不像實體錢包中的硬幣那樣混亂。收到的金額不會混合,但保持獨立且與錢包收到的確切金額不同。這是一個例子:
示例:
你創(chuàng)建一個全新的錢包,并及時收到三個0.01,0.2和3BTC的金額,如下所示:你將3BTC發(fā)送到與錢包相關(guān)聯(lián)的地址,并由Alice向另一個地址付款。
錢包報告的余額為3.21BTC,但如果你真的看錢包里面,你會看到——不是321,000,000 satoshi(321 mil satoshi),但是三個不同的數(shù)量仍然由他們的原始交易組合在一起:0.01,0.2和3BTC。
收到的比特幣金額不會混合,但保持分開,作為發(fā)送到錢包的確切金額。上例中的三個金額稱為其原始交易的輸出。
比特幣錢包始終保持輸出分離和獨特。
輸出output是(通過標準交易)發(fā)送到比特幣地址的金額,以及解鎖輸出金額的一組規(guī)則。在比特幣用語中,輸出稱為“未使用的交易輸出”或UTXO。
可以使用與接收地址相關(guān)聯(lián)的私鑰解鎖標準交易輸出。地址及其相關(guān)的公鑰/私鑰對將在本系列的后面部分介紹。目前,我們只關(guān)注總數(shù)。
示例:
讓我們考慮一個例子,在你向Bob發(fā)送0.15BTC的情況下跟蹤錢。
正如我們所看到的,你的錢包沒有選擇15mil miloshi(0.15 BTC)來自一個無差別的321 mil satoshi組成錢包余額。相反,錢包從錢包中包含的三個現(xiàn)有輸出outputs中選擇一個支出候選者。因此,它選擇(由于各種原因,現(xiàn)在不重要)0.2BTC輸出。錢包將解鎖0.2 BTC輸出并使用全部0.2BTC作為新的0.15 BTC交易的輸入input。0.2BTC輸出在此過程中花費spent。
你的錢包創(chuàng)建的花費交易將向Bob的地址發(fā)送0.15BTC——它將作為輸出存放在他的錢包中——等待最終花費。
0.05BTC差額(0.2 BTC輸入減去0.15 BTC輸出)稱為改變change,交易將通過新創(chuàng)建的地址將其發(fā)送回你的錢包。0.05 BTC改變的金額將作為新輸出存放在你的錢包中——等待最終花費。所以,現(xiàn)在你錢包里會顯示以下內(nèi)容:
“等待花費”的三個輸出中的每一個被鎖定到其接收地址,直到選擇它們中的一個或多個作為新花費交易的輸入為止。
在后臺,當(dāng)選擇UTXO作為新交易的輸入時,不同的錢包客戶端應(yīng)用不同的邏輯規(guī)則。一個理智的錢包策略是盡可能先使用舊的UTXO,但實現(xiàn)方式不同。我們現(xiàn)在并不關(guān)注選擇UTXO的方式,因為我們的目標一直是強調(diào)我們的錢包收到的金額是分開的和不同的。
比特幣交易如何完成的總結(jié)各種收到的金額不會像在實體錢包中那樣混合。相反,在我們花費比特幣時,收到的金額(UTXO)被多帶帶使用(或組合使用)。在創(chuàng)建支出交易時,我們的錢包選擇UTXO(具有足夠的價值以滿足我們想要發(fā)送的金額)并且通常創(chuàng)建兩個新輸出:一個用于接收器,一個用于我們收到的更改到錢包。更改成為我們錢包中的全新UTXO,我們發(fā)送的金額成為鎖定到收件人地址的UTXO——可能與錢包相關(guān)聯(lián),也可能不與錢包相關(guān)聯(lián),例如冷存儲。用作支出交易的輸入的原始UTXO將“花費”并永久銷毀。
這是錢包軟件如何處理輸出(UTXO)的介紹。一旦選擇了UTXO用于支出,它就需要與接收它的地址相關(guān)聯(lián)的私鑰。此私鑰兌換UTXO并允許它成為新支出交易中的輸入。以前的交易輸出被重新用作新交易的輸入的機制是比特幣協(xié)議功能的核心——完全符合Satoshi的設(shè)計。
建議你瀏覽我們匯智網(wǎng)的各種編程語言的區(qū)塊鏈教程和區(qū)塊鏈技術(shù)博客,深入了解區(qū)塊鏈,比特幣,加密貨幣,以太坊,和智能合約。
java比特幣開發(fā)教程,本課程面向初學(xué)者,內(nèi)容即涵蓋比特幣的核心概念,例如區(qū)塊鏈存儲、去中心化共識機制、密鑰與腳本、交易與UTXO等,同時也詳細講解如何在Java代碼中集成比特幣支持功能,例如創(chuàng)建地址、管理錢包、構(gòu)造裸交易等,是Java工程師不可多得的比特幣開發(fā)學(xué)習(xí)課程。
php比特幣開發(fā)教程,本課程面向初學(xué)者,內(nèi)容即涵蓋比特幣的核心概念,例如區(qū)塊鏈存儲、去中心化共識機制、密鑰與腳本、交易與UTXO等,同時也詳細講解如何在Php代碼中集成比特幣支持功能,例如創(chuàng)建地址、管理錢包、構(gòu)造裸交易等,是Php工程師不可多得的比特幣開發(fā)學(xué)習(xí)課程。
php以太坊,主要是介紹使用php進行智能合約開發(fā)交互,進行賬號創(chuàng)建、交易、轉(zhuǎn)賬、代幣開發(fā)以及過濾器和交易等內(nèi)容。
java以太坊開發(fā)教程,主要是針對java和android程序員進行區(qū)塊鏈以太坊開發(fā)的web3j詳解。
以太坊入門教程,主要介紹智能合約與dapp應(yīng)用開發(fā),適合入門。
以太坊開發(fā)進階教程,主要是介紹使用node.js、mongodb、區(qū)塊鏈、ipfs實現(xiàn)去中心化電商DApp實戰(zhàn),適合進階。
python以太坊,主要是針對python工程師使用web3.py進行區(qū)塊鏈以太坊開發(fā)的詳解。
C#以太坊,主要講解如何使用C#開發(fā)基于.Net的以太坊應(yīng)用,包括賬戶管理、狀態(tài)與交易、智能合約開發(fā)與交互、過濾器和交易等。
EOS入門教程,本課程幫助你快速入門EOS區(qū)塊鏈去中心化應(yīng)用的開發(fā),內(nèi)容涵蓋EOS工具鏈、賬戶與錢包、發(fā)行代幣、智能合約開發(fā)與部署、使用代碼與智能合約交互等核心知識點,最后綜合運用各知識點完成一個便簽DApp的開發(fā)。
匯智網(wǎng)原創(chuàng)翻譯,轉(zhuǎn)載請標明出處。這里是原文
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/24339.html
摘要:創(chuàng)建比特幣錢包需要一組優(yōu)秀的程序員。如何使用流行的庫構(gòu)建自己的比特幣錢包應(yīng)用程序創(chuàng)建比特幣錢包應(yīng)用程序的一種方法是依賴現(xiàn)有工具。具有以下功能它允許開發(fā)人員使用密碼加密創(chuàng)建比特幣錢包應(yīng)用程序。 盡管目前加密貨幣市場相當(dāng)黯淡,但比特幣和其他山寨幣繼續(xù)受歡迎。每天都有新的交易者加入市場,希望能夠在下一個價格高漲時獲利。 隨著市場的突飛猛進,開發(fā)商也在獲益。新交易者的首要任務(wù)是設(shè)置比特幣錢包。...
摘要:創(chuàng)建比特幣錢包需要一組優(yōu)秀的程序員。如何使用流行的庫構(gòu)建自己的比特幣錢包應(yīng)用程序創(chuàng)建比特幣錢包應(yīng)用程序的一種方法是依賴現(xiàn)有工具。具有以下功能它允許開發(fā)人員使用密碼加密創(chuàng)建比特幣錢包應(yīng)用程序。 盡管目前加密貨幣市場相當(dāng)黯淡,但比特幣和其他山寨幣繼續(xù)受歡迎。每天都有新的交易者加入市場,希望能夠在下一個價格高漲時獲利。 隨著市場的突飛猛進,開發(fā)商也在獲益。新交易者的首要任務(wù)是設(shè)置比特幣錢包。...
摘要:書接上回區(qū)塊鏈筆記基礎(chǔ)概念掃盲,我們討論了關(guān)于比特幣以及區(qū)塊鏈的許多基礎(chǔ)概念,可能通過我略帶類比的描述,讓你初步有了一些概念,但是對于一個比特幣到底長什么樣以及如何使用比特幣進行交易可能還不是很清楚,說的直白點就是聽過豬叫,但沒吃過豬肉。 解惑是每個人都在走的一條路,可誰又能解這漫漫無期呢?路上總是麻醉的人多,釋懷的人少。 書接上回區(qū)塊鏈筆記(1)基礎(chǔ)概念掃盲,我們討論了關(guān)于比特幣以及...
摘要:比特幣的到帳時間是個區(qū)塊的高度,約分鐘。請注意,比特幣與的地址是一樣的。 showImg(https://segmentfault.com/img/remote/1460000018378805?w=1200&h=659); 方案一: 通過ExinCore API進行幣幣交易 Exincore 提供了基于Mixin Network的幣幣交易API. 你可以支付USDT給ExinCore...
摘要:比特幣的到帳時間是個區(qū)塊的高度,約分鐘。請注意,比特幣與的地址是一樣的。 showImg(https://segmentfault.com/img/remote/1460000018419614?w=1200&h=659); 方案一: 通過ExinCore API進行幣幣交易 Exincore 提供了基于Mixin Network的幣幣交易API. 你可以支付USDT給ExinCore...
閱讀 870·2021-11-19 11:29
閱讀 3361·2021-09-26 10:15
閱讀 2872·2021-09-22 10:02
閱讀 2445·2021-09-02 15:15
閱讀 1981·2019-08-30 15:56
閱讀 2423·2019-08-30 15:54
閱讀 2928·2019-08-29 16:59
閱讀 645·2019-08-29 16:20