比特币区块

比特币CPU挖矿、GPU挖矿、矿池及矿机挖矿技术原理

孤街醉人 提交于 2019-11-26 00:35:33
比特币挖矿原理   比特币的区块头,共含6个字段,如下:   int32_t nVersion,4字节,版本号,一般固定不变,仅在升级时改变。   uint256 hashPrevBlock,32字节,前一个区块的区块头哈希,由前一个区块决定。   uint256 hashMerkleRoot,32字节,包含进区块的所有交易构造的Merkle根,调整区块中的交易次序、增删交易、或修改Coinbase交易时改变。   uint32_t nTime,4字节,时间戳,后一个区块时间略早于前一个区块是被允许的,但必须在合理的时间区间,一般会直接使用机器当前时间戳。   uint32_t nBits,4字节,挖矿难度,由全网决定,每2016个区块按算法重新调整。   uint32_t nNonce,4字节,随机数,提供2^32种取值。即4,294,967,296。   其中nVersion、hashPrevBlock、nBits是固定的,其他hashMerkleRoot、nTime、nNonce为可变的。   比特币挖矿原理即,不断变更区块头中的可变值,使得对区块头做双重SHA256哈希,结果小于挖矿难度目标值。即:   SHA256D(BlockHeader) < F(nBits)   其中SHA256D(BlockHeader)即对区块头做双重SHA256哈希,F(nBits

PoW挖矿算法原理及其在比特币、以太坊中的实现

夙愿已清 提交于 2019-11-25 22:49:51
  PoW,全称Proof of Work,即工作量证明,又称挖矿。大部分公有链或虚拟货币,如比特币、以太坊,均基于PoW算法,来实现其共识机制。即根据挖矿贡献的有效工作,来决定货币的分配。 比特币区块   比特币区块由区块头和该区块所包含的交易列表组成。区块头大小为80字节,其构成包括:    4字节:版本号   32字节:上一个区块的哈希值   32字节:交易列表的Merkle根哈希值    4字节:当前时间戳    4字节:当前难度值    4字节:随机数Nonce值   此80字节长度的区块头,即为比特币Pow算法的输入字符串。   交易列表附加在区块头之后,其中第一笔交易为矿工获得奖励和手续费的特殊交易。   bitcoin-0.15.1源码中区块头和区块定义: class CBlockHeader { public: //版本号 int32_t nVersion; //上一个区块的哈希值 uint256 hashPrevBlock; //交易列表的Merkle根哈希值 uint256 hashMerkleRoot; //当前时间戳 uint32_t nTime; //当前挖矿难度,nBits越小难度越大 uint32_t nBits; //随机数Nonce值 uint32_t nNonce; //其它代码略 }; class CBlock : public

比特币原理详解

自古美人都是妖i 提交于 2019-11-25 19:59:05
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人分别称之为ABCD,他们之间发起了3个交易,A转给B10个比特币,B转给C5个比特币,C转给D2个比特币。如果是传统的记账方式,这些交易会记录在银行的系统中,这些信息由银行来记录,我们相信银行不会随意添加、删除或修改一条交易记录,我们也不会关注到底有哪些交易,我们只关注自己的账户余额。而比特币的记账方式为ABCD每个人保存了这样一份账本,账本上记录了上述交易内容,如果每个人账本实时的一致,ABCD就不再需要银行。 比特币是这样做的,每当有人发起一笔交易,他就要将一笔交易广播至全网,由全网中的某一个人,把一段时间内的交易打包好记录到一个区块上,再按照顺序把这些区块,一个一个的链接在一起,进而形成了一个链条,这就是所谓的区块链。 那么问题来了 1、我凭什么要参与这个系统,我为什么要动用自己的计算机资源来存储这些信息呢? 2、以谁的记录为准呢?比如上面的账单顺序,A用户可能是这个顺序