Transaction Hash:
Block:
9665224 at Mar-13-2020 08:24:52 PM +UTC
Transaction Fee:
0.000192425 ETH
$0.38
Gas Used:
38,485 Gas / 5 Gwei
Emitted Events:
| 131 |
MyERC20.Transfer( from=[Sender] 0x8138b2221723c820dcb019f9e4622e66ea0f64a8, to=0x6D6075AC1ae17ee04982d0e531A1C35A9e49e3Eb, tokens=3292171414780000000000 )
|
Account State Difference:
| Address | Before | After | State Difference | ||
|---|---|---|---|---|---|
|
0x5A0b54D5...D3E029c4c
Miner
| (Spark Pool) | 112.899105307388752716 Eth | 112.899297732388752716 Eth | 0.000192425 | |
| 0x80C549E8...4F14D23CA | |||||
| 0x8138B222...6eA0F64A8 |
7.1217930964 Eth
Nonce: 700
|
7.1216006714 Eth
Nonce: 701
| 0.000192425 |
Execution Trace
MyERC20.transfer( _to=0x6D6075AC1ae17ee04982d0e531A1C35A9e49e3Eb, _value=3292171414780000000000 ) => ( success=True )
transfer[MyERC20 (ln:59)]
Transfer[MyERC20 (ln:65)]
pragma solidity ^0.5.16;
contract ERC20Basic {
function balanceOf(address tokenOwner) external view returns (uint balance);
function allowance(address tokenOwner, address spender) external view returns (uint remaining);
function approve(address spender, uint tokens) external returns (bool success);
function transfer(address to, uint tokens) external returns (bool success);
function transferFrom(address from, address to, uint tokens) external returns (bool success);
function setTotalSupply(uint256 _value) public returns (uint totalSupply);
event Transfer(address indexed from, address indexed to, uint tokens);
event Approval(address indexed tokenOwner, address indexed spender, uint tokens);
}
contract MyERC20 is ERC20Basic {
string public name;
string public symbol;
uint8 public constant decimals = 18;
uint public totalSupply;
mapping(address => uint256) internal _balances;
mapping(address => mapping(address => uint256)) allowed;
constructor(string memory _name, string memory _symbol, uint256 _initialSupply) public {
name = _name;
symbol = _symbol;
totalSupply = setTotalSupply(_initialSupply);
_balances[msg.sender] = totalSupply;
}
function setTotalSupply(uint256 _value) public returns (uint total) {
return _value * 10 ** uint256(decimals);
}
function balanceOf(address tokenOwner) public view returns (uint balance) {
return _balances[tokenOwner];
}
function allowance(address _owner, address _spender) public view returns (uint256 remaining) {
return allowed[_owner][_spender];
}
function transferFrom(address _from, address _to, uint256 _value) public returns (bool success) {
require(_to != address(0));
require(allowed[_from][msg.sender] >= _value);
require(_balances[_from] >= _value);
require(_balances[ _to] + _value >= _balances[ _to]);
_balances[_from] -= _value;
_balances[_to] += _value;
allowed[_from][msg.sender] -= _value;
emit Transfer(msg.sender, _to, _value);
return true;
}
function transfer(address _to, uint256 _value) public returns (bool success) {
require(_to != address(0));
require(_balances[msg.sender] >= _value);
require(_balances[ _to] + _value >= _balances[ _to]);
_balances[msg.sender] -= _value;
_balances[_to] += _value;
emit Transfer(msg.sender, _to, _value);
return true;
}
function approve(address _spender, uint256 _value) public returns (bool success) {
allowed[msg.sender][_spender] = _value;
emit Approval(msg.sender, _spender, _value);
return true;
}
}