Port EVM bytecode to ConfluxCopy the code
Conflux uses a deposit mechanism. If non-zero data is written to the storage through the SSTORE (0x55) instruction during the execution of the smart contract, a storage deposit is required. When the data is emptied, the deposit is returned to the payer.
The price of the deposit is 1/1024 CFX/byte. Each storage unit counts 64 bytes. In addition, once the contract is created, the code also charges a deposit for storage.
Deposit mechanism produces the differenceCopy the code
Conflux uses a deposit mechanism. If non-zero data is written to the storage through the SSTORE (0x55) instruction during the execution of the smart contract, a storage deposit is required. When the data is emptied, the deposit is returned to the payer.
The price of the deposit is 1/1024 CFX/byte. Each storage unit counts 64 bytes. In addition, once the contract is created, the code also charges a deposit for storage.
Storage upper limit domain for transactionsCopy the code
In Conflux, each transaction requires a storage upper limit, in bytes. If the deposit limit is set too high, exceeding the deposit the account balance can pay, the transaction will fail. If the upper limit is too low, the number of newly added storage exceeds the upper limit, the transaction will fail.
One of the simplest scenarios is to use Conflux RPC to estimate the storage upper limit required by the transaction (see the related section). Alternatively, you can use the n x 1024 formula to calculate the maximum storage limit supported by the account balance. (where N is the balance after payment of transaction fees and account transfer fees. Or, to be on the safe side, a smaller number, such as n*1000)
Write storage consumes fuel
Just measure it. In Conflux, all SSTORE (0x55) instructions consume 5000 gas of fuel. Ethereum’s logic here is complicated by comparison. However, the average developer does not need to be concerned with the specific gas pricing for each order, and only needs to estimate the fuel usage for the entire transaction through RPC.
The consensus mechanism produces the distinction between block height and block hashing related instructionsCopy the code
In Ethereum, the BLOCKHASH (0x40) directive (the block.blockhash(n) function in Solidity) takes the block number (block height) n as input and outputs the hash value corresponding to the block height. The difference between the height of the parameter N and the height of the block where the transaction is executed cannot exceed 256, otherwise 0 will be returned.
Conflux adopts a tree graph structure. When the blocks are sorted, each block will generate a sort number, which is different from the block height. Because the two adjacent blocks may not have a parent-child relationship after the tree structure is sorted, the block numbered N-1 may not be the parent block numbered N.
The BLOCKHASH (0x40) directive in Conflux (the block.blockhash(n) function in Solidity) takes the block sort number N as input. Correspondingly, the NUMBER (0x43) instruction (the block. NUMBER variable in Solidity) also gives the sort NUMBER.
In addition, Ethereum’s BLOCKHASH (0x40) instruction can ask the exchange for the hash of the first 256 blocks in the block, whereas Conflux’s instruction can only ask for the hash of the previous block. However, the number of parameters in Conflux is no different from ethereum.
A piece of speedCopy the code
Conflux generates blocks at a rate of 2 per second, much faster than Ethereum. If block speed is hardcoded into the smart contract code logic, it needs to be changed accordingly.
Fill in the transaction informationCopy the code
When a user initiates a transaction, Conflux has different information to fill in. However, RPC and SDKS generally do this for developers and users.
Storage Limit: Indicates the Storage upper Limit. See the transaction storage upper limit area section.
Gas Limit: indicates the upper Limit of fuel. Conflux will refund at most 1/4 of the gas Limit for unused gas, so it is important to estimate a reasonable fuel Limit before sending a transaction.
Chain ID: indicates the number of the blockchain. Specify the block chain number that can execute the transaction to prevent someone from replaying the test network transaction on the main network. Currently, the Chain ID of the test network is 1, and that of the primary network is 2.
Epoch Height: The (approximate) Epoch when a trade is executed. If the actual Epoch at the time of execution differs by more than 100000 from the Epoch Height of the transaction (the Epoch number increases by 100000 in half a day to a few days), the transaction will fail to execute. In other words, transactions that have not been packaged for too long will not be executed.
Recipient: Conflux’s address algorithm is different from Ethereum’s. The first four bits of all public key addresses are 0001, and the first four bits of all contract addresses are 1000. The first four bits of all built-in contract addresses are 0000. If the first four bits of the recipient address are not one of these three, the transaction fails.
The other differenceCopy the code
After the contract is created, the author (msG.sender at the time the contract was created) automatically becomes the administrator of the contract. The administrator has the right to destroy the contract or transfer administrative authority to another person. The administrator can be a common address or a contract address.
Conflux creates a contract code cap of 49,152 bytes, twice as much as Ethereum.
Please check your contract for hard-coded ethereum addresses.
There are some other differences in Conflux that developers and users of the contract don’t need to be concerned about, and we’ll leave them out here.