0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

通過這7個函數(shù)來探索區(qū)塊鏈

C語言專家集中營 ? 來源:工程師曾玲 ? 2019-02-02 14:04 ? 次閱讀

我想對很多人來說,區(qū)塊鏈是一種很難理解的技術(shù),雖然我也看了很多視頻和文章,但從我個人角度來講,直到我開始寫一些簡單的區(qū)塊鏈應(yīng)用,我才真正理解了它是什么以及它的潛在應(yīng)用。

我對區(qū)塊鏈的看法是,它是一個公開的加密數(shù)據(jù)庫。舉個例子,亞馬遜也許想利用這種技術(shù)來跟蹤庫存水平,那么使用區(qū)塊鏈?zhǔn)欠裼幸饬x呢?大概率沒有,因為消費者不會愿意花費資源來驗證亞馬遜的區(qū)塊鏈?zhǔn)欠窨尚校鼊e說亞馬遜總是在網(wǎng)站上宣稱商品“只剩最后一個!”。

關(guān)于區(qū)塊鏈未來可能的應(yīng)用場景留給您自己思考,廢話不多說,讓我們一起通過這7個函數(shù)來探索區(qū)塊鏈吧。

def hash_function(k):

"""Hashes our transaction."""

if type(k) is not str:

k = json.dumps(k, sort_keys=True)

return hashlib.sha256(k).hexdigest()

區(qū)塊鏈的核心是哈希函數(shù),如果不加密,區(qū)塊鏈將很容易被操縱,交易將能夠被欺騙性地插入到區(qū)塊鏈中。

def update_state(transaction, state):

state = state.copy()

for key in transaction:

if key in state.keys():

state[key] += transaction[key]

else:

state[key] = transaction[key]

return state

所謂的“狀態(tài)”是交易完成后的資產(chǎn)分配記錄。比如,我有10個幣,我把其中1個幣給了Medium,那么當(dāng)前的“狀態(tài)”就是如下字典中的值。

{‘transaction’: {‘Tom’: 9, ‘Medium’: 1}}

值得注意的是,在這個體系中,透支是不可能存在的。如果我只有10個幣,那么我不可能將11個幣給別人。下面的函數(shù)將驗證我們嘗試進行的交易確實是有效的。而且,交易必須平衡,我不可能給了對方5個幣,但他只收到4個幣,否則會引起幣的銷毀和創(chuàng)建。

def valid_transaction(transaction, state):

"""A valid transaction must sum to 0."""

if sum(transaction.values()) is not 0:

return False

for key in transaction.keys():

if key in state.keys():

account_balance = state[key]

else:

account_balance = 0

if account_balance + transaction[key] < 0:

return False

return True

現(xiàn)在我們可以構(gòu)建自己的區(qū)塊了。讀取上一個區(qū)塊的信息,并將其鏈接到下一個區(qū)塊,這也是區(qū)塊鏈的核心技術(shù)之一,看起來有效交易可以被欺詐性地插入到區(qū)塊鏈中,但是對前面所有的區(qū)塊進行解密在計算上幾乎是不可能的,這就保留了區(qū)塊鏈的完整性。

def make_block(transactions, chain):

"""Make a block to go into the chain."""

parent_hash = chain[-1]['hash']

block_number = chain[-1]['contents']['block_number'] + 1

block_contents = {

'block_number': block_number,

'parent_hash': parent_hash,

'transaction_count': block_number + 1,

'transaction': transactions

}

return {'hash': hash_function(block_contents), 'contents': block_contents}

下面是一個小小的幫助函數(shù),用于檢查前一個區(qū)塊的哈希值。

def check_block_hash(block):

expected_hash = hash_function(block['contents'])

if block['hash'] is not expected_hash:

raise

return

一旦我們把所有的東西整合起來,就是時候創(chuàng)建自己的區(qū)塊了。接下來我們將更新區(qū)塊鏈。

def check_block_validity(block, parent, state):

parent_number = parent['contents']['block_number']

parent_hash = parent['hash']

block_number = block['contents']['block_number']

for transaction in block['contents']['transaction']:

if valid_transaction(transaction, state):

state = update_state(transaction, state)

else:

raise

check_block_hash(block) # Check hash integrity

if block_number is not parent_number + 1:

raise

if block['contents']['parent_hash'] is not parent_hash:

raise

return state

在完成之前,區(qū)塊鏈必須經(jīng)過驗證:

def check_chain(chain):

"""Check the chain is valid."""

if type(chain) is str:

try:

chain = json.loads(chain)

assert (type(chain) == list)

except ValueError:

# String passed in was not valid JSON

return False

