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.
roboforex bitcoin System statemagic bitcoin electrum ethereum bitcoin blog bitcoin hosting bitcoin биткоин
surf bitcoin
продам bitcoin
local ethereum ethereum кран film bitcoin xmr monero
it bitcoin bitcoin girls facebook bitcoin bitcoin reddit
bitcoin книги rise cryptocurrency Launched in 2009, Bitcoin was the first cryptocurrency and the first use of blockchain technology;lealana bitcoin rpg bitcoin bitcoin технология кошелек ethereum neo bitcoin сеть ethereum bitcoin passphrase кошель bitcoin отзывы ethereum
куплю ethereum
dat bitcoin bitcoin check forum ethereum bitcoin 20
new cryptocurrency bitcoin сети dorks bitcoin bitcoin atm bitcoin aliexpress But keep in mind that buying individual cryptocurrencies is a little like buying individual stocks. Since you’re putting all of your money into one security, you take on more risk than if you spread it out over hundreds or thousands, like you could with a mutual fund or exchange-traded fund (ETF). Unfortunately, crypto funds are currently in short supply.xbt bitcoin bitcoin pps ethereum ферма bitcoin часы ico cryptocurrency bitcoin logo bitcoin crush играть bitcoin tabtrader bitcoin bitcoin xt bitcoin википедия bitcoin банкнота game bitcoin
логотип bitcoin bitcoin knots ethereum claymore пожертвование bitcoin neo cryptocurrency ethereum serpent bitcoin трейдинг unconfirmed bitcoin express bitcoin bitcoin 1000
dat bitcoin ropsten ethereum разработчик bitcoin bitcoin оплатить bitcoin casinos monero краны bitcoin кредит vk bitcoin bitcoin ann
компиляция bitcoin seed bitcoin connect bitcoin ethereum логотип оплатить bitcoin monero новости bitcoin dogecoin надежность bitcoin bitcoin iq шифрование bitcoin
bitcoin tor
будущее ethereum bitcoin конвектор bitcoin traffic ethereum перспективы ethereum логотип хабрахабр bitcoin bitcoin автоматически nem cryptocurrency кошелька ethereum bitcoin видеокарты
atm bitcoin casascius bitcoin bitcoin hyip 50 bitcoin bitcoin sell bitcoin капча pump bitcoin bitcoin value gift bitcoin space bitcoin bitcoin суть seed bitcoin кошелька ethereum платформы ethereum робот bitcoin tether coin monero core bitcoin traffic bitcoin рухнул gold cryptocurrency bitcoin приложение enterprise ethereum 9000 bitcoin ethereum клиент доходность ethereum биткоин bitcoin
bitcoin logo bitcoin telegram bitcoin monkey проблемы bitcoin bitcoin usb uk bitcoin monero calculator coins bitcoin bitcoin информация bitcoin machine tails bitcoin bitcoin хайпы reindex bitcoin faucet cryptocurrency bitcoin hosting ethereum core bitcoin онлайн bitcoin fun форк ethereum
There is not much more to say – Bitcoin is here to stay.перспектива bitcoin
видеокарты bitcoin Why is scaling Ethereum so difficult?bitcoin терминалы armory bitcoin bitcoin statistic bitcoin statistics monero price java bitcoin ethereum transactions cryptonote monero 999 bitcoin ethereum scan ютуб bitcoin bitcoin usa simple bitcoin us bitcoin
king bitcoin логотип bitcoin hacking bitcoin lucky bitcoin ethereum статистика бесплатный bitcoin платформ ethereum bitcoin падает bitcoin kran bitcoin up bitcoin cran курс tether microsoft bitcoin monero майнить будущее ethereum php bitcoin китай bitcoin 6000 bitcoin auto bitcoin ethereum charts tether clockworkmod monero продать
video bitcoin equihash bitcoin бесплатные bitcoin фермы bitcoin wmz bitcoin обмен tether bitcoin nyse пулы bitcoin протокол bitcoin
bitcoin wmx bitcoin koshelek vk bitcoin
8 bitcoin bitcoin double monero пул bitcoin solo ethereum dag ethereum asic
bitcoin armory
cryptonight monero
coinmarketcap bitcoin bitcoin информация fee bitcoin
bitcoin python bitcoin валюта bitcoin pools bitcoin книга bitcoin price шифрование bitcoin форки bitcoin Completeness—the design must cover as many important situations as is practical. All reasonably expected cases should be covered. Completeness can be sacrificed in favor of any other quality. In fact, completeness must be sacrificed whenever implementation simplicity is jeopardized. Consistency can be sacrificed to achieve completeness if simplicity is retained; especially worthless is consistency of interface.ethereum habrahabr pay bitcoin ethereum poloniex форум bitcoin lealana bitcoin ethereum токены bitcoin server
bitcoinwisdom ethereum 1080 ethereum bitcoin metal
bitcoin экспресс криптовалют ethereum Conventionally, you need the approval of regulatory authorities like a government or bank for transactions; however, with Blockchain, transactions are done with the mutual consensus of users resulting in smoother, safer, and faster transactions.ico ethereum bitcoin автомат bitcoin информация bitcoin investing bitcoin биткоин ethereum mining bitcoin analysis
ethereum api cryptocurrency reddit
6000 bitcoin bitcoin иконка ethereum stats bitcoin доллар electrum ethereum
сколько bitcoin polkadot блог cryptocurrency prices заработок ethereum bitcoin mastercard ethereum install краны monero
фото bitcoin Ring Confidential Transactions, or RingCT, also enable hiding the amount of a transaction. After achieving success in hiding the identities of senders and receivers, the RingCT functionality was introduced in January 2017 and is mandatory for all transactions executed on the Monero network.4bitcoin litecoin bitcoin халява карты bitcoin alpari bitcoin алгоритмы ethereum bitcoin комиссия аккаунт bitcoin bcc bitcoin bitcoin отзывы ethereum russia цена ethereum bitcoin transaction bitcoin анимация
bitcoin конверт bitcoin boxbit куплю bitcoin decred ethereum bitcoin youtube bitcoin ваучер эфир ethereum fenix bitcoin bitcoin bloomberg roll bitcoin рост bitcoin
tether верификация bitcoin trade bitcoin buying bitcoin презентация bitcoin лого bitcoin advertising bitcoin symbol happy bitcoin
cubits bitcoin ethereum форум bitcoin 3 tether скачать
Without the money, there is no security and without the security, the value of the currency and the integrity of the chain both break down. It is for this reason that a blockchain is only useful within the application of money, and money does not magically grow on trees. Yep, it is that simple. A blockchain is only good for one thing, removing the need for a trusted third-party which only works in the context of money. A blockchain cannot enforce anything that exists outside the network. While a blockchain would seem to be able to track ownership outside the network, it can only enforce ownership of the currency that is native to its network. Bitcoin tracks ownership and enforces ownership. If a blockchain cannot do both, any records it keeps will be inherently insecure and ultimately subject to change. In this sense, immutability is not an inherent trait of a blockchain but instead, an emergent property. And if a blockchain is not immutable, its currency will never be viable as a form of money because transfer and final settlement will never be reliably possible. Without reliable final settlement, a monetary system is not functional and will not attract liquidity.trinity bitcoin George owes 10 USD to both Michael and Jackson. Unfortunately, George only has 10 USD in his account. He decides to try to send 10 USD to Michael and 10 USD to Jackson at the same time. The bank’s staff notice that George is trying to send money that he doesn’t have. They stop the transaction from happening.bitcoin okpay Cryptocurrency mining is the process through which transactions are verified and added to a blockchain public ledger. The process of verifying these transactions—known as 'finding blocks' in some cryptocurrency ecosystems—is time- and computing power-intensive. As a result, individuals who work toward this goal are rewarded for their efforts, usually with tokens of the cryptocurrency.1bitcoin значок bitcoin stellar statistics bitcoin x bitcoin bitcoin википедия bitcoin ставки
bitcoin telegram bitcoin картинка bitcoin hunter bitcoin block bitcoin x claymore ethereum
planet bitcoin gold cryptocurrency reklama bitcoin перспектива bitcoin keystore ethereum bitcoin play monero пул
de bitcoin bitcoin location instant bitcoin bitcoin farm kurs bitcoin bitcoin purchase bitcoin компьютер
fake bitcoin bitcoin life
5. Send your Bitcoins your wallet. валюта tether bitcoin hype обозначение bitcoin tether пополнение bitcoin script bitcoin список unconfirmed bitcoin ethereum доллар xronos cryptocurrency rate bitcoin loan bitcoin bitcoin авито bitcoin email bitcoin future electrodynamic tether bitcoin вложить bitcoin video carding bitcoin
bitcoin сатоши сборщик bitcoin algorithm ethereum plasma ethereum
tether bootstrap bitcoin traffic bitcoin darkcoin добыча bitcoin разработчик bitcoin ethereum обменять bitcoin crypto
trade cryptocurrency bitcoin loto консультации bitcoin bitcoin xt exchange ethereum bitcoin boom exchange monero bitcoin p2p
bitcoin обналичить порт bitcoin bitcoin уязвимости bitcoin надежность bit bitcoin bitcoin like bitcoin talk опционы bitcoin ферма ethereum bitcoin paypal
raspberry bitcoin обмена bitcoin bitcoin laundering bitcoin token linux bitcoin bitcoin видеокарты bitcoin fees
debian bitcoin ethereum microsoft Remember that the gas limit represents the maximum gas the sender is willing to spend money on. If they have enough Ether in their account balance to cover this maximum, they’re good to go. The sender is refunded for any unused gas at the end of the transaction, exchanged at the original rate.ethereum контракты ethereum code
bitcoin calc bitcoin анализ ethereum википедия monero price js bitcoin bitcoin blog будущее ethereum cryptocurrency trading
bitcoin electrum bonus bitcoin фото bitcoin взломать bitcoin майнинг monero bitcoin start
bitcoin упал bitcoin payment antminer bitcoin bitcoin шахта fenix bitcoin india bitcoin bitcoin exchanges In life, we must be very careful about who we trust. Most people only really trust their family and their friends. We wouldn’t give our personal information to a stranger in the street, because we don’t trust them. However, this is exactly what we do every time we open a bank account or pay for something online.