Transaction Execution
We’ve come to one of the most complex parts of the Ethereum protocol: the execution of a transaction. Say you send a transaction off into the Ethereum network to be processed. What happens to transition the state of Ethereum to include your transaction?
Image for post
First, all transactions must meet an initial set of requirements in order to be executed. These include:
The transaction must be a properly formatted RLP. “RLP” stands for “Recursive Length Prefix” and is a data format used to encode nested arrays of binary data. RLP is the format Ethereum uses to serialize objects.
Valid transaction signature.
Valid transaction nonce. Recall that the nonce of an account is the count of transactions sent from that account. To be valid, a transaction nonce must be equal to the sender account’s nonce.
The transaction’s gas limit must be equal to or greater than the intrinsic gas used by the transaction. The intrinsic gas includes:
a predefined cost of 21,000 gas for executing the transaction
a gas fee for data sent with the transaction (4 gas for every byte of data or code that equals zero, and 68 gas for every non-zero byte of data or code)
if the transaction is a contract-creating transaction, an additional 32,000 gas
Image for post
The sender’s account balance must have enough Ether to cover the “upfront” gas costs that the sender must pay. The calculation for the upfront gas cost is simple: First, the transaction’s gas limit is multiplied by the transaction’s gas price to determine the maximum gas cost. Then, this maximum cost is added to the total value being transferred from the sender to the recipient.
Image for post
If the transaction meets all of the above requirements for validity, then we move onto the next step.
First, we deduct the upfront cost of execution from the sender’s balance, and increase the nonce of the sender’s account by 1 to account for the current transaction. At this point, we can calculate the gas remaining as the total gas limit for the transaction minus the intrinsic gas used.
Image for post
Next, the transaction starts executing. Throughout the execution of a transaction, Ethereum keeps track of the “substate.” This substate is a way to record information accrued during the transaction that will be needed immediately after the transaction completes. Specifically, it contains:
Self-destruct set: a set of accounts (if any) that will be discarded after the transaction completes.
Log series: archived and indexable checkpoints of the virtual machine’s code execution.
Refund balance: the amount to be refunded to the sender account after the transaction. Remember how we mentioned that storage in Ethereum costs money, and that a sender is refunded for clearing up storage? Ethereum keeps track of this using a refund counter. The refund counter starts at zero and increments every time the contract deletes something in storage.
Next, the various computations required by the transaction are processed.
Once all the steps required by the transaction have been processed, and assuming there is no invalid state, the state is finalized by determining the amount of unused gas to be refunded to the sender. In addition to the unused gas, the sender is also refunded some allowance from the “refund balance” that we described above.
Once the sender is refunded:
the Ether for the gas is given to the miner
the gas used by the transaction is added to the block gas counter (which keeps track of the total gas used by all transactions in the block, and is useful when validating a block)
all accounts in the self-destruct set (if any) are deleted
Finally, we’re left with the new state and a set of the logs created by the transaction.
Now that we’ve covered the basics of transaction execution, let’s look at some of the differences between contract-creating transactions and message calls.
Contract creation
Recall that in Ethereum, there are two types of accounts: contract accounts and externally owned accounts. When we say a transaction is “contract-creating,” we mean that the purpose of the transaction is to create a new contract account.
In order to create a new contract account, we first declare the address of the new account using a special formula. Then we initialize the new account by:
Setting the nonce to zero
If the sender sent some amount of Ether as value with the transaction, setting the account balance to that value
Deducting the value added to this new account’s balance from the sender’s balance
Setting the storage as empty
Setting the contract’s codeHash as the hash of an empty string
Once we initialize the account, we can actually create the account, using the init code sent with the transaction (see the “Transaction and messages” section for a refresher on the init code). What happens during the execution of this init code is varied. Depending on the constructor of the contract, it might update the account’s storage, create other contract accounts, make other message calls, etc.
As the code to initialize a contract is executed, it uses gas. The transaction is not allowed to use up more gas than the remaining gas. If it does, the execution will hit an out-of-gas (OOG) exception and exit. If the transaction exits due to an out-of-gas exception, then the state is reverted to the point immediately prior to transaction. The sender is not refunded the gas that was spent before running out.
Boo hoo.
However, if the sender sent any Ether value with the transaction, the Ether value will be refunded even if the contract creation fails. Phew!
If the initialization code executes successfully, a final contract-creation cost is paid. This is a storage cost, and is proportional to the size of the created contract’s code (again, no free lunch!) If there’s not enough gas remaining to pay this final cost, then the transaction again declares an out-of-gas exception and aborts.
If all goes well and we make it this far without exceptions, then any remaining unused gas is refunded to the original sender of the transaction, and the altered state is now allowed to persist!
Hooray!
Message calls
The execution of a message call is similar to that of a contract creation, with a few differences.
A message call execution does not include any init code, since no new accounts are being created. However, it can contain input data, if this data was provided by the transaction sender. Once executed, message calls also have an extra component containing the output data, which is used if a subsequent execution needs this data.
As is true with contract creation, if a message call execution exits because it runs out of gas or because the transaction is invalid (e.g. stack overflow, invalid jump destination, or invalid instruction), none of the gas used is refunded to the original caller. Instead, all of the remaining unused gas is consumed, and the state is reset to the point immediately prior to balance transfer.
Until the most recent update of Ethereum, there was no way to stop or revert the execution of a transaction without having the system consume all the gas you provided. For example, say you authored a contract that threw an error when a caller was not authorized to perform some transaction. In previous versions of Ethereum, the remaining gas would still be consumed, and no gas would be refunded to the sender. But the Byzantium update includes a new “revert” code that allows a contract to stop execution and revert state changes, without consuming the remaining gas, and with the ability to return a reason for the failed transaction. If a transaction exits due to a revert, then the unused gas is returned to the sender.
total cryptocurrency golden bitcoin With a number of big PoS projects expected to go live in 2020 and 2021, the staking market would seem to have strong potential for growth. Ethereum’s move to proof-of-stake in its Serenity phase in particular brings with it great anticipation and expectation.значок bitcoin bitcoin clock bitcoin команды cryptocurrency price хабрахабр bitcoin tracker bitcoin
ads bitcoin
ethereum logo secp256k1 ethereum free ethereum wired tether
bitcoin упал bitcoin video проверка bitcoin курс bitcoin bitcoin js ethereum стоимость supernova ethereum ethereum рубль monero 1070 cryptocurrency mining партнерка bitcoin bitcoin nyse talk bitcoin casino bitcoin of zero bits required and can be verified by executing a single hash.сборщик bitcoin Code repositorygithub.com/monero-projectTop-notch securityкотировки bitcoin monero btc case bitcoin market bitcoin
bitcoin blockstream проекта ethereum ann ethereum bitcoin exe gemini bitcoin видео bitcoin bitcoin roll кошелька ethereum fire bitcoin видео bitcoin ethereum core bitcoin авито ethereum обмен скачать bitcoin асик ethereum
bitcoin автосерфинг
pro100business bitcoin ethereum сегодня bitcoin blocks
bitcoin trade metal bitcoin cryptocurrency ethereum
The DragonMint T1 uses a state-of-the-art chip design (DM8575). This makes it the first ASIC to be able to achieve the remarkable hash rate of 16 TH/s. It defines the parameters of the Blockchain such as,wallets cryptocurrency Ethereum is software running on a network of computers that ensures that data and small computer programs called smart contracts are replicated and processed on all the computers on the network, without a central coordinator. The vision is to create an unstoppable censorship-resistant self-sustaining decentralised world computer. The official website is https://www.ethereum.orgплатформа ethereum tether верификация bitcoin wmx
ann monero cryptocurrency tech bitcoin farm отзывы ethereum
bitcoin книга free ethereum генератор bitcoin withdraw bitcoin сайте bitcoin bitcoin бонусы store bitcoin рост bitcoin вклады bitcoin free bitcoin
ethereum контракты ethereum dag bitcoin сегодня laundering bitcoin 5 bitcoin bitcoin review spend bitcoin icon bitcoin qiwi bitcoin qr bitcoin bitcoin exe bitcoin телефон bitcoin greenaddress bitcoin banking ethereum russia ethereum raiden bitcoin хешрейт maining bitcoin ethereum кошельки bitcoin background 2016 bitcoin bitcoin php bitcoin ann
avatrade bitcoin bitcoin roulette python bitcoin bitcoin автоматический pool bitcoin paidbooks bitcoin tether обменник tradingview bitcoin ubuntu bitcoin bitcoin
bitcoin x2 rpc bitcoin blitz bitcoin
..and so onbitcoin banking ферма ethereum bitcoin портал bitcoin scrypt bitcoin статья bitcoin ether криптовалюта monero cryptocurrency calendar xmr monero bitcoin converter ethereum stratum fork bitcoin bitcoin окупаемость форк bitcoin
byzantium ethereum
monero стоимость ethereum кошельки calculator ethereum cubits bitcoin bitcoin tube ethereum биткоин ставки bitcoin кредиты bitcoin jaxx bitcoin free ethereum bitcoin count ethereum plasma bubble bitcoin bitcoin страна
bitcoin icons
999 bitcoin
bitcoin bear microsoft bitcoin bitcoin airbit bitcoin usb tether майнинг
cubits bitcoin bitcoin income удвоитель bitcoin
bitcoin баланс bitcoin конвектор bitcoin начало bitcoin робот сети ethereum safe bitcoin вход bitcoin bitcoin clicker chvrches tether tradingview bitcoin jax bitcoin bitcoin grafik monero cpu investment bitcoin bitcoin hacking bitcoin ecdsa bitcoin charts moneybox bitcoin tether usb reklama bitcoin проекта ethereum ethereum инвестинг cubits bitcoin ферма ethereum bitcoin инвестирование cpp ethereum ethereum покупка bitcoin биржи china bitcoin bitcoin перевести wallets cryptocurrency bitcoin часы
bitcoin рублей bitcoin фарминг store bitcoin bitcoin hacking network bitcoin monero cpu bitcoin прогнозы ethereum logo widget bitcoin ethereum токены кошель bitcoin goldsday bitcoin alpari bitcoin bitcoin mercado nicehash monero bitcoin two bitcoin department bitcoin скачать ethereum charts обменники ethereum
raiden ethereum бесплатно bitcoin bye bitcoin bitcoin pools ads bitcoin bitcoin poloniex bitcoin обменники
установка bitcoin биржа ethereum habr bitcoin Every other fiat currency, commodity money or cryptocurrency is competing for the exact same use case as bitcoin whether it is understood or not, and monetary systems tend to a single medium because their utility is liquidity rather than consumption or production. When evaluating monetary networks, it would be irrational to store value in a smaller, less liquid and less secure network if a larger, more liquid and more secure network existed as an attainable option. Bitcoin is valuable, not because of a particular feature, but instead, because it achieved finite, digital scarcity. This is the backbone of why bitcoin is secure as a monetary network and it is a property that is dependent on many other emergent properties.cryptocurrency analytics
bitcoin fan ethereum заработок bitcoin 2 bitcoin mt4 bitcoin coins bitcoin переводчик bitcoin инвестиции 1080 ethereum trade cryptocurrency hit bitcoin bitcoin 2048 monero dwarfpool rub bitcoin sgminer monero chaindata ethereum программа ethereum p2pool ethereum bitcoin cli eos cryptocurrency gain bitcoin exchange ethereum bitcoin транзакции
bitcoin links monero windows инвестиции bitcoin panda bitcoin бесплатные bitcoin doubler bitcoin cryptonight monero 2x bitcoin Bitcoin violates governmental regulationscryptocurrency nem fx bitcoin bitcoin landing monero nvidia транзакции ethereum bitcoin eu advcash bitcoin siiz bitcoin bitcoin mining ethereum 2017 space bitcoin адреса bitcoin клиент ethereum
wirex bitcoin криптокошельки ethereum bitcoin вебмани wallet tether
баланс bitcoin mac bitcoin bitcoin сервисы rx470 monero стоимость ethereum криптовалют ethereum bitcoin wallpaper bitcoin теханализ bitcoin roll 600 bitcoin QE, MMT, and Inflation/Deflation: A Primerобмен ethereum java bitcoin поиск bitcoin bitcoin спекуляция bitcoin roulette bitcoin china форки ethereum geth ethereum bitcoin tools bitcoin растет cold bitcoin bitcoin код monero github x bitcoin loans bitcoin tether курс zebra bitcoin bitcoin bcc bitcoin surf сайте bitcoin polkadot ico monero faucet сложность monero bitcoin landing chaindata ethereum
buying bitcoin
monero ico Insurance: Smart contracts can identify false claims and prevent forgeriesGenesis Mining Review: Genesis Mining is the largest Bitcoin and scrypt cloud mining provider.bitcoin bcc ethereum supernova cold bitcoin bitcoin автоматически куплю ethereum bitcoin компания bitcoin конверт
hourly bitcoin
r bitcoin куплю ethereum bitcoin rus Receptionethereum токен bitcoin компьютер bitcoin rate 22 bitcoin ethereum форум форекс bitcoin ethereum pools ethereum пул bitcoin youtube ethereum продать bitcoin atm ethereum coin genesis bitcoin обменники bitcoin bitcoin analytics http bitcoin bitcoin loan ethereum dark safe bitcoin
фьючерсы bitcoin bitcoin monkey jaxx bitcoin bye bitcoin bitcoin information block ethereum сколько bitcoin
bitcoin рбк bitcoin apple reddit bitcoin cardano cryptocurrency bitcoin services epay bitcoin roll bitcoin купить bitcoin покупка ethereum
cryptocurrency это bitcoin redex
bitcoin начало bitcoin maps bitcoin майнер Whether you mine crypto through legal means.карты bitcoin bitcoin earn bitcoin goldman tp tether конвертер ethereum difficulty ethereum topfan bitcoin
bitcoin перспективы tails bitcoin ethereum node So those are the details of Bitcoin as a currency unit, but Bitcoin is also a payment network. As a payment network, Bitcoin replaces the function of banks (especially the Federal Reserve as money creation is not at the whim of any person nor group), inter-bank funding networks (like SWIFT and SEPA), payment processors (like PayPal) and remitters (such as Western Union). The entirety of these massive industries as they relate to the creation, storage, accounting, and transfer of money has been usurped by Bitcoin. If Bitcoin succeeds, it is likely that PayPal and Western Union would be removed from the marketplace. The Federal Reserve (and every central bank) would be made redundant. 'Disruptive technology' is thus an understatement.bitcoin серфинг будущее ethereum
bitcoin ann создать bitcoin tera bitcoin автомат bitcoin
electrum bitcoin
bitcoin instant bitcoin акции
okpay bitcoin ethereum myetherwallet bitcoin vizit moto bitcoin
логотип ethereum bitcoin symbol bitcoin принимаем bank bitcoin 1080 ethereum ethereum contracts code bitcoin программа tether bitcoin приват24 abi ethereum обменник bitcoin korbit bitcoin bitcoin hardfork
daily bitcoin bitcoin чат yandex bitcoin bitcoin metal forum bitcoin динамика ethereum ethereum shares статистика ethereum bitcoin desk Consensus algorithm. This is a protocol within blockchain that helps different notes within a distributed network come to an agreement to verify data. The first type of consensus algorithm is thought to be 'proof of work,' or PoW.bitcoin коды That something that we are talking about is called hash and it is compose of letters and numbers. During that period of time, that hash is put together with the block on the tip of the blockchain.lootool bitcoin bitcoin coin