www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當(dāng)前位置:首頁 > 物聯(lián)網(wǎng) > 區(qū)塊鏈
[導(dǎo)讀] 這里我們討論的是區(qū)塊鏈。區(qū)塊鏈上所定義的協(xié)議不僅是要交易數(shù)據(jù)而且還要交易數(shù)據(jù)的價(jià)值。目前的主要方式是在互聯(lián)網(wǎng)出現(xiàn)之前發(fā)明的,它需要使用一個(gè)集中的票據(jù)交易所。機(jī)器有時(shí)需要等待四天才能將付款從一個(gè)地

這里我們討論的是區(qū)塊鏈。區(qū)塊鏈上所定義的協(xié)議不僅是要交易數(shù)據(jù)而且還要交易數(shù)據(jù)的價(jià)值。目前的主要方式是在互聯(lián)網(wǎng)出現(xiàn)之前發(fā)明的,它需要使用一個(gè)集中的票據(jù)交易所。機(jī)器有時(shí)需要等待四天才能將付款從一個(gè)地方轉(zhuǎn)移到另一個(gè)地方,但在所有其他方面,機(jī)器之間的通信速度又是驚人的。比如他們可以互相發(fā)送小額支付。但必須要滿足電力、存儲(chǔ)空間和計(jì)算等資源的情況下才能立即進(jìn)行交易。

比特幣和其他加密貨幣作為價(jià)值轉(zhuǎn)移的第五個(gè)協(xié)議層,其底層技術(shù)稱為區(qū)塊鏈。區(qū)塊鏈?zhǔn)状卧试S機(jī)器同意價(jià)值轉(zhuǎn)移而不必相信一個(gè)中央權(quán)力機(jī)構(gòu),在現(xiàn)實(shí)世界中如果我創(chuàng)建一個(gè)“我”,就只有我擁有它,但如果我創(chuàng)建了一個(gè)數(shù)字圖像,那么在互聯(lián)網(wǎng)上其他人就可以復(fù)制它,然后我們都擁有它,那么就沒有辦法證明其所有權(quán)。但區(qū)塊鏈讓我們以分散的方式達(dá)成共識(shí)層, 防止一個(gè)壞行為者謊稱擁有所有權(quán)。

讓我們用python構(gòu)建我們自己的簡(jiǎn)單區(qū)塊鏈,以更好地理解這個(gè)不可思議的數(shù)據(jù)結(jié)構(gòu)是如何工作的。為了簡(jiǎn)單起見, 讓我們定義一個(gè)塊是什么, 假設(shè)每個(gè)塊代表一個(gè)事務(wù), 一個(gè)值在兩臺(tái)計(jì)算機(jī)之間傳輸。想要查看下面的代碼并讀取, 就必須使用索引在創(chuàng)建時(shí)顯示區(qū)塊鏈中表示其順序的一組重要屬性來定義其自己類中的塊對(duì)象, 它將存儲(chǔ)由發(fā)件人定義的一些數(shù)據(jù)以及兩個(gè)數(shù)據(jù)哈希值,一個(gè)用于區(qū)塊鏈中的上一個(gè)哈希值, 一個(gè)用于它自己的哈希值, 塊需要哈希值的原因是因?yàn)楣V堤峁┝艘粋€(gè)唯一的 id, 并且它有驗(yàn)證數(shù)據(jù)完整性的能力。

class Block():

def __init __(self,params):

self.index = params.index

self.previous_hash = params.previous_hash

self.timestamp = params.TImestamp

self.data = params.data

self.hash = self.calc_hash()

我們使用流行的加密哈希算法sha-256來幫助從哈希函數(shù)中的每個(gè)塊生成256位簽名。為此,您必須導(dǎo)入hashlib。

def calc_hash(self):

return hashlib.sha256(str(self.params())。encode())。hexdigest()

塊是如何生成的?

用戶提供了一些數(shù)據(jù)在他們的事務(wù)中,所以我們可以使用它作為唯一的參數(shù)生成函數(shù),因?yàn)槲覀儽仨毇@取最后一塊才能完成工作。我們將使用最后一塊幫助尋找這一塊指數(shù)以及哈希值,我們還將給它一個(gè)時(shí)間戳。因此,每個(gè)生成的塊都通過存儲(chǔ)其的哈希值來指向前一個(gè)塊。

def generate_next_block(self,data):

index = len(self.blockchain_store)

previous_hash = self.latest_block()。hash

TImestamp = int(TIme.TIme())

params = block_params.BlockParams(index,previous_hash,timestamp,data)

new_block = block.Block(params)

self.blockchain_store.append(new_block)

它是一個(gè)叫做區(qū)塊鏈的塊

第一個(gè)生成的塊稱為genesis塊,我們將在預(yù)定義的屬性中硬編碼到它自己的函數(shù)中

def genesis_block(cls):

params = block_params.BlockParams.genesis_params()

return cls(params)

我們將使用它初始化區(qū)塊鏈,并將其存儲(chǔ)為內(nèi)存列表

def __init __(self):

self.blockchain_store = self.fetch_blockchain()

def latest_block(self):

return self.blockchain_store [-1]

def fetch_blockchain(self):

return [block.Block.genesis_block()]

記住我這里所說的塊哈希值既可以作為它的標(biāo)識(shí),也可以驗(yàn)證它的完整性。我們可以使用哈希值來判斷一個(gè)新生成的塊,并在給定一個(gè)新塊和上一個(gè)塊的聯(lián)系下查看是否有效,上一個(gè)塊也就是鏈中的最后一個(gè)塊。我們可以先查看正確的排序指數(shù),我們可以檢查以前的哈希值屬性,并將其匹配到已經(jīng)驗(yàn)證了過得前一個(gè)快,最后我們將計(jì)新塊的哈希值,確保其準(zhǔn)確無誤。

def receive_new_block(self, new_block):

previous_block = self.latest_block()

if not new_block.has_valid_index(previous_block):

print(‘invalid index’)

return

if not new_block.has_valid_previous_hash(previous_block):

print(‘invalid previous hash’)

return

if not new_block.has_valid_hash():

print(‘invalid hash’)

return

self.blockchain_store.append(new_block)

假設(shè)所有節(jié)點(diǎn)都存儲(chǔ)了區(qū)塊鏈的一個(gè)副本,我們需要一種方法來選擇在發(fā)生沖突時(shí)使用哪個(gè)區(qū)塊鏈。假設(shè)2個(gè)節(jié)點(diǎn)生成相同的塊數(shù),那么我們的解決方案是選擇具有最長(zhǎng)塊數(shù)的鏈,因?yàn)樗拇嬖跁r(shí)間更長(zhǎng)因此它更有可能是真實(shí)的區(qū)塊鏈。

def replace_chain(self,block:self.blockchain_store):

if self.is_valid_chain(blocks)和len(blocks)》 self.length:

self.blockchain_store = blocks

else:

self.log(“Recieved blockchain invalid”)

給出一個(gè)新的區(qū)塊鏈之后:我們將檢查如果是有效的編程方式,是不是就意味著它有用一個(gè)新塊的替換我們之前的塊,因?yàn)槊總€(gè)節(jié)點(diǎn)存儲(chǔ)一個(gè)區(qū)塊鏈的副本, 并且塊不斷生成事務(wù), 這樣每個(gè)節(jié)點(diǎn)就可以進(jìn)行廣播, 每當(dāng)它生成一個(gè)新的塊時(shí), 它就會(huì)連接到一個(gè)新的節(jié)點(diǎn),它可以將塊添加到其當(dāng)前鏈或整個(gè)區(qū)塊鏈中, 因此我們可以以封裝節(jié)點(diǎn)的方式, 以便用戶可以查詢其他節(jié)點(diǎn)創(chuàng)建一個(gè) http 服務(wù)器。

因此,用戶將通過HTTP請(qǐng)求控制節(jié)點(diǎn),它將通過對(duì)WebSockets與其他節(jié)點(diǎn)通信。這就是簡(jiǎn)單的區(qū)塊鏈我們要討論的一個(gè)關(guān)鍵特性是工作證明算法。

比特幣挖掘節(jié)點(diǎn)完成了一系列非常昂貴的計(jì)算, 以批準(zhǔn)每筆交易, 并獲得比特幣的計(jì)算工作, 以便生成一個(gè)新塊。但是生成新塊的前提必須是突破51%的攻擊,這才證明這個(gè)新的塊是有效的, 可以添加到區(qū)塊鏈中, 因此一個(gè)壞的行為者必須有更多的計(jì)算能力, 而不是一半的比特幣網(wǎng)絡(luò)。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