第两百二十一章 区块链(2/3)

易单位变为比特币。

另一个改进就是之前的账本我们约好是月底结账,而现在我们把易单位改成了虚拟的比特币,易也由月底统一割改为事实割。

而比特币就像是账本上的数字,随时都可以视大家的意见进行套现,即在现实中割。

如此一来,我们就需要确保每个的账户里有足够的比特币进行易。也就是确定任何一笔易的前提就是付款方的比特币账户中有足够的比特币用于支付。

传统银行系统中,银行会记录储户的账余额,判断储户是否能够进行转载。

这个很好理解,我在网银里错向某账户转账一个亿,但我账户里显然没有这么多钱,因此银行系统会认定易失败。

但比特币系统并没有一个“银行式”的权威中心,所以不能像银行这种作方式。

比特币的解决方案是,每笔易不以余额为基础,而是以以前的易为基础。

比如,“小王支付给小黄50btc”的前提是自己曾经收到过多余50btc。因此小王的易记录需要包含自己之前的易信息,举个例子:

小白支付给小王40btc

你支付给小王20btc

小王支付给小黄50btc

我们忽略比特币的源,及它是如何产生的事,先继续往下看。

这个时候小王需要广播的易信息就是:

之前易小白支付给小王60btc,你支付给小王60btc。

当前易小白支付给小黄20btc,你支付给小黄10btc,你支付给小黄10btc。

这里说一句,“你支付给小王20btc”中的20btc是一个整体,无法分割,因此无法只从中拿出10btc易。

还有最后一个改进就是不留证明,改留比特币账号。就是用户a并不用留下自己的名字,而是用一个字符串来代表自己进行易,同理,用户b和c也是如此,只留下了一个字符串。

所以你们室友在帐本里都不写名字,而是写下跟各自对应的字符串,即比特币账户。

虽然对于你们四个的寝室这纯属脱裤子放,但如果对于规模更大的系统,比如前文提到的整个学校而言,这种作可以极大提升隐私

我们只能知道每个账户,而无法知道谁拥有这个账户,这就保证了隐私

而区块链呢,就是从这一节开始进正题。

前面我们提到了这个账本是分布式存储的,每个都有一个自己独立管理的账本。

当这个账本系统变得很大时,一致问题就必须要考虑。

比如,如果你有室友在易记录发布时不在寝室,那么他就错了这次消息,使得这次消息不会出现在他的帐本里。

换回比特币系统,也就是部分电脑可能处于关机或者未联网状态,会错过部分易。

此外,还可能会有黑客侵部分电脑,篡改易记录。

此外,还有一个更严重的问题就是,实际网络拓扑非常复杂,链路质量的随机很大。

因此,如果用户a(假设账户里有10btc)连续广播两条相互矛盾的消息,比如:

易信息1:用户a支付10btc给b。

易信息2:用户a支付10btc给c。

有的读者应该会觉得,那我们就采信先收到的易信息1,忽略与之矛盾的脚印信息2不就行了。

但问题是,因为网络链路的复杂,所以很可能存在部分用户先收到易信息1,又有部分用户先收到易信息2。如果依靠先后顺序辨别有效,那么就会存在不同用户记录的易信息不一致。

所以为了解决这个问题,中本聪才提出了区块链的概念。

每个用户如果愿意,都可以整理自己从网络中接收到的易信息,然后检查其是否合理,也就是每笔易是否由足够余,然后数字签名是否正确后,再将易记录打包成一个区块。

因此每个易记录都是以区块的形式存储,然后再广播到系统中的其他用户中。

而区块之间相互连接,形成一条由系统内全体用户共同维护的区块链。

因此其他用户收到广播的区块时,就会把这个区块加到自己维护的账本,也就是区块链的尾部。

但如果只是这样,并没有解决任何问题。互联网节点遍布全球,广播过程也需要时间,因此肯定会存在不同节点收到不同区块存储的问题。

所以如此一来这个网络就套了。

而为了降低传播时间的影响,一个简单粗的方式就是从系统设计中就限制区块生成的速度。

所以比特币系统的核心思想采就是用算力限制区块的生成速度。

比特币系统要求,每个用户在发布新区块前

地址发布邮箱:Ltxsba@gmail.com 发送任意邮件即可!

本章未完,点击下一页继续阅读。