• Solidity(address的四个方法)


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

     

  • 相关阅读:
    HDU
    UVa——540Team Queue(STL练习map、queue数组的综合使用)
    NOJ——1659求值(log10取对数+floor取整数部分+可有可无的快速幂)
    NOJ——1658平方和(自然数平方和公式和取模法则)
    HDU——2723Electronic Document Security(STL map嵌套set做法)
    HDU——1982Kaitou Kid
    HDU——1073Online Judge(string类以及其对应函数)
    HDU——1062Text Reverse(水题string::find系列+reverse)
    HDU——1009FatMouse' Trade(贪心+结构体+排序)
    HDU——1799循环多少次(杨辉三角/动态规划/C(m,n)组合数)
  • 原文地址:https://www.cnblogs.com/yunxintryyoubest/p/10652703.html
Copyright © 2020-2023  润新知