博客
关于我
solidity中的transfer、send、call(delegatecall)的区别和用法总结
阅读量:674 次
发布时间:2019-03-15

本文共 1835 字,大约阅读时间需要 6 分钟。

务必注意:solidity0.5.0以上的版本发生了很大的变化,具体的规则以官方最新版为准!!!

 

transfer、send、call都是可以合约之间相互转账的方法,但是用法有很大的不同!

//如果异常会转账失败,抛出异常(等价于requi(send()))(合约地址转账)// 有gas限制,最大2300
.transfer(uint256 amount)//如果异常会转账失败,仅会返回false,不会终止执行(合约地址转账)// 有gas限制,最大2300
.send(uint256 amount) returns (bool)如果异常会转账失败,仅会返回false,不会终止执行(调用合约的方法并转账)// 没有gas限制
.call(bytes memory) returns (bool, bytes memory)

三个方法的共同点:addr.transfer(1 ether)、addr.send(1 ether)、addr.call.value(1 ether)的接收方都是addr(这一点和我们传统的语言不一样,很容易混淆)

 

如果使用addr.transfer(1 ether)、addr.send(1 ether),addr合约中必须增加fallback回退函数!

如果使用addr.call.value(1 ether),那么被调用的方法必须添加payable修饰符,否则转账失败!

pragma solidity ^0.5.0;contract Hello {        address adds;    # 如果使用transfer或send函数必须添加fallback回退函数     function () external payable {             }        function get_balance() public view returns (uint){        return address(this).balance;    }    # 如果使用call.value(1 ether)方法,则被调用的方法必须增加payable修饰符,否则转账会失败!    function set_sender() public payable{        adds = msg.sender;    }        function get_sender() public view returns(address) {        return adds;    } }contract Test {        constructor() public payable{    }    function get_balance() public view returns (uint){        return address(this).balance;    }    function send_call(address payable a) public {                # 获得被调用的方法的签名(也就是函数的selector属性)        # 方法签名的原理是:对给定参数进行编码,并以给定的函数选择器作为起始的 4 字节数据一起返回。详情参考官方文档abi编码函数!        # 如果有参数:bytes memory payload = abi.encodeWithSignature("set_sender(string)","参数");后面"参数"就是带的参数        bytes memory payload = abi.encodeWithSignature("set_sender()");        (bool success, bytes memory returnData) = a.call.value(0.1 ether)(payload);        require(success);    }    function send_transfer(address payable a) public {        //这里是被调用的方法签名(0.5.0以上的版本和之前的不一样,查看官方最新文档)        a.transfer(1 ether);    }}

转载地址:http://jsmmz.baihongyu.com/

你可能感兴趣的文章
Mysql 数据类型一日期
查看>>
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>