EOS上如何实现UTXO功能?_PEO:BIT

UTXO究竟是什么?

UTXO的全称是UnspentTransactionOutput。这概念首先是在比特币中使用,是个输出类型,可以是“没花出去的”或“花出去的”。一个钱包的余额,是追踪所有可花费的UTXO,把它们加起来的总和。在交易时,支出方钱包花出去多个UTXO,主网系统将生成新的UTXO到收取方钱包,如果收取方要“找零”给支出方,新的找零UTXO也会生成并返回到支出方钱包。所有UTXO显示的额度都是固定的,也改变不了,用户不能只花一部分UTXO,而是要全部花出去。

用UTXO模型实现交易环节

这些设计上的限制是UTXO的特色。UTXO不可变的特点,让程序员可基于UTXO开发出隐私算法。CoinJoin?是个很好的隐私算法案例,它就是用我们今天公布的代码做出来的!

EOS社区建议建立BP计分面板,目前BP排名远远不能代表BPs效率和对网络的专注程度:官方消息,EOS社区建议建立BP计分面板,其表示,EOS上目前的BP排名远远不能代表BPs效率和对网络的专注程度。前21名中的许多BPs完全忽略了项目,只是为了在EOS通货膨胀中赚钱,而有许多BPs给EOS带来了很多价值,没有得到他们应得的排名和奖励。建立BP记分面板可以:让社区和新来的人知道哪些BPs值得投票;给那些想在EOS上建立新代理的人一些好主意。

计分面板以有一个简单的表格的形式,例如列有80个BP,行有社交网络活动、基础设施质量等变量,最后一列是主观排名(或不排名)。[2021/7/10 0:41:38]

代码

pEOS团队致力于提供实用工具,以保护全世界人民的经济隐私。我们在最先进的区块链平台上,通过先进且高效的算法,实现交易的不可追溯性。

EOS跌破3美元关口 日内跌幅为3.81%:火币全球站数据显示,EOS短线下跌,跌破3美元关口,现报2.9888美元,日内跌幅达到3.81%,行情波动较大,请做好风险控制。[2020/11/22 21:41:46]

这个目标比打造pEOS更艰巨,我们的使命也涵盖了:市场教育、用户支持、工具开发、为EOS区块链赋予隐私相关的功能与技术。我们深信这么做能加速EOS生态多方全面的成熟。

基于这个理念,我们今天发布了一个智能合约,为基于EOS的代币实现比特币的?UTXO?功能。

我们今天发布的代码,是在pEOS项目早前探索期写的。虽然有段时间了,但仍然非常有用。我们希望能协助其他项目团队,把真正的UTXO应用于他们的项目代币或项目本身中。

动态 | Block.one同时发布了EOSIO合约 v1.8.7 及 v2.0.0-rc3候选版本更新:今日 Block.one-devops 在GitHub上提交了合约v1.8.7 及 v2.0.0-rc3候选版本更新, 两个版本主要包含安全性、稳定性和其他程序修复。此外,v2.0.0-rc3候选版本的安全修复程序与EOSIO区块链网络上的所有v2.0.x节点相关。特别是,当前正在运行EOSIO的 v2.0.0-rc1或v2.0.0-rc2的块生产节点应考虑尽快将其节点升级到v2.0.0-rc3。[2019/12/18]

这个智能合约在基本代币协议之上,新增两个指令:loadutxo?与?transferutxo。在一般的EOS账号中,用户可执行?loadutxo?指令将资金转换成新的UTXO,执行?transferutxo?实现UTXO的完整交易。

动态 | EOSNode是假节点 采用模式发展下线:据IMEOS消息,EOSNode是一个不存在的EOS节点,公然抄袭了cryptolions的介绍以及团队信息,cryptolions为目前排名第9的乌克兰节点。EOSNode打着分红的旗帜拉票,大肆宣传:年入100亿的收益,分给大众;将EOS充值到他们的app内;采用模式,鼓励发展下线。[2018/7/6]

在UTXO模型下的交易指的是输入一定数量的UTXO,输出一定数量新的UTXO,和比特币的交易方式是一样的。对于最常见的交易指令,可以执行Github代码库里的命令行工具。此工具也可做为钱包,用于钥匙管理。

