前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >bitcoin 交易锁定

bitcoin 交易锁定

作者头像
路之遥
发布2022-09-26 16:58:42
8660
发布2022-09-26 16:58:42
举报
文章被收录于专栏:luzhiyaoluzhiyao

交易的结构

代码语言:javascript
复制
Version
Txin[]
    prevout : txID + index
    sig 
    nSequence
Txout[]
    value 
    scriptPubkey
LockTime

bitcoin交易的锁定方法

bitcoin 交易提供了3种交易锁定的方式

  • 通过交易的LockTime 字段锁定交易
    • 通过该字段,用来锁定一个交易。
    • 如果该字段的值 小于LOCKTIME_THRESHOLD(500000000);则标识该交易的锁定高度
    • 如果该字段的值大于等于 LOCKTIME_THRESHOLD,则标识使用高度锁定。
  • 通过交易的nSequence 字段锁定某个指定的交易输入(使用BIP168进行检测)
    • 通过该字段用来锁住一个交易中的指定输入
  • 通过锁定脚本,锁定某个交易输出(添加了某个特殊的操作码)
    • 通过添加操作码,在锁定脚本上锁定一个交易的指定输出。

在交易进交易池,打包区块时,以及验证区块有效性时,都会判断交易的成熟度。对于未成熟的交易,不允许进入进入交易池,不允许打包。

详细解释

在交易池中,交易的输入分为两种:来自于UTXO的输出,来自于交易池中其它未确认交易的输出。

如果一个交易的所有输入都来自于UTXO:

如果要获取该交易所有输入 通过nSequence字段来标识的锁定时间戳; 第一步:是先判断该nSequence字段是否用来锁定

  • 如果某个交易输入的nSequence字段最高bit(1 << 31)位被设置,标识该字段没有启用锁定功能;否则启用了锁定功能

第二步:判断nSequence字段使用了哪种锁定功能

  • 如果第22bit位被设置,则标识启用了时间戳锁定的功能;否则标识启用了高度锁定的功能
    • 对于时间戳的锁定功能:该交易输入的锁定时间为,它的父区块的中位数时间戳 + 锁定字段的值* (1<< 9) - 1
    • 对于高度锁定功能:该交易输入的锁定高度为, 该输入的 utxo高度 + 锁定字段的值 - 1

第三步:依据这些依赖于 nSequence字段进行锁定的交易输入,记录他们的高度,并去除交易池中的交易输入,获取该交易剩下的 utxo集的最高的块索引,用来作为缓存,可以标识刚才计算的交易的锁定时间和锁定高度什么时候失效。

第四步:比较锁定的时间戳和锁定高度

  • 只有当这个交易所有输入的 最大锁定时间和最大锁定高度 大于当前Tip区块时,这个交易才被允许打包到下一个区块中。

对于交易池中的交易,它的输出形成的临时utxo 在集合中的高度为 MEMPOOL_HEIGHT(0x7FFFFFFF),在计算锁定时间和锁定高度时,它的高度被临时赋值为 Tip + 1;

则当交易池中某交易依赖于交易池中其他交易的输出

  • 且该输出还使用nSequence字段进行时间戳锁定时,它的锁定时间的计算相当于当前Tip区块的中位数时间 + 锁定字段的值 * (1 << 9) - 1;所以它肯定在当前正在打包的区块中成熟,所以不会在当前区块时被打包。
  • 该输出使用nSequence字段进行高度锁定,它的锁定高度相当于当前正在打包的区块高度 + 锁定字段的值 - 1
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-09-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 交易的结构
  • bitcoin交易的锁定方法
  • 详细解释
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档