elif type(chain) is not list:

return False

state = {}

for transaction in chain[0]['contents']['transaction']:

state = update_state(transaction, state)

check_block_hash(chain[0])

parent = chain[0]

for block in chain[1:]:

state = check_block_validity(block, parent, state)

parent = block

return state

最后,需要一個交易函數(shù),將所有上述功能整合在一起:

def add_transaction_to_chain(transaction, state, chain):

if valid_transaction(transaction, state):

state = update_state(transaction, state)

else:

raise Exception('Invalid transaction.')

my_block = make_block(state, chain)

chain.append(my_block)

for transaction in chain:

check_chain(transaction)

return state, chain

現(xiàn)在我們有了7個函數(shù),那么怎樣使用它們呢?首先,我們需要一個創(chuàng)世塊來開始我們的區(qū)塊鏈,這也是新幣產(chǎn)生的開始。在這篇文章里,我將會從10個幣開始。

genesis_block = {

'hash': hash_function({

'block_number': 0,

'parent_hash': None,

'transaction_count': 1,

'transaction': [{'Tom': 10}]

}),

'contents': {

'block_number': 0,

'parent_hash': None,

'transaction_count': 1,

'transaction': [{'Tom': 10}]

},

}

block_chain = [genesis_block]

chain_state = {'Tom': 10}

那么,當(dāng)我將一些幣給Medium之后發(fā)生了什么呢?

chain_state, block_chain = add_transaction_to_chain(transaction={'Tom': -1, 'Medium': 1}, state=chain_state, chain=block_chain)

狀態(tài)”的值將會被更新為當(dāng)前各人擁有多少個幣:

{'Medium': 1, 'Tom': 9}

然后生成的區(qū)塊鏈會如下所示:

[{'contents': {'block_number': 0,

'parent_hash': None,

'transaction': [{'Tom': 10}],

'transaction_count': 1},

'hash': '064d0b480b3b92761f31831d30ae9f01954efaa62371b4b44f11465ec22abe93'},

{'contents': {'block_number': 1,

'parent_hash': '064d0b480b3b92761f31831d30ae9f01954efaa62371b4b44f11465ec22abe93',

'transaction': {'Medium': 1, 'Tom': 9},

'transaction_count': 2},

'hash': 'b4ae25f0cc0ee0b0caa66b9a3473e9a108652d53b1dc22a40962fef5c8c0f08c'}]

至此,我們的第一個交易已經(jīng)創(chuàng)建并被插入到堆棧的頂部?,F(xiàn)在,我希望這些已經(jīng)激起你的好奇心,并且有興趣將代碼復(fù)制下來跑一跑。在我看來,這是學(xué)習(xí)新技術(shù)的最佳途徑。

請嘗試運行代碼去創(chuàng)造自己的幣。思考一下,如果您想提供比現(xiàn)存更多的幣,會發(fā)生什么情況?如果您不斷創(chuàng)建新的收款人,會發(fā)生什么?

還有,您能想到區(qū)塊鏈在未來會被應(yīng)用到哪些場景呢?歡迎在評論中留言。


聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 區(qū)塊鏈
    +關(guān)注

    關(guān)注

    110

    文章

    15558

    瀏覽量

    105229

原文標(biāo)題:通過7個函數(shù)解密區(qū)塊鏈

