区块链中的记账原理讲解

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

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

区块链中的记账原理讲解_第1张图片

很多人只了解过比特币,不知道区块链,比特币实际是一个运用了区块链技术的应用,只是比特币当时太热,把区块链技术的光辉给掩盖了。区块链才是未来,期望各位开发人员少关怀币价,多关怀技术。

本文将解说区块链1.0技术是怎样实现的。

哈希函数

在讲区块链记账之前,先说明一下哈希函数。

哈希函数:Hash(原始信息) = 摘要信息

原始信息可所以恣意的信息, hash之后会得到一个简略的摘要信息

哈希函数有几个特点:

相同的原始信息用同一个哈希函数总能得到相同的摘要信息

原始信息任何细小的改动都会哈希出面目全非的摘要信息

从摘要信息无法逆向推算出原始信息

举例说明:

Hash(张三借给李四100万,利息1%,1年后还本息 ……) = AC4635D34DEF

账本上记载了AC4635D34DEF这样一条记载。

可以看出哈希函数有4个效果:

简化信息

很好理解,哈希后的信息变短了。

标识信息

可以运用AC4635D34DEF来标识原始信息,摘要信息也称为原始信息的id。

躲藏信息

账本是AC4635D34DEF这样一条记载,原始信息被躲藏。

验证信息

假如李四在还款时诈骗说,张三只借给李四10万,两边可以用AC4635D34DEF来验证原始信息

哈希函数的这4个效果在区块链技术里有广泛的运用。

(哈希函数是一组函数或算法,今后会发文章专门介绍哈希)

区块链记账方法

假设有一个账页序号为0的账页生意记载如下:

账号入账出账余额备注说明

王二100 190收到xxx货款

张三 10030xxxx

李四12090170xxxx

记账时间为:2017-10-22 10:22:02

区块链在记账是会把账页信息(包含序号、记账时间、生意记载)作为原始信息进行Hash, 得到一个Hash值,如:787635ACD, 用函数表明为:

Hash(序号0、记账时间、生意记载) = 787635ACD

账页信息和Hash值组合在一起就构成了第一个区块。

比特币系统里约10分钟记一次账,即每个区块生成时间大约间隔10分钟

在记第2个账页的时分,会把上一个块的Hash值和当时的账页信息一起作为原始信息进行Hash,即:

Hash(上一个Hash值、序号1、记账时间、生意记载) = 456635BCD

这样第2个区块不仅包含了本账页信息,还直接的包含了第一个区块的信息。依次按照此方法持续记账,则最新的区块总是直接包含了全部之前的账页信息。

全部这些区块组合起来就形成了区块链,这样的区块链就构成了一个便于验证(只要验证最终一个区块的Hash值就相当于验证了整个账本),不行更改(任何一个生意信息的更改,会让全部之后的区块的Hash值发作改动,这样在验证时就无法经过)的总账本。

记账有成本,想了解节点为什么要记账,请看这篇:在比特币怎样挖矿-工作量证明

你可能感兴趣的:(区块链中的记账原理讲解)