馬蹄鏈智能合約開發(fā)詳細丨馬蹄鏈智能合約系統開發(fā)邏輯及方案丨馬蹄鏈智能合約系統源碼
一個智能合約被編譯后就是一段EVM字節(jié)碼,將它部署在以太坊的區(qū)塊鏈時,會根據部署者的地址和該地址的nonce分配一個合約地址
合約地址和賬戶地址的格式是沒有區(qū)別的,但合約地址沒有私鑰,也就沒有人能直接操作該地址的合約數據。要調用合約,唯一的方法是調用合約的公共函數。
這也是合約的一個限制:合約不能主動執(zhí)行,它只能被外部賬戶發(fā)起調用。如果一個合約要定期執(zhí)行,那只能由線下服務器定期發(fā)起合約調用。
mint函數,進行代幣增發(fā),注意它是internal函數,所以外部是無法調用的
function _mint(address to,uint256 value)internal{
totalSupply=totalSupply.add(value);
balanceOf[to]=balanceOf[to].add(value);
emit Transfer(address(0),to,value);
}
_burn函數,進行代幣燃燒,同樣它也是internal函數
function _burn(address from,uint256 value)internal{
balanceOf[from]=balanceOf[from].sub(value);
totalSupply=totalSupply.sub(value);
emit Transfer(from,address(0),value);
}開發(fā)案例I59源碼2OO7詳細3O69
_approve函數,進行授權操作,注意它是private函數,意味著只能在本合約內直接調用。不過,在子合約中可以通過一個內部或者公共的函數進行間接調用。
function _approve(
address owner,
address spender,
uint256 value
)private{
allowance[owner][spender]=value;
emit Approval(owner,spender,value);
}
_transfer函數,轉移代幣操作,注意也是一個private函數
function _transfer(
address from,
address to,
uint256 value
)private{
balanceOf[from]=balanceOf[from].sub(value);
balanceOf[to]=balanceOf[to].add(value);
emit Transfer(from,to,value);
}開發(fā)邏輯:yy625019
approve函數,注意它是external(外部)函數,用戶通常進行授權操作的外部調用接口。
function approve(address spender,uint256 value)external returns(bool){
_approve(msg.sender,spender,value);
return true;
}
transfer函數,同上,用戶轉移代幣操作的外部調用接口。
function transfer(address to,uint256 value)external returns(bool){
_transfer(msg.sender,to,value);
return true;
}
transferFrom代幣授權轉移函數,它是一個外部函數,主要是由第三方合約來調用。注意它的實現中(UniswapV2的實現)作了一個假定,如果你的授權額度為最大值(幾乎用不完,相當于永久授權),為了減小操作步數和gas,調用時授權余額是不扣除相應的轉移代幣數量的。這里如果沒有授權(授權額度為0),那么會怎樣呢?庫函數.sub(value)調用時無法通過SafeMath的require檢查,會導致整個交易會被重置。所以如果沒有授權,第三方合約是無法轉移你的代幣的,你不用擔心你的資產被別的合約隨便偷走。
function transferFrom(
address from,
address to,
uint256 value
)external returns(bool){
if(allowance[from][msg.sender]!=uint256(-1)){
allowance[from][msg.sender]=allowance[from][msg.sender].sub(
value
);
}
_transfer(from,to,value);
return true;
}