当前位置: 首页 > 编程日记 > 正文

区块链基础--工作量证明

链客,专为开发者而生,有问必答!

此文章来自区块链技术社区,未经允许拒绝转载。

在这里插入图片描述
区块链基础(6)–工作量证明1

我认为技术和共识构建了区块链,那么就由几个问题需要去解决,第一:如果由多个打包节点,那会不会区块链分叉?第二:如果诚实节点的工作无法得到正常激励,那会不会导致节点越来越少?第三:如果系统中的51%节点都是恶意节点,会不会导致系统陷入被操作的境地?为了这三个问题,将以比特币为例,去介绍最火的公有链运行机制:工作量证明。

区块链会跟随某种资源的占有量来选取打包的节点,这种资源如果是计算能力,那么就称之为工作量证明,简称POW,如果这个资源是币的拥有数,那就称为权益证明POS,如果这个资源是可以授权的股份,那就称为股份授权证明Dpos。

工作量证明

那么计算能力到底是怎么反应工作量的呢,对区块链节点来讲,其实单纯的打包和上传数据是非常简单的,只是需要系统选择某一个特定的节点来处理这件事情而已,为了避免所有节点都在打相同的包而导致分叉,比特币通过哈希穷举增加打包难度来延长打包时间,简单说就是每一个节点需要在10分钟之内找到一个随机数,保证这个随机数加上之前区块的哈希值组合经过哈希运算之后能够满足一定的规律(比如第一位为1,第三位为5,第四位为8等等,保证满足条件的结果只处于所有结果中的很小一个范围内)。解决这个问题的办法之后一个,就是不断的尝试新的随机数,在2014年的时候,产生一个区块需要10的20次方 次哈希运算,也就是说,这个目标范围仅仅是1/100000000000000000000。随着计算机计算能力的增强,要保证区块产生的时间(10分钟),那么只能不断的修改计算的难度,难度增加则需要的计算次数增加,难度减少则计算次数减少,在比特币规则里面,就有修改难度这一项,所以,现在要获取到一个这样的随机数,需要计算的次数要远远高于这个数字,如果说你幸运的找到了这样一个随机数,那么你就可以作为打包节点进行打包,当然在比特币刚出来的时候,我们可以用个人电脑去计算,现在个人电脑已经不可能完成这项任务了。

使用哈希穷举来实现工作量证明有两点优势:

a.随机性,即使知道想要的目标范围,每个节点依然只能通过不断的尝试去获取随机值。

b.易验证性,如果有人声明找到了随机数,其他节点可以很快的通过哈希运算来验证这个数的正确性。

打包激励

如果只有工作量没有奖励,节点可不愿意做这种耗时耗资源的事情,所以就设计了两种激励方式:打包奖励和交易费。

1.打包奖励

打包奖励是创建区块链的节点获得一定数量的比特币,其实就是在区块中增加了一项指向自己地址的交易,交易的金额来源有特殊性。对于比特币来说,每生成21万个区块,奖励数量就会减半。

2.交易费

比特币在设计之前规定总数为2100万个,比特币都是通过奖励的形式产生,如果发放完成,那么交易费将是支持打包这工作的一个重要因素。交易费就是指每笔转账都需要由转账者支付打包者一定的费用,

简单说就是这种进行工作量证明并获取打包奖励的行为就叫做挖矿。

在工作量证明中,为了获得奖励,每个人都希望自己被选为打包节点。从现在比特币的运行情况,算力分布的相对较为分散,在一定程度上保证了工作量证明的公平性,也就保证了区块链系统的运行。但是由于大量的电力和硬件资源用域哈希函数穷举,这种穷举方式除了选择节点外是没有任何资源转化价值的,也就是比特币被一些人诟病的原因,不过每个人都由自己客观的看待这个问题,毕竟仁者见仁智者见智。

www.liankexing.com

相关文章:

pat乙级1049

浮点型乘整型和整型乘浮点型结果不同&#xff0c;不知为什么。 1 double sum 0.0; 2 for (int i 0; i < n; i) 3 { 4 cin >> a[i]; 5 sum a[i] * (i 1) * (n - i); 6 } 7 printf("%.2f", sum); 提交结果正确。 1 double sum 0.0; 2 for (int i…

hdu-5778 abs(暴力枚举)

题目链接: abs Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) Problem DescriptionGiven a number x, ask positive integer y≥2, that satisfy the following conditions:1. The absolute value of y - x is minimal2. To prime f…

bugku 杂项 就五层你能解开吗_你能解开这个和数字有关的逻辑解谜游戏吗? | 每日一考...

今天是一道和数字有关的逻辑解谜游戏看看你能用多长时间得到答案这道题的目标是&#xff0c;把网格根据数字划分成很多个方形小块。每个数字都代表它所在的小块面积&#xff0c;也就是包含了几个小格子&#xff0c;要求如下图&#xff0c;每个小块里必须有&#xff0c;而且只能…

区块链技术术语表

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 区块链技术包含了常见的区块链基本概念和进阶阅读的参考文章&#xff0c;用自己的思考方式去优化理解。 比特币&#xff1a;一种分布式网络的数字货…

『TensorFlow』数据读取类_data.Dataset

一、资料 参考原文&#xff1a; TensorFlow全新的数据读取方式&#xff1a;Dataset API入门教程 API接口简介&#xff1a; TensorFlow的数据集 二、背景 注意&#xff0c;在TensorFlow 1.3中&#xff0c;Dataset API是放在contrib包中的&#xff1a; tf.contrib.data 而在Tenso…

出入口控制系统工程设计规范_[问答]连载77-控制系统之间如何时钟同步?

仪表小猪在控制系统中&#xff0c;趋势、报警、事件记录等都与时间相关&#xff0c;因此整个系统始终保持一个统一的时钟很关键。如果操作站和控制站时间不同步&#xff0c;操作员站上面显示的事件、趋势等也不能真正的反应出现场实际变化的时间&#xff0c;不能作为真实的历史…

分布式账本(Distributed ledger)

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 是一种在网络成员之间共享、复制和同步的数据库。分布式账本记录网络参与者之间的交易&#xff0c;比如资产或数据的交换。这种共享账本消除了调解不…

手动删除木马程序

