What is Double Spending & How Does Bitcoin Handle It?

5 stars based on 57 reviews

One article I am reading said that proof of work system is used in Bitcoin to prevent double spending. Imagine we are protecting against double spending in following way. When Bob receives transaction from Alice saying that "Alice transfers some BTC to Bob", bob would broadcast this to entire network to ask them to verify whether this is a legitimate transaction.

In the mean time say if Alice had sent also same message to Charlie saying that she is transfering same BTC to CharlieCharlie would have also broadcast this message and other nodes on the network would spot that Alice is trying to spend same BTC bitcoin double spend example two persons, and they would let Bob or Charlie know that this is invalid transaction.

Or if all is ok Bob or Charlie would wait till some nodes send acknowledgment that this is valid transaction. Above scheme would work but Alice could bitcoin double spend example in the following way. She could create say one million fake identities on network, and they would lie to Bob and Charlie that the transactions was valid- making them accept payment.

Now comes my question. It seems proof of work was introduced in Bitcoin to prevent exactly the above kind of sock poppet attack. But I fail to see bitcoin double spend example proof of work helps protect against above sock puppet attack. Why would Alice not be able to introduce those fake identities on the network anymore? I know what proof of work is, this question is more related how and why it prevents above mentioned sock puppet attack.

It is not really the Proof of Work which prevents double spends but rather the blockchain itself which prevents double spends. The Proof of Work is just one aspect of the blockchain. For a transaction to be considered final, it must be in the blockchain.

Otherwise it could disappear forever and everyone forgets about it. For a transaction bitcoin double spend example be added to the blockchain, it must be included in a block, and miners will do a Proof of Work for the block. In order for the transaction to be included in a block, the outputs that it spends from must have not been spent by any other transaction in the blockchain nor by any other transaction in the block.

If such an other transaction exists in the blockchain, then the block will be invalid. Bitcoin double spend example is this process of including transactions in blocks which avoids double spends. It essentially establishes an order and says "this transaction is the real transaction, all others which spends any of the outputs which this transaction spends are fake". The proof of work mechanism exists in Bitcoin because that is what makes the blockchain immutable.

A valid proof of work means that a miner is proving that they did a certain amount of work, on average, in order to produce a block. In order to replace that block, someone bitcoin double spend example must also do about the same amount of work for that block.

If someone wanted to modify a block in the blockchain and have everyone accept it, that person must perform the same amount of work that went into creating the block, then do the same for every single block that follows it because those blocks would be invalid since a block in their history has changed.

This makes the blockchain immutable; the amount of work required to rewrite history is considered to be infeasible and much too costly to do practically. That is what the Proof of Work is for. For a transaction to be valid it is not enough to be broadcasted bitcoin double spend example the attacker or repeated by many bitcoin double spend example. It must be added to the blockchain by some node in the network.

Adding the transaction to the blockchain is not easy, as some node in the network must make PoW, which is time and processing power consuming. Inside single chain transactions cannot collide. Each node accepts longest chain as valid one so for an attack to succede the attacker must maintain two equally long chains.

Then some nodes will accept one chain and others other chain as valid, thus allowing an attacker to spend bitcoin double spend example twice - within one transaction on one chain and other 'colliding' bitcoin double spend example on other chain. Thus there will exist in long term: As said, inside single chain transactions cannot colide, thus you cannot double spend.

Since the amount of computation required do Hash Guessing to send rogue messages is so high, it becomes impractical to do 1M impersonation requests. One can steal private keys of other nodes to create transactions on their behalf, but still bitcoin double spend example would follow Blockchain consensus principles.

If Alice owns majority of the Blockchain nodes, then she can authenticate a rogue transaction using the consensus. Faking identities is quite difficult and the scenarios why it will eventually fail has been explained in croraf's answer.

By posting your answer, you agree to the privacy policy and terms of service. Questions Tags Users Badges Unanswered. Bitcoin Stack Exchange is a question and answer site for Bitcoin crypto-currency bitcoin double spend example. Join them; it only takes a minute: Here's how it works: Anybody can ask a question Anybody can answer The best answers are voted up and rise to the top.

How proof of work prevents double spend. Can someone ealaborate and explain? Only block chain would not suffice. All nodes have blockchain locally. So as in question if alice simultaneously sends same transaction to bob and charlie in both users' blockchain it would seem that the transaction is valid bitcoin double spend example that coin has not been spent yet.

So you need a consesus protocol where bob and charlie would ask for example whole network if the transaction they receive is OK. That's not how the blockchain works. The blockchain is the consensus protocol where Bob and Charlie asks the network whether the transaction they receive is ok. The blockchain is not something that is added to locally when new transactions are received.

It is added to locally when new blocks are received, and new blocks can only be created by performing the proof of work. Blocks and transactions must also conform to the consensus rules that the node is following. Those rules also include double spend protection. Here is article I referred to: And besides can you then explain maybe in answer WHY proof of work was added to bitcoin?

The Sock Puppet reference Why would Alice not be able to introduce those fake identities on the network anymore? She could create say one million fake identities bitcoin double spend example network Sign up or log in Sign up using Google.

Sign up using Facebook. Sign up using Email and Password. Post as a guest Name. Stack Overflow for Teams is Now Available. Bitcoin Stack Exchange works best with JavaScript enabled.

Dogecoin difficulty next

  • Asic bitcoin miner software for windows 10

    Bittrex cannot withdraw

  • Trabalhos bitcoin faucet bot

    Cloud based litecoin mining machines

Profit trading bot review

  • Can you make money bitcoin mining 2014 world

    Bitcoin price prediction in next 12h currenttime = 20180403 170647015325

  • Winklevoss twins bitcoin value graph

    Compatibilidade signos sagitario e leao

  • Bitcoin live trading chart

    Demand for bitcoin in japan continues to grow

Bitcoin machine in pakistan vaccine

24 comments Dodge dice bot bitcointalk gawminers

Chris derose bitcoin mining

Vor 5 Monate Tradingis Fun what app do you use to get trade recommendation window popup. By increasing demand for them, the government hopes prices will rise. To exploit this difference, you would have to send dollars to Bitfinex and command them to make what appear to be fraudulent transfers on your behalf. Vous trouverez les reponses a toutes vos questions.