CEX.IO News

Why you should never send your BCH to BTC address

, May 13, 2020

In the Bitcoin and Bitcoin Cash networks, addresses have the same format and look similar. This is confusing, and many people mistakenly send Bitcoin Cash (BCH) coins to Bitcoin (BTC) wallets. However, these two currencies run on separate blockchains. That means when you send your BCH to a BTC wallet, your coins may be gone for good.

In this post, we look deeply into the differences between BCH and BTC and explain why it’s important to be super attentive when transferring crypto.

 

📚 Background

 

The Bitcoin Cash (BCH) network was created with the idea to increase the number of transactions that can be processed each second compared to Bitcoin.

The only way to update the Bitcoin blockchain is with a hard fork. So BCH developers split from the BTC network and literally created a new blockchain with modified rules. Bitcoin Cash uses the same codebase but with a block size limit of 8 MB and without support for SegWit* transactions and addresses. BCH developers believed that with increased block size, the network could handle more transactions per second. For comparison, at the time of the split, Bitcoin Core (BTC) had a block size limit of 1 MB.

When Bitcoin Cash was created, it shared the same address format as Bitcoin. As a result, BCH and BTC holders were mixing up addresses. A lot of users sent their BCH coins to BTC SegWit wallets, which are not supported by the BCH network. Therefore, the coins simply got stuck in the blockchain with no way to restore them.

*SegWit stands for Segregated Witness. It’s the name of protocol updates for increasing BTC network scalability. SegWit removes the signature (witness) from the middle of transaction data and places it at the end, outside the block. Thus, SegWit makes transaction sizes notably smaller, allowing more transactions to be processed in one block.

 

☝️ Avoiding errors when transferring BCH

 

How can you prevent your funds from getting stuck or lost in the network? Well, the answer is simple: double-check the wallet address you’re sending crypto to.

In order to avoid confusion with addresses, BCH developers later proposed a new unique format for BCH wallets. It’s called CashAddr, and it has a totally different format that starts with bitcoincash: or a lowercase q or p. You can easily compare the old legacy format to the new Cashaddr format on the BCH deposit page on CEX.IO.

Screen Shot 2020-05-06 at 10.07.23.png

 

Thanks to the new format, the number of mistaken transactions decreased. However, the possibility to send BCH coins to BTC addresses still exists, and up to 18,000 BCH remain stuck in the network.

 

🤔 What happens to these mistaken transactions?

 

It’s possible to mine the BCH coins sent to BTC SegWit addresses, but it requires hard effort.

In 2018 and 2019, some mining pools managed to claim back a lot of lost coins and return them to their individual owners. They got access to the stuck transactions by using a non-standard Bitcoin Cash transaction script available only for Bitcoin Cash miners. Regular users cannot send the necessary type of transaction to the blockchain.

Still, not all miners agreed to return funds to the owners. There’s still a buzz around one unknown miner who managed to mine enough blocks to sweep about 9,000 BCH. This lucky individual took all the coins as their own instead of returning them to their owners.

Meanwhile, BCH developers are still trying to fix the issue and make it impossible to access BCH coins that are locked in the network.

 

🛠 What CEX.IO has done to prevent users from sending BCH to BTC wallet addresses

 

Currently, CEX.IO has no technical possibility to restore BCH coins that are sent to BTC addresses. The reason is that we do not have access to those coins — they are locked in the BCH network. This is not a shortcoming of CEX.IO or any other exchange but rather a vulnerability of the Bitcoin Cash network.

With the aim to prevent users from sending BCH to BTC addresses, CEX.IO has an integrated address validator. This validator automatically recognizes the wallet format and doesn’t allow users to withdraw BCH to BTC addresses. However, we cannot prevent users from sending BCH from external platforms to BTC addresses on CEX.IO. So take this risk seriously and double-check the information you enter when transferring funds.

Over the years, BCH developers and technical teams of other crypto platforms have been trying to find a solution to prevent loss of funds. Remember that you’re the only one who has control over your funds and only you can confirm a deposit or withdrawal operation. Always check the currency you’re sending and the destination wallet. Even a little mistake can send your funds to the wrong wallet address. Sometimes, with complicated and costly technical efforts, it’s possible to restore lost coins. However, there’s no way to return BCH coins sent to a BTC SegWit address.

If you aren’t sure about your wallet address or have any questions, you can easily contact the CEX.IO Customer Support Team by phone or via the form on our Help Center. You may also find our guides on crypto deposits and withdrawals helpful:

 

Related

CEX.IO News

Free Deposits via Bank Transfer

Great news! Now you can fund your CEX.IO account for free using wire transfer. 0% deposit fee applies to USD, EUR, and GBP. Deposits via SEPA are free of charge as well, which is great if you are used to fund account in EUR. You can find out more

Feb 16, 2017 | 1 min read
CEX.IO News

Black Friday Week on CEX.IO: 5% cashback on crypto purchases via Instant Buy option

We’re launching Black Friday Week with a special offer! Buy crypto via our Instant Buy service and get the 5% cashback to your CEX.IO account.

Nov 23, 2020 | 4 min read
CEX.IO News

CEX.IO’s White Paper – COMPASS: Topline Trends for the Crypto Curious and Serious

The CEX.IO COMPASS examines the biggest events in crypto and how they influenced the market. This report sheds light on the digital asset ecosystem’s performance for the first half of this year.

Jul 14, 2022 | 3 min read