Solidity 小白教程:7. 映射类型 mapping

Solidity 小白教程:7. 映射类型 mapping

这一讲,我们将介绍 solidity 中的哈希表:映射(Mapping)类型。

映射 Mapping

在映射中,人们可以通过键(Key )来查询对应的值(Value ),比如:通过一个人的id 来查询他的钱包地址。

声明映射的格式为mapping(_KeyType => _ValueType) ,其中**_KeyType _ValueType分别是 KeyValue**的变量类型。例子:

solidity 复制代码
mapping(uint => address) public idToAddress; // id映射到地址
    mapping(address => address) public swapPair; // 币对的映射,地址到地址

映射的规则

  • 规则 1 :映射的**_KeyType只能选择 solidity默认的类型,比如 uint**,address 等,不能用自定义的结构体。而**_ValueType可以使用自定义的类型。下面这个例子会报错,因为_KeyType**使用了我们自定义的结构体:
solidity 复制代码
// 我们定义一个结构体 Struct
    struct Student{
        uint256 id;
        uint256 score;
    }
     mapping(Student => uint) public testVar;
  • 规则 2 :映射的存储位置必须是storage ,因此可以用于合约的状态变量,函数中的storage 变量,和 library 函数的参数(见例子)。不能用于public 函数的参数或返回结果中,因为mapping记录的是一种关系 (key - value pair)。
  • 规则 3 :如果映射声明为public ,那么solidity 会自动给你创建一个getter 函数,可以通过Key 来查询对应的Value
  • 规则 4 :给映射新增的键值对的语法为**_Var_Key = _Value**,其中**_Var是映射变量名, _Key_Value**对应新增的键值对。例子:
solidity 复制代码
function writeMap (uint _Key, address _Value) public{
        idToAddress[_Key] = _Value;
    }

映射的原理

  • 原理 1 : 映射不储存任何键(Key)的资讯,也没有 length 的资讯。
  • 原理 2: 映射使用**keccak256(key)**当成 offset 存取 value。
  • 原理 3 : 因为 Ethereum 会定义所有未使用的空间为 0,所以未赋值(Value )的键(Key)初始值都是各个 type 的默认值,如 uint 的默认值是 0。

在 Remix 上验证 (以 Mapping.sol为例)

  • 映射示例 1 部署
  • 映射示例 2 初始值
  • 映射示例 3 key-value pair

总结

这一讲,我们介绍了solidity 中哈希表------映射(Mapping )的用法。至此,我们已经学习了所有常用变量种类,之后我们会学习控制流if-else,** while**等。

相关推荐
Flynt3 天前
npm v12 来了:allowScripts 默认关闭,我的项目差点跑不起来
安全·npm·node.js
Rockbean7 天前
10分钟智能合约:进阶实战-7.2 Foundry开发环境
web3·智能合约·solidity
冬奇Lab7 天前
Skill 系列(02):Skill 安全风险——三类攻击面的实战测试
人工智能·安全·开源
Rockbean10 天前
10分钟智能合约:进阶实战-6.4 使合约拒绝服务
web3·智能合约·solidity
Rockbean10 天前
10分钟智能合约:进阶实战-6.3 重入攻击提取资金
web3·智能合约·solidity
Aphasia31111 天前
VPN 与内网穿透
安全
木西12 天前
实战:基于 Solidity 0.8.27 与 OpenZeppelin V5 构建多链恶搞代币(以 SPX6900 为例)
web3·智能合约·solidity
Mr_愚人派12 天前
当"Claude"不再是 Claude:一次第三方 API 代理引发的 AI 身份伪造排查实录
人工智能·安全
DaLi Yao13 天前
【无标题】
人工智能·安全
Alsn8613 天前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker