交易 - Transaction
一点点手写笔记
一个真实的交易
|
|
Lock Time
The locktime indicates the earliest time a transaction can be added to the blockchain.
想象一个实际生活中的场景: Alice给Bob一个支票,支票上写Bob只有到某个日期才能使用支票提款。在比特币中,我们则用Lock Time来实现这个Post Date
除此之外,Locktime给支付者了一定的反悔时间。
- 在区块链中,交易一旦发出就不可收回。
- Alice发出了一个3天后的交易,给Bob 1个比特币。
- 现在Alice反悔了,但是之前的消息不可撤回。
- Alice这时候发出一个没有Locktime的交易,把这个相同的比特币支付给Alice’。
- 这样当三天后这个给Bob的交易执行的时候会被认为是一个double spend因此会被拒绝
- Alice成功反悔了她之前的操作。
关于Locktime的使用:
- 如果locktime < 500 million. locktime被认为是block height (The number of blocks preceding a particular block on a block chain 就是说之后的第几个区块)。Transaction can be added to any block which has this height or higher.
- 如果locktime >= 500 million, 那locktime被认为是一个unix format的时间 (the number of seconds elapsed since 1970-01-01T00:00 UTC—currently over 1.395 billion). The transaction can be added to any block whose block time is greater than the locktime.
Multisig
The multisig can be implemented as a m of n scheme.
简单的应用如下: Alice, Bob, Tom把他们的bitcoin都放在一起,如果要使用必须要拿到至少两个人的签名。(就是个例子,不要考虑两人狼狈为奸坑掉第三个人…hhh)
Writing messages in a transaction
应用场景: 表白(偷笑), 因为区块链是永存的…也不能删除。所以把表白信息放在区块链上后就写入历史了!看,表白墙。当然也可以用于存在性证明,比如说我拍了个照片或者其他数字信息放到区块链中去就表示自己拥有它了(就像你拥有钱币一样样的意思)。
一个方法是用OP_RETURN
- This script allows 80 bytes of data to be added to an output
- This creates a provably unspendable output that the network recognizes
|
|
上面的”636861726c6579206c6f766573206865696469”就是“charley loves heidi”
相关资料: