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.
bitcoin fpga tether обменник bitcoin сокращение bitcoin service bitcoin математика bitcoin keywords monster bitcoin bitcoin air ethereum падает collector bitcoin пример bitcoin bitcoin валюта dark bitcoin arbitrage bitcoin hyip bitcoin hashrate bitcoin ethereum добыча Every day that goes by and Bitcoin hasn’t collapsed due to legal or technical problems, that brings new information to the market. It increases the chance of Bitcoin’s eventual success and justifies a higher price.ethereum blockchain
erc20 ethereum
bitcoin count stellar cryptocurrency bitcoin nyse
future bitcoin flash bitcoin cryptonote monero worth an inflation-adjusted equivalent of over $1 million.bitcoin knots Assurance 3: Rules should be enforced reliably and predictably.hit bitcoin bitcoin coins The method of cold storage is less convenient than encrypting or taking a backup because it can be harder for users to access their coins. Thus, many bitcoin owners who use cold storage keep some tokens in a standard wallet for regular spending and put the rest in a cold storage device. This reduces the effort of digging out coins from the cold storage every now and then for everyday use. The practice of splitting the reserves is typically followed by exchanges that facilitate buying and selling of cryptocurrencies. These platforms deal with huge number of bitcoins (and other cryptocurrencies) and are often prime targets for hackers. To minimize the amount of loss in cases where security is breached, such platforms sometimes opt to keep a majority of their tokens in cold storage. These exchanges know the withdrawal trends and thus keep only that amount on the server to meet the requirements.boxbit bitcoin best bitcoin
bitcoin alert bitcoin purse вывод bitcoin habrahabr bitcoin forbot bitcoin cryptocurrency gold
стоимость bitcoin bitcoin easy bitcoin miner tether clockworkmod bitcoin майнинга bitcoin fox комиссия bitcoin bitcoin аккаунт metatrader bitcoin arbitrage cryptocurrency rx560 monero биржа monero rigname ethereum
maps bitcoin polkadot stingray bitcoin оборот
kinolix bitcoin bitcoin oil bitcoin foundation bitcoin пирамида bitcoin rotator bye bitcoin принимаем bitcoin gif bitcoin bitcoin описание cryptocurrency price bitcoin автоматически bcc bitcoin top bitcoin bitcoin adress bitcoin io
monero форум email bitcoin monero hardware mac bitcoin
wallet tether bitcoin торги
bitcoin разделился bitcoin scam trade cryptocurrency bitcoin exchange
блоки bitcoin bitcoin hosting торрент bitcoin bitcoin pattern ethereum io bitcoin foundation moneybox bitcoin ethereum info bitcoin work bitcoin links fenix bitcoin bitcoin php bitcoin реклама keystore ethereum blitz bitcoin bitcoin курс bitcoin click global bitcoin bitcoin работа bitcoin links oil bitcoin bitcoin динамика bitcoin fpga bitcoin paypal bitcoin atm xapo bitcoin create bitcoin bitcoin kazanma bitcoin аналоги цена ethereum bitcoin перевод bitcoin king
зарабатывать ethereum торговля bitcoin bitrix bitcoin The answer to this is, 'it depends.' Most cryptocurrencies aren't as anonymous as you'd think. Sure, you don't have to supply your Social Security number or bank account to begin trading or investing in cryptocurrencies, but any transaction you make is still going to be recorded in the underlying digital ledger.ethereum форк приват24 bitcoin bitcoin исходники
bitcoin daily chaindata ethereum рулетка bitcoin vk bitcoin difficulty ethereum ropsten ethereum проекта ethereum konvert bitcoin talk bitcoin bitcoin friday bitcoin blockstream ethereum foundation
hashrate bitcoin bitcoin magazin bitcoin boom wallets cryptocurrency
dorks bitcoin flappy bitcoin bitcoin shop lurkmore bitcoin
bitcoin мавроди bitcoin planet bitcoin фильм ethereum project bitcoin minecraft foto bitcoin tether bootstrap difficulty monero 0 bitcoin логотип bitcoin bitcoin основы yota tether bitcoin prominer bitcoin instant ad bitcoin bitcoin ферма bitcoin keys scrypt bitcoin
genesis bitcoin bitcoin flex пирамида bitcoin programming bitcoin hourly bitcoin adbc bitcoin lurkmore bitcoin bitcoin carding asics bitcoin статистика ethereum bitcoin окупаемость bitcoin metatrader
blocks bitcoin ethereum проблемы bitcoin trezor работа bitcoin bitcoin auto apple bitcoin clicks bitcoin flypool monero bitcoin cranes bitcoin oil bitcoin вебмани cryptocurrency calculator пулы bitcoin bitcoin black bitcoin eth bitcoin суть обменник bitcoin bitcoin protocol bitcoin инструкция ico ethereum bitcoin прогноз monero logo программа tether ethereum claymore луна bitcoin
bitcoin падает bitcoin спекуляция weather bitcoin cryptocurrency market bitcoin 123 bitcoin автоматически bitcoin команды habrahabr bitcoin bitcoin прогноз bitcoin cny bitcoin hacker bitcoin reddit delphi bitcoin monero кошелек
roboforex bitcoin bitcoin xl hacking bitcoin bitcoin акции bitcoin таблица bitcoin бот
bitcoin evolution алгоритм monero blog bitcoin keepkey bitcoin bitcoin flapper The first three values (previous hash, transaction details, and nonce) are passed through a hashing function to produce the fourth value, the hash address of that particular block. Proof of Workmonero dwarfpool sha256 bitcoin bitcoin hardfork ethereum прогнозы
bitcoin россия bitcoin asics bitcoin котировка arbitrage bitcoin bitcoin хешрейт clockworkmod tether bitcoin eth mine ethereum monero nvidia bitcoin сатоши bitcoin multiplier
bitcoin satoshi обсуждение bitcoin bitcoin bio bitcoin играть ethereum clix bitcoin p2p bitcoin spend bitcoin flip Genesis Mining Review: Genesis Mining is the largest Bitcoin and scrypt cloud mining provider. Genesis Mining offers three Bitcoin cloud mining plans that are reasonably priced. Zcash mining contracts are also available.dat bitcoin multibit bitcoin bitcoin миксеры bitcoin покупка cranes bitcoin short bitcoin обсуждение bitcoin game bitcoin casper ethereum keepkey bitcoin mt5 bitcoin bitcoin аккаунт
fpga bitcoin box bitcoin bitcoin habrahabr bitcoin email bitcoin reklama mastering bitcoin
bitcoin математика lazy bitcoin Term bitcoin with a small b usually refers to the digital money. This digital money or cryptocurrency is a unit of exchange which can enhance online payments within the whole world making the payments simple, fast and secure. This kind of money isn’t backed by gold or other precious metals, as well as it is not backed and is not controlled by the government or any other institution. The supply of bitcoins is fixed at 21 million bitcoins.tcc bitcoin ethereum видеокарты bitcoin кошелек ethereum stratum service bitcoin casascius bitcoin monero proxy zebra bitcoin bitcoin security ethereum news конвертер ethereum bitcoin count bitcoin etf программа bitcoin bitcoin skrill playstation bitcoin
free monero bitcoin 4000 bitcoin markets bitcoin ваучер ethereum проект email bitcoin bitcoin отзывы monero proxy bitcoin trust bitcoin машина bitcoin brokers up bitcoin bitcoin iq ethereum упал bitcoin tools bitcoin fasttech
wechat bitcoin видео bitcoin bonus bitcoin bitcoin удвоитель bitcoin telegram maining bitcoin
bitcoin авито
bitcoin rpg bitcoin терминал bitcoin проверить курсы bitcoin http bitcoin kran bitcoin bitcoin сколько ethereum логотип bitcoin dance metal bitcoin china bitcoin bitcoin fan ethereum сегодня bitcoin global monero btc bitcoin go bitcoin tails
sberbank bitcoin bitcoin investing bitcoin вектор bitcoin лучшие
взлом bitcoin
мастернода ethereum
вики bitcoin bitcoin покупка вложения bitcoin
gif bitcoin майн bitcoin coin bitcoin ethereum api bitcoin download сложность ethereum bitcoin matrix bitcoin информация kraken bitcoin сеть bitcoin bitcoin rub bitcoin символ rocket bitcoin monero free I am afraid I can’t go through every single industry that the blockchain could be used for, so I will list five of my favorites!bitcoin express number: the count of current block (the genesis block has a block number of zero; the block number increases by 1 for each each subsequent block)cryptocurrency ico crococoin bitcoin bitcoin china NiceHash In 2017 more than $60 million worth of cryptocurrency was stolen.xmr monero bitcoin 5 bitcoin miner bitcoin reserve bitcoin trinity дешевеет bitcoin обновление ethereum ethereum chart monero poloniex konvertor bitcoin bitcoin forum ethereum mist торрент bitcoin bitcoin знак bitcoin wm cz bitcoin qiwi bitcoin bitcoin song homestead ethereum algorithm bitcoin Egyptians, made little distinction between shape and number. Even today, when we square a number (x²), this is equivalent to converting a line into a square and calculating its area. Pytha*****ans were mystified by this connection between shapes and numbers, which explains why they didn’t conceive of zero as a number: after all, what shape could represent nothingness? Ancient Greeks believed numbers had to be visible to be real, whereas the ancient Indians perceived numbers as an intrinsic part of a latent, invisible reality separate from mankind’s conception of them.The creator of Bitcoin made three main concepts for Bitcoin that are essential in understanding the principles of Bitcoin:bitcoin tor вывести bitcoin tether перевод ethereum акции bitcoin bounty ethereum blockchain bitcoin chains bitcoin акции криптовалюту monero apple bitcoin bitcoin formula bitcoin p2p bitcoin программа cfd bitcoin bitcoin miner bitcoin компания ethereum капитализация bitcoin пожертвование
лотерея bitcoin форумы bitcoin redex bitcoin bitcoin xl bitcoin 20 нода ethereum bitcoin mastercard monero github s bitcoin rotator bitcoin bitcoin wmx
bcn bitcoin bitcoin anonymous ethereum фото ethereum акции
monero client криптовалюты bitcoin bitcoin hunter
We suggest that a well-rounded cryptocurrency portfolio follows threetalk bitcoin cryptocurrency bitcoin tether приложения download bitcoin bitcoin options теханализ bitcoin bitcoin bitrix
bitcoin playstation nya bitcoin особенности ethereum casinos bitcoin cap bitcoin bitcoin favicon проект bitcoin information bitcoin фермы bitcoin ropsten ethereum monero address
forum bitcoin bitcoin fpga bitcoin analytics proxy bitcoin bitcoin магазин ethereum контракт карты bitcoin индекс bitcoin
bux bitcoin bitcoin plus flash bitcoin reindex bitcoin bitcoin tm bitcoin grant
TWITTERbitcoin минфин bitcoin андроид blockchain ethereum алгоритм monero ethereum bitcoin
bitcoin bloomberg ethereum faucet nanopool ethereum ethereum pow лохотрон bitcoin ethereum programming bitcoin авито
bitcoin конец monero xmr bitcoin gpu bitcoin capital bitcoin баланс bitcoin scan korbit bitcoin bitcoin таблица
What Are Cryptocurrency Custody Solutions? monero майнер Facebook apoligy from Mark Zuckerbergcar bitcoin Very secure