文章出處:【微信號:C_Expert,微信公眾號:C語言專家集中營】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    區(qū)塊如何改變AI

    于決策、評估和理解某些模式和數(shù)據(jù)集,最終產(chǎn)生自主交互。人工智能和區(qū)塊共同擁有幾個特點,可以確保在不久的將來能夠?qū)崿F(xiàn)無縫互動。下面列出了三主要特點。I.人工智能和區(qū)塊
    發(fā)表于 02-27 14:01

    什么是區(qū)塊 區(qū)塊有什么用

    賬本的數(shù)據(jù)。同時,區(qū)塊還具有去中介化、信息透明等特點?!  ?b class='flag-5'>區(qū)塊技術(shù)本質(zhì)上是一種數(shù)據(jù)庫技術(shù),具體講就是一種賬本技術(shù)。賬本記錄一或多個賬
    發(fā)表于 03-26 11:31

    區(qū)塊不是泡沫 馬云或?qū)?chuàng)造新的神話

    那時候根本沒明白什么是區(qū)塊,但聽說東西能夠解決數(shù)據(jù)的安全和隱私,阿里巴巴就開始投入區(qū)塊。”同時馬云也強調(diào),
    發(fā)表于 05-18 18:10

    區(qū)塊在商業(yè)方面的應(yīng)用如何

    ,形成一數(shù)據(jù)記錄,通過區(qū)塊可以讓交易的各方交易過程更加透明,更方便對資金及物流進行監(jiān)管,避免虛假交易的產(chǎn)生。供應(yīng)金融管理應(yīng)用系統(tǒng)。 隨
    發(fā)表于 07-14 11:31

    區(qū)塊將改革供應(yīng)

    團隊攜手研發(fā)出區(qū)塊應(yīng)用系統(tǒng),它對于整個供應(yīng)的權(quán)益有以下幾點:1) 對于生產(chǎn)者:通過消費者對商品的購買數(shù)據(jù)以及零售商的銷售業(yè)績來推動生產(chǎn)者的進步,
    發(fā)表于 08-08 11:11

    區(qū)塊熱度不止,參考架構(gòu)9部分解密

    應(yīng)用。其中,區(qū)塊技術(shù)仍然處于實驗探索階段,各方對于區(qū)塊的概念、適用場景、架構(gòu)、技術(shù)特點、發(fā)展路線及治理與監(jiān)管尚未形成共識。比較常見的觀點
    發(fā)表于 09-06 17:48

    區(qū)塊技術(shù)開發(fā)公司談區(qū)塊賺錢滿足人哪些需求

    在日常生活中需要什么?  第一,利益保護需求  我們知道的區(qū)塊是賺錢的,它所使用的整個系統(tǒng)是非常安全的。因為每個人都會建立自己的制度來最大化自己的利益。當(dāng)我們在區(qū)塊中賺錢時,我們可
    發(fā)表于 11-19 17:14

    淺談區(qū)塊對銀行業(yè)的發(fā)展

    `區(qū)塊軟件談區(qū)塊對銀行業(yè)的發(fā)展前者是通過人來記賬,后者則是通過計算機來記賬。因為人太“聰明”
    發(fā)表于 11-19 17:19

    區(qū)塊將如何優(yōu)化產(chǎn)業(yè)?

    ,他供應(yīng)了各種開發(fā)言語(相似JAVA等)幫忙開發(fā)者開發(fā)或許將原有的一些互聯(lián)網(wǎng)運用移植再造到去中心化的網(wǎng)絡(luò)構(gòu)建中。所以,整個區(qū)塊的工業(yè)開端衍生出了各個不同的生態(tài)層次。  區(qū)塊
    發(fā)表于 12-13 15:19

    區(qū)塊對我們的生活有什么影響

    未來是光明的,它是由區(qū)塊驅(qū)動的。區(qū)塊技術(shù)已經(jīng)通過顛覆性的應(yīng)用程序改變了金融行業(yè),但金融業(yè)只是冰山一角。
    發(fā)表于 07-10 04:20

    區(qū)塊+從全球50案例看區(qū)塊的應(yīng)用與未來》高清pdf

    技術(shù)發(fā)展到今天,已經(jīng)進入了一全新的時代:由信息互聯(lián)逐步發(fā)展至價值互聯(lián),而實現(xiàn)關(guān)鍵轉(zhuǎn)變需要一種能適用于全球的底層價值互聯(lián)網(wǎng)技術(shù)。在這個背景下,區(qū)塊技術(shù)以“安全、公開、透明、數(shù)據(jù)不可
    發(fā)表于 03-13 00:42

    區(qū)塊錢包軟件開發(fā),區(qū)塊錢包源碼搭建

    什么是區(qū)塊錢包?區(qū)塊錢包本質(zhì)上是一工具,目前絕大多數(shù)的區(qū)塊
    發(fā)表于 05-26 16:30

    區(qū)塊分成兩部分, 一區(qū)塊,一

    了上一區(qū)塊的HASH值(通過散列函數(shù)變換的散列值)和本區(qū)塊的HASH值。本區(qū)塊的HASH,又在
    發(fā)表于 03-20 08:55

    什么是區(qū)塊?區(qū)塊都有哪些應(yīng)用?

    什么是區(qū)塊?區(qū)塊未來的應(yīng)用前景怎樣?
    發(fā)表于 06-28 09:20

    用不到50行的 Python 2.x代碼實現(xiàn)一簡單的區(qū)塊

    現(xiàn)在我們可以創(chuàng)建創(chuàng)世區(qū)塊了,我們需要一函數(shù)來生成該區(qū)塊中的后繼區(qū)塊。該
    的頭像 發(fā)表于 03-29 15:29 ?5840次閱讀
    用不到50行的 Python 2.x代碼實現(xiàn)一<b class='flag-5'>個</b>簡單的<b class='flag-5'>區(qū)塊</b><b class='flag-5'>鏈</b>