solidity得高级语法3

1.事件

事件是合约的可继承成员。 发出一个事件,它存储事务日志中传递的参数。 这些日志存储在区块链上,并且可以使用合约地址进行访问,直到合约出现在区块链上为止。 生成的事件无法从合约内部访问,甚至是创建和发出事件的事件。

可以使用 event 关键字声明事件。

复制代码
//Declare an Event
event Deposit(address indexed _from, bytes32 indexed _id, uint _value);

//Emit an event
emit Deposit(msg.sender, _id, msg.value);
 

示例

尝试以下代码来了解事件在 Solidity 中的工作原理。

首先创建合约并发出事件。

复制代码
pragma solidity ^0.5.0;

contract Test {
   event Deposit(address indexed _from, bytes32 indexed _id, uint _value);
   function deposit(bytes32 _id) public payable {      
      emit Deposit(msg.sender, _id, msg.value);
   }
}
 

然后在 JavaScript 代码中访问合约的事件。

复制代码
var abi = /* abi as generated using compiler */;
var ClientReceipt = web3.eth.contract(abi);
var clientReceiptContract = ClientReceipt.at("0x1234...ab67" /* address */);

var event = clientReceiptContract.Deposit(function(error, result) {
   if (!error)console.log(result);
});
 

它应该打印类似于以下内容的详细信息 −

输出

复制代码
{
   "returnValues": {
      "_from": "0x1111...FFFFCCCC",
      "_id": "0x50...sd5adb20",
      "_value": "0x420042"
   },
   "raw": {
      "data": "0x7f...91385",
      "topics": ["0xfd4...b4ead7", "0x7f...1a91385"]
   }
}

2.错误处理

Solidity 提供了各种错误处理函数。 一般来说,当发生错误时,状态会恢复到原来的状态。 其他检查是为了防止未经授权的代码访问。 以下是错误处理中使用的一些重要方法 −

  • assert(bool condition) − 如果不满足条件,此方法调用会导致无效的操作码,并且对状态所做的任何更改都会被恢复。 此方法用于内部错误。

  • require(bool condition) − 如果不满足条件,此方法调用将恢复到原始状态。 - 此方法用于输入或外部组件中的错误。

  • require(bool condition, string memory message) − 如果不满足条件,此方法调用将恢复到原始状态。 - 此方法用于输入或外部组件中的错误。 它提供了一个选项来提供自定义消息。

  • revert() − 此方法中止执行并恢复对状态所做的任何更改。

  • revert(string memory reason) − 此方法中止执行并恢复对状态所做的任何更改。 它提供了一个选项来提供自定义消息。

示例

尝试以下代码来了解 Solidity 中错误处理的工作原理。

复制代码
pragma solidity ^0.5.0;

contract Vendor {
   address public seller;
   modifier onlySeller() {
      require(
         msg.sender == seller,
         "Only seller can call this."
      );
      _;
   }
   function sell(uint amount) public payable onlySeller { 
      if (amount > msg.value / 2 ether)
         revert("Not enough Ether provided.");
      // Perform the sell operation.
   }
}

调用revert时,会返回如下的十六进制数据。

输出

复制代码
0x08c379a0                     // Function selector for Error(string)
0x0000000000000000000000000000000000000000000000000000000000000020 // Data offset
0x000000000000000000000000000000000000000000000000000000000000001a // String length
0x4e6f7420656e6f7567682045746865722070726f76696465642e000000000000 // String data
相关推荐
傻小胖4 小时前
21.ETH-权益证明-北大肖臻老师客堂笔记
笔记·区块链
硅基流动7 小时前
硅基流动 × ValueCell:8K+Star,去中心化金融智能体加速投资决策
金融·去中心化·区块链
devmoon8 小时前
使用 Hardhat 在 Polkadot Hub 测试网部署基础 Solidity 合约(完整实战指南)
web3·区块链·智能合约·波卡·hardhat
威胁猎人9 小时前
【黑产大数据】2025年全球KYC攻击风险研究报告
大数据·区块链
焦点链创研究所9 小时前
去中心化实体基础设施网络的崛起:比较分析
网络·去中心化·区块链
MicroTech202515 小时前
微算法科技(NASDAQ :MLGO)量子测量区块链共识机制:保障数字资产安全高效存储与交易
科技·安全·区块链
区块链蓝海16 小时前
Ardor v2.6.0 正式发布:Nxt迁移完成,Ardor迈入多链协同新阶段
人工智能·区块链
MQLYES16 小时前
02-UniswapV1-源码篇
去中心化·区块链
devmoon16 小时前
快速了解兼容 Ethereum 的 JSON-RPC 接口
开发语言·网络·rpc·json·区块链·智能合约·polkadot
devmoon16 小时前
用Remix IDE在Polkadot Hub部署一个最基础的Solidity 合约(新手友好)
web3·区块链·智能合约·编译·remix·polkadot