solidity 之 call与delegatecall区别

今天我们谈一谈solidity 中call与delegatecall区别。这两个方法都是进行合约之间的调用。call是自己本身不发生改变,被调用的值发生改变,delegatecall是自己本身的值发生改变,被调用的不发生改变。

可能这样说大家大家理解不够直观,接下来我们创建2个合约代码,进行演示调用。直接上示例代码:

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方法

}

}
pragma solidity ^0.4.1;



contract B{

uint public qq;
bool public b;

//当我们用B中的call方法的时候,调用A中的某个方法的执行,只会改变A中某个方法的值,B中的某个方法的值不会发生改变,被调用的合约本身发生改变

function call1(address add) returns(bool){
b=add.call(bytes4(keccak256("fun(uint256,uint256)")),30,3);
return b;//下面的add调用call方法
}

//下面的delegatecall是会改变B中的某个方法,而A中的某个方法是不会有任何的改变,下面是自己的合约发生变化
function call2(address add) returns(bool){
b=add.delegatecall(bytes4(keccak256("fun(uint256,uint256)")),10,3);
return b;
}
}

接下来分别把代码复制remix进行编译->部署
智能合约1部署后如下界面:
在这里插入图片描述
智能合约2如下:
在这里插入图片描述

call1方法填入智能合约1的部署后的地址,点击运行后结果会在部署合约1中显示,而call2中的结果在本合约下显示结果。

完整示例代码:

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
}
}

还有什么不懂的 大家可以评论,自己实践一下。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值