zoukankan      html  css  js  c++  java
  • Solidity中如何判断mapping中某个键是否为空呢?

    Solidity中如何判断mapping中某个键是否为空呢?

    一.比较标准的做法是建立一个专门和value相关的结构体,用一个布尔型变量来看是否这个key所对应的value被赋过值

    代码如下:

    pragma solidity ^0.4.19;
    
    contract UserTest {
        
        struct User{
          string name;
          bool isVaild;
        }
        
        mapping(address => User) public users;
        
        function addUser(string _name) public returns (string) {
            if(users[msg.sender].isVaild){
                return users[msg.sender].name;
            }
            users[msg.sender].name = _name;
            users[msg.sender].isVaild = true;
            return users[msg.sender].name;
        }
        
        function deleteUser() public returns (bool) {
            if(users[msg.sender].isVaild){
                users[msg.sender].name = '';
                users[msg.sender].isVaild = false;
                return true;
            }
            return false;
        }
        
        function getUser() public constant returns (string, bool) {
            return (users[msg.sender].name, users[msg.sender].isVaild);
        }
    }

    二.也可以简单的来看一下value所对应的length来判断这个值是否被赋值过(零值无法判断!)【实际上我在测试过程中这种方式一直报编译错误】

    mapping(address => uint) public deposits;
    if(deposits[msg.sender].length == 0){
        // deposit[msg.sender] is empty, do your thing
    }

      如果我们不用判断某个变量是否为赋过值后的零值时,我建议用第二种通过length来判断的方法,因为后者将大大减少合约gas的消耗。但实际上我在测试过程中这种方式一直报编译错误

    参考文章:https://ohyoukillkenny.github.io/blog/2018/01/07/null-in-solidity/

  • 相关阅读:
    poj 3613(经过N条边的最短路)
    poj 3328(多起点多终点的最短路)
    poj 3311(floyd+状态压缩)
    新CCIE笔记-IP网络基础
    新CCIE笔记-IP网络基础
    算法之【冒泡排序法】
    算法之【冒泡排序法】
    算法之【冒泡排序法】
    算法之【辗转相除法】
    算法之【辗转相除法】
  • 原文地址:https://www.cnblogs.com/flyingeagle/p/10119824.html
Copyright © 2011-2022 走看看