• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Go实现Pow工作量证明

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

之前使用python编写了一段代码实现了工作量证明机制,近期由于参与以太坊智能合约开发钱包的工作接触到golang语言,所以借此以go来实现Pow(Proof of work).

  • 实现代码如下:

    // pow 工作量证明
    package main
    import (
    	"crypto/sha256"
    	"fmt"
    	"strconv"
    	"time"
    )
    
    func main() {
    	c := PowProcess("Haxima")
    	fmt.Println(c)
    }
    
    /* Pow working process
    设定条件:当hash后的值满足特定条件
    */
    
    func PowProcess(x string) string {
    	var i int
    	t1 := time.Now().UnixNano()
    	for i = 0; (HashString(x + strconv.Itoa(i)))[:4] != "0000"; i ++ {
    		fmt.Println(i)
    	}
    
    	fmt.Println(i)
    	fmt.Printf("Duration:%.3fs\n", float64((time.Now().UnixNano()-t1)/1e6)/1000)
    	return HashString(x + strconv.Itoa(i))
    }
    
    /* hash函数
    params:	available_str string ---> pre hash blockchain
    */
    func HashString(available_str string) string {
    	h := sha256.New()
    	h.Write([]byte(available_str))
    	return fmt.Sprintf("%x", h.Sum(nil))
    }
    
    
    func main() {
    	c := PowProcess("Haxima")
    	fmt.Println(c)
    }
    
    /*运行结果
    i--->	1
    i--->	2
    i ...
    i--->	99110
    i--->	99111
    Duration:1.570s
    000063d6789a2f7d7f26157cdc38f82c67e52ddda8d6c4e1bf2a3bc4717737ae
    */
    

运行代码可知 :当PowProcess函数条件设置越苛刻(即0的个数越多),其工作量难度越大,CPU在计算时耗费的时间越长


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Go 语言进阶学习路线图发布时间:2022-07-10
下一篇:
go语言入门(4)函数发布时间:2022-07-10
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap