BTC中的数据结构

普通指针

普通指针存储的是某个结构体在内存中的地址(假如P是指向一结构体的指针,那么P里面存放的就是该结构体在内存中的起始位置)

Hash pointer(哈希指针)

对于如下的节点,有两个指针指向这个节点(实际上是一个),其中P为该节点的地址,H()为该节点的哈希值,该值与节点中的内容有关。当节点中的内容发生改变,该哈希值也会发生变化,从而保证了区块内容不会被篡改。

主要作用

  1. 存地址
  2. 从哈希值H()这个哈希指针,可以找到该结构体的位置
  3. 同时还能够检测出该结构体的内容有没有被篡改,因为我们保存了它的哈希值

区块链和普通的链表相比有什么区别:

  1. Block chain is a linked list using hash pointers(用哈希指针代替了普通指针)
  • 比特币中最基本的结构就是区块链,区块链就是一个一个区块组成的链表
  • 区块链第一个区块叫作genesis block (创世纪块)最后一个区块是most recent block(最近产生的区块) 每一个区块都包含指向前一个区块的哈希指针,也就是保存有前一个区块的哈希值
  • 哈希指针的结果是通过对前一个区块的所有数据进行哈希运算而得到的。区块链中的每个区块都包含前一个区块的哈希值,以确保区块链的连续性和安全性。如果修改了前一个区块的数据,其哈希值也会发生变化,从而影响到之后的所有区块,这保证了区块链数据的不可篡改性。
  1. 普通链表可以任意修改,区块链不行
  • 比特币没有要保存所有区块的内容,只保留最近的几千个区块。如果要用到以前的区块,可以向系统中其他节点要这个区块。
  • 判断恶意节点,这里要用到哈希值一个性质:

    其他节点给你一个区块,算出它的哈希值,与保留的区块的哈希值对比,即可

Tamper-evident log(防篡改 log/区块链)图示分析

Merkle Tree(默克尔树)

1、Merkle Tree用哈希指针代替了普通指针

(上面两层内部节点都是哈希指针(Hash Pointers),第一层是根节点,根节点的区块也可以取哈希(root hash))。比特币当中各区块之间用哈希指针连接在一起,每个区块所包含的交易组织成一个Merkle Tree的形式,最下层的数据块(data blocks)每个区块是一个交易transaction,每个区块分为两个部分,分别是块头和块身(block header,block body)。块头里面有根哈希值,每个区块所包含的所有交易组成的Merkle Tree的根哈希值存在于区块的块头里面,但是,块头里面没有交易的具体内容,只有一个根哈希值,块身里面是有交易的列表的。

Merkle Tree的优点

  • 知道根哈希值,就能检测出数中任何位置的修改

  • 每个数据块是一个交易

作用(提供merkle proof )

比特币中的节点分为两类

  • fully validating node(全节点,保存整个区块的内容,即块头块身都有,有交易的具体信息)
  • light node(轻节点,例如手机上的比特币钱包)(只有保存块头,只有根哈希值)
    • 用merkle proof向一个轻节点证明某个交易是写入区块链的:找到交易所在的位置(最底行的其中一个区块),这时该区块一直往上到根节点的路径就叫merkle proof。
    • merkle proof可以证明merkle tree里面包含了某个交易,这种证明又叫proof of membership或 proof of inclusion。
    • 对于一个轻节点来说,验证一个merkle proof 复杂度是多少?假设最底层有n个交易,则merkle proof 复杂程度是θ(log(n))

证明merkle tree里面没有包含某个交易?

即proof of non-membership。可以把整棵树传给轻节点,轻节点收到后验证树的构造都是对的,每一层用到的哈希值都是正确的,说明树里只有这些轻节点,要找的交易不在里面,就证明了proof of non-membership,只能一个个节点的验证,所以时间复杂度是线性O(n)。如果将数据节点的哈希值排好序之后,时间复杂度是O(logn)。

一般来说,一般的链表我们都可以改造为使用哈希指针的链表,但当链表中存在环时,哈希指针便不能再使用,会出现循环。

BTC中的数据结构的更多相关文章

  1. java中的数据结构(集合|容器)

    对java中的数据结构做一个小小的个人总结,虽然还没有到研究透彻jdk源码的地步.首先.java中为何需要集合的出现?什么需求导致.我想对于面向对象来说,对象适用于描述任何事物,所以为了方便对于对象的 ...

  2. Python 中的数据结构总结(一)

    Python 中的数据结构 “数据结构”这个词大家肯定都不陌生,高级程序语言有两个核心,一个是算法,另一个就是数据结构.不管是c语言系列中的数组.链表.树和图,还是java中的各种map,随便抽出一个 ...

  3. [转]详细介绍java中的数据结构

    详细介绍java中的数据结构 本文介绍的是java中的数据结构,本文试图通过简单的描述,向读者阐述各个类的作用以及如何正确使用这些类.一起来看本文吧! 也许你已经熟练使用了java.util包里面的各 ...

  4. 详细介绍java中的数据结构

    详细介绍java中的数据结构 http://developer.51cto.com/art/201107/273003.htm 本文介绍的是java中的数据结构,本文试图通过简单的描述,向读者阐述各个 ...

  5. sql点滴42—mysql中的数据结构

    原文:sql点滴42-mysql中的数据结构 MySQL 的数值数据类型可以大致划分为两个类别,一个是整数,另一个是浮点数或小数.许多不同的子类型对这些类别中的每一个都是可用的,每个子类型支持不同大小 ...

  6. PHP中的数据结构

    PHP7以上才能安装和使用数据结构,安装比较简单: 1. 运行命令 pecl install ds 2. 在php.ini中添加 extension=ds.so 3. 重启PHP或重载配置  Coll ...

  7. Python中的数据结构

    Python中的数据结构 这里总结一下Python中的内置数据结构(Built-in Data Structure):列表list.元组tuple.字典dict.集合set,涵盖的仅有部分重点,详细地 ...

  8. 在Object-C中学习数据结构与算法之排序算法

    笔者在学习数据结构与算法时,尝试着将排序算法以动画的形式呈现出来更加方便理解记忆,本文配合Demo 在Object-C中学习数据结构与算法之排序算法阅读更佳. 目录 选择排序 冒泡排序 插入排序 快速 ...

  9. PHP中的数据结构:DS扩展

    PHP7以上才能安装和使用该数据结构扩展,安装比较简单: 1. 运行命令 pecl install ds 2. 在php.ini中添加 extension=ds.so 3. 重启PHP或重载配置 在这 ...

  10. JavaScript中的数据结构及实战系列

    本系列主要是讲解JavaScript中的数据结构及在实际项目中遇到的地方 JavaScript中的数据结构及实战系列(1):队列 JavaScript中的数据结构及实战系列(2):栈

随机推荐

  1. SRIO接口卡航电总线解决方案

    TES600是天津拓航科技的一款基于FPGA与DSP协同处理架构的通用高性能实时信号处理平台,该平台采用1片TI的KeyStone系列多核浮点/定点DSP TMS320C6678作为主处理单元,采用1 ...

  2. OpenAI CLIP 关键点 - 连接图像和文字

    标签: #CLIP #Image2Text #Text2Image #OpenAI 创建时间:2023-04-21 00:17:52 基本原理 CLIP是一个图像分类模型. 准备训练数据:准备大量的文 ...

  3. Node.js躬行记(28)——Cypress自动化测试实践

    最近在研究如何提升项目质量,提炼了许多个用于自测的测试用例,但是每次修改后,都手工测试,成本太高,于是就想到了自动化测试. 在一年前已将 Cypress 集成到管理后台的项目中,不过没有投入到实践中. ...

  4. #Powerquery pq从入门到精通,笔记梳理

    详细视频可以B站搜索,ms_excel博主,看leila的视频翻译课,powerquery从入门到精通. 后续也会根据自己工作来更新这部分的实际用法.

  5. 2021-03-08:在一个数组中,任何一个前面的数a,和任何一个后面的数b,如果(a,b)是降序的,就称为逆序对。返回逆序对个数。

    2021-03-08:在一个数组中,任何一个前面的数a,和任何一个后面的数b,如果(a,b)是降序的,就称为逆序对.返回逆序对个数. 福哥答案2021-03-08: 1.归并排序,从右往左,相等拷右. ...

  6. 2021-06-23:给定一个数组arr,代表每个人的能力值。再给定一个非负数k,如果两个人能力差值正好为k,那么可以凑在一起比赛。一局比赛只有两个人,返回最多可以同时有多少场比赛。

    2021-06-23:给定一个数组arr,代表每个人的能力值.再给定一个非负数k,如果两个人能力差值正好为k,那么可以凑在一起比赛.一局比赛只有两个人,返回最多可以同时有多少场比赛. 福大大 答案20 ...

  7. 2021-12-09:二叉树展开为链表。 给你二叉树的根结点 root ,请你将它展开为一个单链表: 展开后的单链表应该同样使用 TreeNode ,其中 right 子指针指向链表中下一个结点,而左

    2021-12-09:二叉树展开为链表. 给你二叉树的根结点 root ,请你将它展开为一个单链表: 展开后的单链表应该同样使用 TreeNode ,其中 right 子指针指向链表中下一个结点,而左 ...

  8. 2021-08-23:超级水王问题。扩展1:摩尔投票。扩展2:给定一个正数K,返回所有出现次数>N/K的数。

    2021-08-23:超级水王问题.扩展1:摩尔投票.扩展2:给定一个正数K,返回所有出现次数>N/K的数. 福大大 答案2021-08-23: 扩展1: 1.如果无候选,当前数就是候选,血为1 ...

  9. 2021-08-22:定义什么是可整合数组:一个数组排完序之后,除了最左侧的数外,有arr[i] = arr[i-1]+1,则称这个数组为可整合数组,比如{5,1,2,4,3}、{6,2,3,1,5,

    2021-08-22:定义什么是可整合数组:一个数组排完序之后,除了最左侧的数外,有arr[i] = arr[i-1]+1,则称这个数组为可整合数组,比如{5,1,2,4,3}.{6,2,3,1,5, ...

  10. vue全家桶进阶之路42:Vue3 SCSS、SASS、CSS

    SCSS和SASS都是CSS预处理器,它们的主要目的是简化CSS的编写,增加可维护性,并提供更丰富的功能.下面是它们与普通的CSS的区别: 语法:SCSS和SASS都具有比普通CSS更丰富的语法.其中 ...