在Jungle测试网络上体验

这个系统已经部署于Jungle测试网络,大家可以使用命令行工具做测试。在测试网络上的智能合约名是netpeostoken。不用任何实参调用此工具将显示帮助画面:

Kcash已确认支持EOS映射:Kcash官方发布消息称,Kcash已确认支持EOS映射,Kcash将在下月初正式发布2.2.2版本,并上线EOS映射功能,满足EOS钱包映射需要调用智能合约的需求。[2018/4/9]

操作输入时,在命令名后面加上?--help?将可获得更多帮助信息。

获得钱包信息,请使用balance命令如下:

获得UTXO的分析画面,请使用?balance-u?命令如下:

我们可以看到,这个钱包一共有98.0000PEOS,由2个UTXO构成,其中一个是88.0000PEOS,而另一个是10.0000PEOS,上述余额在EOS账号中是看不到的!

现在,我们试着把11.0000PEOS的资金转给另一个人,他的地址是?EOS8Dj5BLdUe1iAi6xNJnZ3bvNEMxDHX6bf4DGesA8USTwj4byJES?。操作非常简单:

依据工具的UTXO选择策略,这将会把我们的2个UTXO都花掉,同时生成2个新的UTXO,其中一个进入收取方的账号,另一个“找零”回到我们的账号。现在我们执行新的balance命令,看看我们的UTXO:

你可以看到,一个新的地址产生了,在这个地址里有我们的“找零”,而原先的UTXO被花掉了。

transfer命令也可以用来执行“从”一个EOS账号转“到”另一个EOS账号。如果操作者在“from”与“to”的地址填写处,输入EOS账号名而不是EOS地址,工具将执行合适的指令,完成转账交易。

如果你需要收进PEOS,你可以使用?receive?命令,操作如下:

你就可以把这个地址发给对方,让对方付PEOS给你。

此工具版本用了EOSIO原生钱包来创造并保护钥匙,同时为交易签名。我们建议用户使用?cleos?工具创造新的钱包,并安置工具于?clpeos?的配置中。

这工具还有很多功能,但超出了本文章的介绍范围。其他功能包括,输出交易但不传递信息、传播已撰写的交易。

pEOS的UTXO与Everipedia的Pay2Key“UTXO”区别在哪?

我们实现UTXO的方案与Everipedia的区别在哪?哪个更匹配开发者的需求?来看看以下几点:

Everipedia的解决方案不能结合多个UTXO为复合交易做新的输出,所以做不到CoinJoin那样的匿名性。

EveripediaUTXO不具备独特性且数值是可改变的。pEOS的UTXO方案完全遵循正真正UTXO的定义,与比特币、门罗币等主流币的UTXO定义一致。Everipedia的方案需要持续追踪每个账号,记录UTXO的数值更改情况。如果开发者想要以太坊的记账系统,Everipedia方案就更加合适。

按时间排序的额交易记录会出现问题。

EveripediaUTXO方案使用IQ_UTXO代币为媒介,而不是IQ。pEOS的方案可配合任何代币使用,不需要使用其他指定代币。

可见,两种方案各有用处。Everipedia的方案可实现简易的记账、便捷的钱包功能,但实现不了?CoinJoin、RingCT、MimbleWimble?的算法。

pEOS提议的方案,复制了比特币的UTXO模型,能实现所有隐私算法,实现真正的匿名性。

结语及pEOS的下一步

随着本次源代码的发布,我们希望能帮助所有EOS智能合约开发者。在此必须强调,这不是我们在白皮书中承诺的pEOS技术,这只是其中的5%。这也不是我们的钱包架构,我们将在未来的文章中介绍钱包架构。代码库里的命令行钱包工具只适用于UTXO合约测试,未做用户体验优化。

在接下来的开发进度文章中,我们将聚焦在优化的议题上,讨论如何优化UTXO的验证、创造“SegWit”模式的交易以释放出EOS主网的带宽及CPU资源。

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

金智博客

[0:0ms0-4:357ms