“学习区块链的最快方法就是自己亲手搭建一个”
本文接上篇:手把手教你搭建区块链(上)
“了解工作量证明”
工作量证明算法(PoW)是在区块链上创建或挖掘新区块的方式。
PoW的目标是发现可以解决问题的数字。从计算机的角度来讲,该数字必须既要很难找到又要易于验证。这是工作量证明的核心思想。
我们将看一个非常简单的示例来帮助您深入了解,某个整数x乘以另一个y的哈希必须以0结尾的函数表达为:
hash(x * y)= ac23dc…0
对于这个示例,让我们设x = 5,则代码如下:
from hashlib import sha256
x = 5
y = 0 # We don’t know what y should be yet…
while sha256(f’{x*y}’.encode()).hexdigest()[-1] != “0”:
y += 1
print(f’The solution is y = {y}’)
运行代码后的结果为y =21(产生的哈希以0结尾)
hash(5 * 21) = 1253e9373e…5e3600155e860
在比特币中,工作量证明算法称为Hashcash。,与我们刚才运行的基本示例代码并没有太大不同。这就是矿工竞相创建新区块的算法。通常,难度由字符串中搜索的字符数决定。通过在transaction中获得btc,矿工获得了解题的奖励,整个网络也能够轻松验证其答案。
让我们为我们上一篇文章中搭建的区块链实现类似的算法,例如:找到一个数字p,当该数字与上一个块的答案进行哈希运算时,会产生一个带有4个前导0的哈希值
import hashlib
import json
from time import time
from uuid import uuid4
class Blockchain(object):
…