金色观察 | 硬核解读比特币具体是怎么减半的

就在5月12日凌晨3:23,比特币成功完成众所瞩目的第三次减半。

自2009年诞生,比特币已经走过波澜壮阔的十年。从交易所、矿机、投资者到媒体,比特币已经带动加密货币行业形成一个完整的生态系统。比特币区块奖励减半从供给侧直接减少一半的货币供给,显然在边际和投资者心理上都极大彰显了比特币的稀缺性。

因此,四年一次的比特币减半成为整个加密货币行业关注的焦点。

但看了那么多比特币减半的文章,你可能还不知道比特币具体是怎么减半的,比如四年减半一次的四年是怎么来的,怎么计算当前区块的奖励等问题。

值此比特币第三次减半之际,来跟随金色财经记者看看Bitcoin Core的代码是具体怎么执行比特币区块奖励减半的。

比特币减半代码

比特币减半,是比特币区块奖励减半的简称。而比特币的区块奖励减半是比特币共识的一部分,直接写在比特币软件代码里。

具体减半代码在这里,下面是截图。

比特币区块奖励减半代码 来源:Bitcoin Core github

就这6行代码定义的函数GetBlockSubsidy决定着不同区块高度下的比特币区块奖励。中本聪创造的比特币共识设置区块奖励从50个比特币开始每210000个区块比特币奖励减半,减半64次后区块奖励为0。

全网DeFi锁仓量为1099.7亿美元:金色财经消息,据DeFiLIama数据显示,当前全网DeFi锁仓量1099.7亿美元,24小时下降1.61%。目前,锁仓量排名前5的公链分别为:ETH(696.2亿美元)、BSC(84亿美元)、Avalanche(51.7亿美元)、Tron(42.8亿美元)、Solana(40.2亿美元)。[2022/5/15 3:16:34]

210000个区块的时间大约为四年,这也是币圈人说的四年一次减半的由来。因为比特币减半事件是写进比特币软件代码里并有分布在全世界的比特币全节点验证,其共识很难改变,这也是“In Code We Trust”的由来。

逐行解读比特币减半

上诉代码主要有几个函数和参数:GetBlockSubsidy、nHeight、Consensus.nSubsidyHalvingInterval、halving、nSubsidy。它们的涵义如下:

GetBlockSubsidy主要是活的当前区块高度下的区块奖励(nSubsidy );

nHeight为当前区块高度;

Consensus.nSubsidyHalvingInterval为比特币共识决定的区块奖励减半间隔区块,此值为一个常数,为210000。

halvings为减半次数,是一个整数变量,也就是对nHeight/210000取整;

COIN为常数,为100000000,也就是说,在比特币代码里,比特币的单位是聪。

nSubsidy为区块奖励。

1239行代码调用GetBlockSubsidy函数。

1240行代码:halvings=nHeight/Consensus.nSubsidyHalvingInterval,计算当前区块对应的减半次数。比如截止本文发稿,区块高度为629929,629929/210000=2.99,取整halvings=2。当区块高度达到630000时,halvings=3。

1242和1243行代码:if (halvings >= 64) return 0;判断减半次数是否大于64,如果减半次数大于等于64,则区块奖励为0。这也是来自比特币共识,只有64次减半,64次减半后区块奖励为0。

1245行代码nSubsidy=50*COIN,比特币软件每次执行代码都把区块奖励设置成50* COIN,也就是5000000000。

1247行代码nSubsidy>>=halvings,这一句是真正起作用的比特币区块奖励减半代码。>>= 是二进制右移操作,nSubsidy>>=halvings等价于nSubsidy=nSubsidy除以2的halvings次方。

1248行代码返回比特币当前高度的区块奖励值。

上述代码最后的实质是下面的公式:

因此,1-209999区块每个区块奖励为50/(2^0) =50枚比特币;210000-419999区块奖励减半为50/(2^1)=25枚比特币,420000-629999区块奖励减半至50/(2^2)=12.5个BTC。区块高度630000后减至50/(2^3)=6.25枚比特币。

大神也有BUG

不过,上述6行代码不是中本聪的原始代码,中本聪的原始代码如下:

尽管中本聪是大神,但不代表其代码就没有bug。因为nSubsidy是个64位的有符号整数,而>>= 超过64在C++中属于未定义行为,会导致数值环回,最终导致BTC数量不断重复2100万个比特币的释放过程,见下图。

Pieter Wuille修复了这个bug,有一个专门的比特币改进协议BIP042描述这个bug,文档见这里。

参考资料:

Where in the Code Does the Halving Take Place

BIP042

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

区块分享

比特币海南最新区块链政策:设立10亿元子基金 支持探索数字资产交易平台建设

近日,海南省工业和信息化厅发布《关于印发海南省加快区块链产业发展若干政策措施的通知》,提出十点政策措施,分别为:组建区块链联合创新平台、设立区块链产业基金、支持区块链基础设施建设、推广旅游消费区块链积分、推动电子政务项目链改、鼓励区块链核心技术研发、实施区块链应用示范揭榜工程、探索区块链+金融沙箱监管机制和打造区块链产业集群。

USDCOKEx第6、 火币第18 CMC最新交易所排名惹争议

数字货币交易所的排名有了新变化。 在最新的 CoinMarketCap 排名上,币安排名第 1 ,OKEx 排名第 6,火币更是到了第 18 位。 火币、OKEx、币安过去被称为”三大交易所“,一直被认为是势均力敌的存在,此次排名为何相差如此悬殊? 据悉,由于CoinMarketCap修改了排名规则,排名不再按照交易量,而是按照网站流量。

ADA金色前哨 | 毛里求斯央行行长:将发行CBDC 不久将进行试点

金色财经讯,5月12日,毛里求斯央行行长Harvesh Seegolam证实,毛里求斯央行正在逐步接近发行专注于零售的中央银行数字货币(CBDC),毛里求斯共和国将在不久的将来进行试点。 Seegolam称,我们正处于一个阶段,我们都在考虑CBDC,对引入CBDC非常感兴趣,但有一些基本问题还未得到解决,只有这些关键的问题解决了我们才会推出CBDC。

欧易okex官网金色观察 | 2020年加密货币的三个机会还能抓住吗?

眼看着比特币马上要减半了,我们想要的减半行情还没有实现,2019年众多业内人士预测的10万美金遥遥无期。2020年第一个最大的机会要结束了吗? 2019年我们预测2020年的机会时,列举了很多关键词,包含有矿币减半、Eth2.0上线、波卡主网上线、Filecoin挖矿、Defi、产业联盟链等等,但实际结果表明,很多关键词代表的机会,都在市场考验中受挫。

[0:15ms0-0:499ms