address的四个方法
send,call,callcode,delegatecall
例子:
发送以太币的send方法
//下面是send方法,涉及到以太币的情况可能用到payable,senddemo方法是可以发送以太币过去的,add.transfer(u)
pragma solidity ^0.4.1; contract addressDemo{ function addressDemo() payable{ } function sendDemo(address add){ uint u=1 ether;//以太币的最小单位是wei,最大单位是ether
add.transfer(u) } }
call方法,注意地址.call,和地址.delegatecall方法的区别,call是自己本身不发生改变,被调用的值发生改变,delegatecall是自己本省的值发生改变,被调用的不发生改变
pragma solidity ^0.4.1; //首先定义了两个合约
contract A{ uint public p; event e(address add,uint p)//为了观察声明一个事件 //定义了一个方法
function fun(uint u1,uint u2) { p=u1+u2;//改变了A合约中的p,改变被调用者合约方法中的变量
e(msg.sender,p)//下面的2,3传给了fun方法
} } contract B{ uint public q; bool public b; //当我们用B中的call方法的时候,调用A中的某个方法的执行,只会改变A中某个方法的值,B中的某个方法的值不会发生改变,被调用的合约本身发生改变
function call1(address add) returns(bool){ b=add.call(bytes4(keccak256("fun(uint256,uint256)")),2,3) return b;//下面的add调用call方法
} //下面的delegatecall是会改变B中的某个方法,而A中的某个方法是不会有任何的改变,下面是自己的合约发生变化
function call2(address add) returns(bool){ b=add.delegatecall(bytes4(keccak256("fun(uint256,uint256)")),1,3) return b; } }
例子:
pragma solidity ^0.4.0; //定义一个合约
contract CA{ uint public p; bytes public failmsg; string public str; event e(address add,uint p) event e1(address add, bytes b); //定义一个构造函数,构造方法
function CA(string _str) { str=_str;//str重新被赋值
} function fun(uint u1,uint u2) { p=u1+u2; e(msg.sender,p) } //构造一个匿名函数
function () {//下面就会执行这个匿名函数
failmsg=msg.data; e1(msg.sender,failmsg)// } } contract CB{ uint public q; bool public b; function call1(address add) returns(bool){ b=add.call(bytes4(keccak256("fun(uint256,uint256)")),2,3); return b } function call2(address add) returns(bool){ b=add.delegatecall(bytes4(keccak256("fun(uint256,uint256)")),2,3); return b } //使用的是call方法,上面发生的值发生改变,下面不发生改变
function call3(address add) returns(bool){ b=false b=add.call("aaaa",2,4,5,54,3); return b } //下面是本身自己的值发生改变,b的值发生改变
function call4(address add) returns(bool){ b=false; b=add.delegatecall("bbbb",5,"10x2323",43);//执行匿名函数
return b } }