區塊鏈之工作量證明
在整個區塊鏈中的作用
- 新的區塊依賴工作量證明算法(PoW)| Proof Of Work 來構造
理解
- PoW的目標是找出一個符合特定條件的數字,這個數字很難計算出來,但容易驗證。 這就是工作量證明的核心思想。
示例代碼
from hashlib import sha256
import time
def Pow_fun(x=5, y =0):
'''Pow算法函數
param: x=5 為原始信息
param: y=0 工作量初始值,通常為0
return : y 值越大,工作量也會越大
during_time
'''
strat_time = time.time()
while sha256('{0}*{1}'.format(x, y).encode()).hexdigest()[-4:0] != "0000": #預設條件:當0的位數越多,理論上,CPU在進行枚舉時所需要耗費的時間要更長,工作量也會越大
y += 1 #用來判斷Pow的量
end_time = time.time()
during_time = end_time - start_time
print(sha256('{0}*{1}'.format(x, y).encode()).hexdigest())
print('The solution is y = {}'.format(y))
print ("Working time:{}".format(during_time))
if __name__ == "__main__":
Pow_fun(x=5,y=0)
Pow扮演的成分--以比特幣說明
比特幣錢包是由私鑰和公鑰所組成的數據庫。比特幣本身是存儲在區塊鏈中的。用戶用私鑰來簽名交易,從而證明他們有這筆交易。當你用私鑰簽名一筆交易之后,那些交易里面提到的比特幣就會有記錄,這些記錄所有人都可以查詢。
- 礦工們則負責驗證這筆交易,同時也會收取一些費用,這個過程叫做 Proof of Work(POW,工作量證明)。