1 ??? 2 这个蠢货竟然用360? (360杀毒太流氓&#xff0c;插件不可控&#xff0c;就是第一个要杀的木马) 一些基本的命令往往可以在保护网络安全上起到很大的作用,下面几条命令的作用就非常突出。 一、检测网络连接 如果你怀疑自己的计算机上被别人安装了木马,或者是中…

phpstorm如何同时打开两个文件夹_2分钟学会文件夹共享,化身办公室电脑大神

点击上方蓝色字体&#xff0c;关注我们身在职场或学校的你&#xff0c;还在用微信或QQ给办公室的小伙伴传文件吗&#xff1f;那你可真就out了&#xff0c;总结一下&#xff0c;微信或QQ传文件存在以下3个缺点。1、传输文件大小存在限制微信不能发送100MB以上的文件&#xff0c;…

Hdu_2063 过山车 -最大匹配(邻接表版)

题目&#xff1a;就是最大匹配了 /************************************************ Author :DarkTong Created Time :2016/8/1 12:53:27 File Name :Hdu2063.cpp *************************************************/#include <cstdio> #include <cstr…

“去中心化”为何意义重大?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 互联网的前两个时代 在互联网的第一个时代–从20世纪80年代到21世纪初–互联网服务建立在由互联网社区控制的开放协议之上。这意味着&#xff0c;人…

一阶微分算子锐化图像_【动手学计算机视觉】第三讲:图像预处理之图像分割...

本讲完整代码>>前言图像分割是一种把图像分成若干个独立子区域的技术和过程。在图像的研究和应用中&#xff0c;很多时候我们关注的仅是图像中的目标或前景(其他部分称为背景)&#xff0c;它们对应图像中特定的、具有独特性质的区域。为了分割目标&#xff0c;需要将这些…

visual studio code 里调试运行 Python代码

最近对微软的visual studio code 挺感兴趣的&#xff0c;微软的跨平台开发工具。轻量简洁。 版本迭代的也挺快的&#xff0c;截止16年8月2日已经1.3.1版本了&#xff0c;功能也愈加完善。&#xff08;16年12月18日 已经&#xff0c;发到1.10.1版本了&#xff0c;更新非常频繁&a…

GridView单元格取值显示为nbsp;

在通过GridView取一个单元格&#xff08;cell&#xff09;的值时&#xff0c;数据库中为NULL&#xff0c;而页面上显示为空格。发现通过gridview.cell[i].text取出来的值为 &#xff0c;导致获取数据出现问题。 解决方法&#xff1a; 一、利用Server.HtmlDecode(string)进行转换…

什么是比特币?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 比特币就是所谓的“加密货币”&#xff0c;这是一种完全以数据形式存在的数字资产。你存在银行的钱可能也是一堆数字&#xff0c;但这些数字等效于…

C程序设计-----第1次作业

一、 PTA作业。 在完成PTA作业的时候我没有认真读题。每次都是提交完整代码 6-1&#xff08;1&#xff09; 1 #include <stdio.h>2 3 //P等价于&#xff08;p&#xff09;还是等价于*&#xff08;p&#xff09;&#xff1f;4 5 int main(){6 int *p, a 3;7 p…

python画散点图对散点阴影扩充_Python金融应用之图表制作(三)

​NO.602020.04.06工欲善其事&#xff0c;必先利其器//- 前言 - 今天&#xff0c;小咖带大家使用Python制作申万行业PE和ROE的散点图&#xff1f;最终将得到以下效果&#xff1a;

List集合的去除重复性练习

package com.java.b.listdmeo.www; import java.util.ArrayList;import java.util.Iterator; import com.java.Student.www.Student; public class listtest { public static void main(String[] args) { //创建一个集合&#xff0c;该集合为List 集合 ArrayList listnew Arr…

区块链的安全软肋是什么?

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 今天我们来谈谈区块链的安全软肋。 作为比特币中的核心技术&#xff0c;在无法建立信任关系的互联网上&#xff0c;区块链技术依靠密码学和巧妙的分…

web service 项目 和 普通 web项目 的 区别

web service 面向的是开发者&#xff08;需要再次开发&#xff09; 普通web 面向的是用户&#xff08;直接使用&#xff09;转载于:https://www.cnblogs.com/zno2/p/5612024.html

selenium:学习资源

selenium中文版文档 http://www.selenium.org.cn/1203.html selenium 搜索功能&#xff1a; http://blog.csdn.net/qq_878799579/article/details/73321015 selenium 详细教程&#xff1a; http://www.cnblogs.com/yoyoketang/p/6123938.html 转载于:https://www.cnblogs.com/f…

node.js 验证路径有效性_怎样识别光伏谐波路径?试试这个算法

国网吉林省电力有限公司四平供电公司的研究人员韩绍禹、李新辉&#xff0c;在2019年第5期《电气技术》杂志上撰文指出(论文标题为“基于信息熵和节点导纳矩阵的光伏谐波路径初探”)&#xff0c;光伏电站的接入给电网注入一定谐波&#xff0c;同时也增加了电网谐波线损。本文针对…

区块链研发与运营

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 传统行业之所以会存在着每况愈下的情况发生&#xff0c;主要的原因还是在于运营方式的墨守成规&#xff0c;造成消费者缺乏了购买欲望和关注度&am…

mysql longtext可以存储多少文字_MySQL 四万字精华总结 + 面试100 问,和面试官扯皮绰绰有余(收藏系列)

作者&#xff1a;派大新 链接&#xff1a;https://juejin.im/post/5f0d4fadf265da22f3250eaa写在之前&#xff1a;不建议那种上来就是各种面试题罗列&#xff0c;然后背书式的去记忆&#xff0c;对技术的提升帮助很小&#xff0c;对正经面试也没什么帮助&#xff0c;有点东西的…

2018.3.15校内互测总结-点分治-线段树

这是曾来过咱们学校集训的一位大神出的~ T1 题目大意 给出一棵带边权的无根树&#xff0c;求树上前$k$大的路径的长度。 $1 \leq n \leq 200000$ 题解 想了一上午点分治&#xff0c;却发现只会$O(nlog^3n)$的...... 正解是二分第$k$大的权值&#xff0c;用点分治判断&#xff0…

EntityFramework Core 学习笔记 —— 创建模型

原文地址&#xff1a;https://docs.efproject.net/en/latest/modeling/index.html 前言&#xff1a; EntityFramework 使用一系列的约定来从我们的实体类细节创建模型。我们可以钦定一些额外的映射配置来添加、重写实体类的哪些细节应该被这些约定所发现。 这篇文章讲述了一些无…

使用docker-compose进行多节点部署

链客&#xff0c;专为开发者而生&#xff0c;有问必答&#xff01; 此文章来自区块链技术社区&#xff0c;未经允许拒绝转载。 创建数据目录及多节点目录 mkdir -p ~/workmeta/EduEthereumServerDeploy/deploy_2/{node1,node2} > cd ~/workmeta/EduEthereumServerDeploy/de…

石头剪刀布python代码_我的第一个python程序,石头剪刀布猜拳游戏

从决定学习python到今天&#xff0c;已经过去了好1个月&#xff0c;买的几本书还没一本看完的&#xff0c;惭愧。 忙不是借口&#xff0c;是时候来点计划&#xff0c;来点坚持。写点什么吧&#xff0c;算是学习的记录&#xff0c;也是对自己的鞭策。 今天写一个猜字游戏&#x…

CATransform3DRotate 实现左右,上下翻转效果

CGFloat m34 800; CGFloat value &#xff1d; &#xff0d;40&#xff1b;//&#xff08;控制翻转角度&#xff09; CGPoint point CGPointMake(0.5, 0.5);//设定翻转时的中心点&#xff0c;0.5为视图layer的正中 CATransform3D transfrom CATransform3DIdentity; transfro…

[UWP小白日记-10]程序启动屏(ios解锁既视感)

[UWP小白日记-10]程序启动屏&#xff08;ios解锁既视感&#xff09; 原文:[UWP小白日记-10]程序启动屏&#xff08;ios解锁既视感&#xff09;讲一下 微软爸爸的开发者大会2016又暴了个表达式动画和Windows.UI.Composition的API&#xff0c;好叼的样子。官方示例库GitHub 目前是…