交易的结构
代码语言: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