区块链编程与智能合约入门
1. 区块链上的编码
在当前的加密货币领域,比特币(Bitcoin)和以太坊(Ethereum)是最为流行的两种加密货币,偶尔瑞波币(Ripple)会占据第二的位置。很多人认为比特币仅用于资金转移,而以太坊则可以创建各种程序,如代币、拍卖或托管等。但实际上,比特币也能创建程序,通常被称为脚本。
在比特币交易中,提供脚本是必要的。一个普通的比特币交易脚本可能是这样:
What's your public key? If the public key is hashed, does it equal Z? If
yes, could you provide your private key to prove that you own this public
key?
脚本也可以更复杂,比如要求四个授权签名中的至少两个来解锁账户,或者设置交易在未来五年内冻结,之后才按常规流程,由支出者提供公钥和私钥。
不过,比特币脚本使用的是简单的编程语言,甚至无法实现循环操作,它是基于栈的。在比特币节点上,脚本指令从左到右依次执行。这种设计使得比特币专注于价值存储和转移,避免复杂程序,因为无循环的脚本简单且执行结束时间可预测,而有循环的脚本执行结束时间难以确定。
由于比特币的这种局限性,以太坊应运而生。以太坊区块链所使用的编程语言比比特币的更为复杂,具备 while 或 for 结构,理论上可以创建永远运行的程序。
以太坊不仅能像比特币一样存储和转移价
超级会员免费看
订阅专栏 解锁全文
15

被折叠的 条评论
为什么被折叠?



