国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

Ameya360的個人空間 http://www.qingdxww.cn/space-uid-143199.html [收藏] [復制] [RSS]

博客

一文告訴你區塊鏈中的“塊”的生成方式及函數代碼

已有 1064 次閱讀2019-1-16 13:17

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

比特幣和其他加密貨幣作為價值轉移的第五個協議層,其底層技術稱為區塊鏈。區塊鏈首次允許機器同意價值轉移而不必相信一個中央權力機構,在現實世界中如果我創建一個“我”,就只有我擁有它,但如果我創建了一個數字圖像,那么在互聯網上其他人就可以復制它,然后我們都擁有它,那么就沒有辦法證明其所有權。但區塊鏈讓我們以分散的方式達成共識層, 防止一個壞行為者謊稱擁有所有權。

讓我們用python構建我們自己的簡單區塊鏈,以更好地理解這個不可思議的數據結構是如何工作的。為了簡單起見, 讓我們定義一個塊是什么, 假設每個塊代表一個事務, 一個值在兩臺計算機之間傳輸。想要查看下面的代碼并讀取, 就必須使用索引在創建時顯示區塊鏈中表示其順序的一組重要屬性來定義其自己類中的塊對象, 它將存儲由發件人定義的一些數據以及兩個數據哈希值,一個用于區塊鏈中的上一個哈希值, 一個用于它自己的哈希值, 塊需要哈希值的原因是因為哈希值提供了一個唯一的 id, 并且它有驗證數據完整性的能力。

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來幫助從哈希函數中的每個塊生成256位簽名。為此,您必須導入hashlib。

def calc_hash(self):

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

塊是如何生成的?

用戶提供了一些數據在他們的事務中,所以我們可以使用它作為唯一的參數生成函數,因為我們必須獲取最后一塊才能完成工作。我們將使用最后一塊幫助尋找這一塊指數以及哈希值,我們還將給它一個時間戳。因此,每個生成的塊都通過存儲器的哈希值來指向前一個塊。

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)

它是一個叫做區塊鏈的塊

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

def genesis_block(cls):

params = block_params.BlockParams.genesis_params()

return cls(params)

我們將使用它初始化區塊鏈,并將其存儲為內存列表

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()]

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

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)

假設所有節點都存儲了區塊鏈的一個副本,我們需要一種方法來選擇在發生沖突時使用哪個區塊鏈。假設2個節點生成相同的塊數,那么我們的解決方案是選擇具有最長塊數的鏈,因為它的存在時間更長因此它更有可能是真實的區塊鏈。

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”)

給出一個新的區塊鏈之后:我們將檢查如果是有效的編程方式,是不是就意味著它有用一個新塊的替換我們之前的塊,因為每個節點存儲一個區塊鏈的副本, 并且塊不斷生成事務, 這樣每個節點就可以進行廣播, 每當它生成一個新的塊時, 它就會連接到一個新的節點,它可以將塊添加到其當前鏈或整個區塊鏈中, 因此我們可以以封裝節點的方式, 以便用戶可以查詢其他節點創建一個 http 服務器。

因此,用戶將通過HTTP請求控制節點,它將通過對WebSockets與其他節點通信。這就是簡單的區塊鏈我們要討論的一個關鍵特性是工作證明算法。

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

來源:網絡,如侵刪


路過

雞蛋

鮮花

握手

雷人

評論 (0 個評論)

facelist

您需要登錄后才可以評論 登錄 | 立即注冊

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯系我們
電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
返回頂部
主站蜘蛛池模板: 黄视频网站在线看 | 一本大道香蕉大vr在线吗视频 | 国产午夜精品一区二区三区不卡 | 久久国内免费视频 | 色欧美视频 | 日韩特级片| 久久婷五月天 | 99在线观看视频免费精品9 | 青青草原在线新免费 | 四虎欧美永久在线精品免费 | 男女啪啦猛视频免费 | 天天亚洲综合 | 久久久这里有精品999 | 黑人操白逼 | 一区二区三区在线 | 向日葵.app在线观看 | 国产aaaaaaa毛片| 亚洲午夜久久久久久噜噜噜 | 牛牛精品视频 | 亚洲欧美日韩一级特黄在线 | 韩国资源视频一区二区三区 | 色噜噜色噜噜天天拍一拍 | 精品视频一区二区 | 天堂在线观看视频观看www | 手机看片1204国内基地在线 | 国产小视频免费在线观看 | 欧美一区二区视频 | 久久国产成人午夜aⅴ影院 久久国产成人精品麻豆 | 亚色在线视频 | 日韩免费高清专区 | 国产在线91区精品 | 中文字幕手机在线视频 | 国产女同一区二区三区五区 | 国产毛片不卡 | 幻女free性zozo仙踪林 | 香蕉欧美成人精品a∨在线观看 | 免费观看污网站 | 色狍97| 免费视频色 | 国产3d动漫精品专区在线观看 | 99视频在线观看高清 |