小白读《比特币白皮书》(三)

作者:倪云华

【题外话】最近接到不少小伙伴们的反馈,一方面小蛆非常荣幸成为了许多比特币小白走进世界的一块敲门砖,但另一方面小蛆也听到了一些反对的声音。大家反对的角度主要是认为比特币作为高风险的资产,现在已经明显不适合投资了,尤其不适合没有强大风控能力的散户入场。这里小蛆必须为自己声明一下,小蛆只做知识的搬运工,而且小蛆的兴趣是链圈,并不在币圈,小蛆也不会给出任何的投资建议。

大家不要凶我了,我只是一个可爱的小虫虫。

OK!上一篇文章我们讲述了比特币区块链是如何实现把银行的记账功能、数据库更新功能分散到各个节点去实现的,又是如何从众多的节点之中选取下一个区块的来源。今天我们从区块的结构上来看一下为什么区块链可以严格控制产生区块的速度,这个区块链是怎样一点一点地向上生长的。

在介绍这些内容之前,我们必须搞明白一个函数,他就是随机散列函数——Hash(哈希)。这个函数有这么几个功能:

函数大家都知道就是Y=H(X),其中X是输入,Y是输出。

1. 任何长度的输入X都会转化为一个固定长度的Y;

2. X输入的任何一个哪怕只是一个字节的变动都会导致Y大相径庭;

3. 通过X可以计算得到Y,但是不可能通过Y反推得到X。

说得简单一点,这个函数就是——

1. 你把乌七八糟乱七八糟牛鬼蛇神都倒进一个黑箱子里,结果会出来内容不一样但是长度一模一样的字符串;

2. 前后两次输出哪怕只有一点点的出入,这个结果会差到十万八千里;

3. 同时,就算你有了输出的结果,也决计不可能知道输入是什么。

从hash函数的这些性质,我们可以推断出这个函数在区块链技术之中可以发挥怎样的作用了——通过这个函数,成千上万条交易记录可以通过字符拼接拼成一个长长长长非常长的大字符,然后通过hash函数,这些记录就变成了统一长度的hash值。(其实这个过程是通过两两交易记录拼接后经过n/2次hash计算得到一个最终的hash值)。

为什么要让交易记录规范化呢?道理很简单,因为每10分钟的交易记录条数是不确定的。就像生产饮料,如果每瓶的容量不同,那我们每生产一瓶饮料就要量身制定一个瓶子,这样的效率是很低下的。但如果我们通过hash函数都变成了统一大小的饮料,那我们在做对比检验的时候,比较这个标准化的结果就可以了。

另外,hash函数牵一发而动全身的特点让它特别适合做验证。只要交易记录里有一点点改动,哪怕只有一个字符,这个区块里的交易信息经过hash函数后的结果与原hash值相差极大。这样新区块就会发现前方区块已经被篡改,就不会委身接在这个被篡改的区块后面。

我们现在来讨论一个区块的结构。大家已经知道了,区块里封装的是10分钟之内所有的交易记录。为了让所有区块按照时间顺序排列,并且每一个区块有序地排列在另一个已经被验证过的区块后面,区块被设计成如下的结构:

所以从宏观来看,一整条区块链的直观形状就应该是这样的:

通过链状的结构,所有比特币交易记录就都被串联进了这条无限延伸的区块链之中。这里,区块头就起到了至关重要的作用,它的最主要功能就是验证。那我们来看一下它是如何实现这个功能的。区块头的结构如下:

当一个节点向网络发出请求的时候,网络会把最新的区块发给他。最新的区块里包含了前面一个区块的hash值,所以根据这个hash值,这个新进入的节点就可以找得到当前区块之前的一个区块。找到上一个区块之后,再通过上一个区块里储存的前、前区块hash值再向前追溯一个区块。由此,只要给节点一个区块,它就可以把之前所有的区块都找到。

由于hash值的唯一性,不同数据包拥有相同hash值的概率极低极低,甚至可以被当作不可能事件,所以只要hash值一致,就可以通过验证,确定区块的位置。

对于过往的历史数据,hash值判定方法使得每个区块的数据是不可更改的。因为一旦更改了其中的信息,反应在区块头中的梅克尔数根就会发生变化,继而使得这个区块的hash值发生变化。新的节点在获取交易记录的时候,就会避开这个hash改变的数据包,而去其他节点获取符合hash值的未被改变的数据包。

由此,我们解释了为什么通过hash函数使得各位节点即使在不同时间加入网络,它也能够获取全部的交易信息,并保证这份信息是唯一的、不可修改的。但是,对于新发生的交易,因为没有hash值可以用以对比,而且每份交易都是节点自行声明的,如何保证新区块是诚实的呢?

且听小蛆下回分解。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容