A decentralised application (DApp,[1] dApp,[2] Dapp, or dapp) is an application that can operate autonomously, typically through the use of smart contracts, that run on a decentralized computing, blockchain or other distributed ledger system.[3] Like traditional applications, DApps provide some function or utility to its users. However, unlike traditional applications, DApps operate without human intervention and are not owned by any one entity, rather DApps distribute tokens that represent ownership.[3][4] These tokens are distributed according to a programmed algorithm to the users of the system, diluting ownership and control of the DApp.[4] Without any one entity controlling the system, the application is therefore decentralised.
Decentralised applications have been popularised by distributed ledger technologies (DLT), such as the Ethereum or Cardano blockchain, on which DApps are built, amongst other public blockchains.[5]
The trustless and transparent nature of DApps have led to greater developments in the utilisation of these features within the decentralized finance (DeFi) space.[6]
DApps are divided into numerous categories: exchanges, games, finance, gambling, development, storage, high-risk, wallet, governance, property, identity, media, social, security, energy, insurance, health, etc.[7][clarification needed]
There are a series of criteria that must be met in order for an application to be considered a DApp.
Traditional definitions of a decentralised application require a DApp to be open-source. That is, the application operates autonomously without a centralised entity in control of the majority of the application’s associated tokens.[3][4] DApps also have a public, decentralised blockchain that is used by the application to keep a cryptographic record of data, including historical transactions.[3][4]
Although traditional DApps are typically open-source, DApps that are fully closed-source and partially closed-source have emerged as the cryptocurrency industry evolves. As of 2019, only 15.7% of DApps are fully open-source while 25% of DApps are closed source. In other words, the proportion of DApps with publicly available code is less than the proportion of Dapps without publicly available code.[7] DApps that are open-source generally have higher transaction volumes than closed-source DApps.[7]
Secondly, tokens, required for application use and user rewards must be generated by the application as per a programmed algorithm or criteria. A portion of the application’s tokens is typically distributed at the beginning of the application’s operation.[4]
Lastly, the protocols of the application must be able to adapt in favor of majority consensus by the application’s users, such to make improvements to the application based on market feedback.[4]
Bitcoin, the first cryptocurrency, is an example of a DApp.[8]
Bitcoin is open-source. All transactions on the Bitcoin blockchain are open, public, immutable, and operates without the control of any centralized entity. This means every Bitcoin transaction since the beginning can be seen by everyone.[4] Bitcoin generates its own Bitcoin tokens, through block rewards to miners for securing the network.[4] Block rewards are halved every 210,000 blocks mined, or roughly every four years, to limit the inflationary effects on Bitcoin; thus, capping the number of total Bitcoins at 21 million.[9] Changes to Bitcoin must be made through Bitcoin’s proof-of-work mechanism which can only be done by majority consensus of Bitcoin’s users.[4]
DApps can be classified based on whether they operate on their own block chain, or whether they operate on the block chain of another DApp. By this classification, DApps are divided into three types.[citation needed]
Type I DApps operate on their own block chain. Block chains such as Bitcoin and Ethereum can be classified as Type I DApps.[4]
Type II DApps are protocols that operate on the block chain of a Type I DApp. These protocols themselves have tokens that are required for their function.[4]
Type III DApps are protocols that operate using the protocols of a Type II DApp. Similar to Type II DApps, Type III DApps also have tokens that are required for their function.[4]
Smart contracts are used by developers to maintain data on the block chain and to execute operations.[7] Multiple smart contracts can be developed for a single DApp to handle more complex operations.[7] Over 75% of DApps are supported by a single smart contract, with the remainder using multiple smart contracts.[7]
DApps incur gas, that is fees paid to the validators of the block chain, due to the cost of deploying and executing the DApp's smart contracts.[7] The amount of gas required of a DApp's functions is dependent on the complexity of its smart contracts.[7] A complex smart contract of a DApp that operates on the Ethereum blockchain may fail to be deployed if it costs too much gas, leading to lower throughput and longer wait times for execution.[7]
Consensus mechanisms are used by DApps to establish consensus on the network. The two most common mechanisms to establish consensus are proof-of-work (POW) and proof-of-stake (POS).[4]
Proof-of-work utilises computational power to establish consensus through the process of mining.[10] Bitcoin uses the proof-of-work mechanism.[10] Proof-of-stake is a consensus mechanism that supports DApps through validators that secure the network by having a stake and percent ownership over the application.[10]
DApps distribute their tokens through three main mechanisms: mining, fund-raising and development.[4] In mining, tokens are distributed as per a predetermined algorithm as rewards to miners that secure the network through transaction verification.[4] Tokens can also be distributed through fundraising, whereby tokens are distributed in exchange for funding in the initial development phase of the DApp, as in an initial coin offering.[4] Lastly, the development mechanism distributes tokens that are set aside for the purpose of developing the DApp through a pre-determined schedule.[4]
There are three main steps that always occur in the formation and development of any DApp: the publishing of the DApp’s whitepaper, the distribution of initial tokens, and the distribution of ownership.[4] Firstly, the whitepaper is published, describing the DApp’s protocols, features and implementation.[4] Then, required software and scripts are made available to the miners and stakeholders that support the validation and fundraising of the network.[4] In exchange, they are rewarded with the initial tokens distributed by the system.[4] Lastly, as greater numbers of participants join the network, either through utilisation of the DApp or through contributions to the DApp’s development, token ownership dilutes, and the system becomes less centralised.[4]
DApps have their backend code running on a decentralized peer-to-peer network, as opposed to typical applications where the backend code is running on centralized servers. A DApp can have frontend code and user interfaces written in any language that can make calls to its backend.
DApps have been utilized in decentralized finance (DeFi), in which dapps perform financial functions on blockchains.[11] Decentralized finance validating peer-to-peer transactions to disrupt centralized finance and lower the cost.[12]
All the DApps have an identifying code that may only work on a specific platform. Not all DApps work on standard web browsers. Some of them only work on special websites with a customized code, adjusted to open certain DApps.[13]
The performance of a DApp is tied to its latency, throughput, and sequential performance.[14] Bitcoin's system for transaction validation is designed so that the average time for a Bitcoin to be mined is 10 minutes.[14] Ethereum offers a reduced latency of one transaction every 15 seconds. For comparison, Visa handles approximately 10,000 transactions per second.[14][15] More recent DApp projects, such as Solana, have attempted to exceed that rate.[16]
Internet connectivity is a core dependency of blockchain systems, which includes DApps.[14] High monetary costs also act as a barrier. Transactions of small monetary values can comprises a large proportion of the transferred amount.[14] Greater demand for the service also leads to increased fees due to increased network traffic.[17] This is an issue for Ethereum, which is attributed to increased network traffic caused by DApps built on the Ethereum blockchain, such as those used by Non-fungible tokens (NFTs).[17] Transaction fees are affected by the complexity of a DApp's smart contracts, and by the particular blockchain.[7]
Ethereum is the distributed ledger technology (DLT) that has the largest DApp market.[7] The first DApp on the Ethereum blockchain was published on April 22, 2016.[7] From May 2017, the number of DApps being developed have grown at a higher rate.[7] After February 2018, DApps have been published every day.[7] Less than one fifth of DApps capture almost all the DApp users on the Ethereum blockchain.[7] About 5% of DApps capture 80% of Ethereum transactions.[7] 80% of DApps on Ethereum are used by less than 1000 users.[7] On Ethereum, DApps that are exchanges capture 61.5% of transaction volume, finance DApps capture 25.6%, gambling DApps capture 5%, high-risk DApps capture 4.1%, and games capture 2.5%.[7]
DApps have not achieved wide adoption. Potential users may not have the skill or knowledge to be able to effectively analyse the differences between DApps and traditional applications, and also may not value those differences. This skill and information can be difficult to access for mainstream users. Additionally, the user experience for DApps is often poor, as they are often developed to prioritize functionality, maintenance and stability.[18]
Many DApps struggle to attract users, particularly in their founding stages, and even those that attract widespread initial popularity struggle to retain it.[full citation needed]
A notable example was the DApp CryptoKitties, which heavily slowed down the Ethereum network at the height of its popularity.[19] CryptoKitties and another similar gaming-based DApp Dice Games have failed to attract similar traction since.[20][needs update]