以太坊系列之十二: solidity变量存储

简介: solidity中变量的存储变量存储主要分为两个区域,一个是storage(对应指定是SLOAD,SSTORE),一个是Memory(MLOAD,MSTORE), 这和普通编程语言的内存模型是不一样的.

solidity中变量的存储

变量存储主要分为两个区域,一个是storage(对应指定是SLOAD,SSTORE),一个是Memory(MLOAD,MSTORE), 这和普通编程语言的内存模型是不一样的.
storage就像硬盘是长期存储,memory调用返回就没了.

默认情况:

  • 函数变量以及返回值都是存储在memory
  • 其他变量(函数的局部变量)都是storage

强制情况(也就是不能通过在声明的时候指定memory或storage):
* 外部函数调用时的参数真是calldata(和memory差不多)
* 合约的成员变量(state variable)

Forced data location:

  • parameters (not return) of external functions: calldata
  • state variables: storage
    Default data location:
  • parameters (also return) of functions: memory
  • all other local variables: storage

存储在memory和storage中的变量在操作上也是有区别的,比如memory中的数组不能改变大小,而storage中的就可以.比如:

uint[] memory a = new uint[](7);
a.length=8 //这是不允许的
uint[] storage sa;
sa.push(32); //只有storage可以push,因为他的大小不固定,而memory中的一旦声明就固定下来了.
目录
相关文章
|
9月前
|
JSON 前端开发 搜索推荐
关于商品详情 API 接口 JSON 格式返回数据解析的示例
本文介绍商品详情API接口返回的JSON数据解析。最外层为`product`对象,包含商品基本信息(如id、name、price)、分类信息(category)、图片(images)、属性(attributes)、用户评价(reviews)、库存(stock)和卖家信息(seller)。每个字段详细描述了商品的不同方面,帮助开发者准确提取和展示数据。具体结构和字段含义需结合实际业务需求和API文档理解。
|
11月前
|
存储 监控 算法
请详细介绍内存池的最佳实践
请详细介绍内存池的最佳实践
|
Linux
如何创建和配置linux虚拟机(一)
如何创建和配置linux虚拟机
352 0
|
机器学习/深度学习 人工智能 自然语言处理
从提示工程到代理工程:构建高效AI代理的策略框架概述
该文探讨了AI代理的发展,特别是ChatGPT等模型如何展示了AI系统的潜力。文章提出从提示工程转向代理工程,定义了代理能力需求,并提出一个框架来设计和实施AI代理。代理工程涉及明确代理的任务、所需行动、能力及熟练度,通过现有技术满足这些需求。文章强调了广泛和特定知识的熟练度、精确信息获取以及代理的结构设计和协调。随着技术进步,该框架为AI代理的未来发展提供了基础。
780 0
|
监控 Dubbo 应用服务中间件
DUBBO--基础篇(二)--监控中心
DUBBO--基础篇(二)--监控中心
230 0
|
算法 Go
Golang实现Raft一致性算法
Golang实现Raft一致性算法
231 0
|
开发工具 Python
Python 打包SDK
Python 打包SDK
325 0
|
存储 Cloud Native 关系型数据库
【云原生 · Docker】入门篇:安装、镜像加速
【云原生 · Docker】入门篇:安装、镜像加速
942 0
|
存储 大数据 Linux
深入理解Python生成器和yield
本文带大家深入地学习了生成器和`yield`语句。生成器在处理大文件大数据集时非常有用,它占用内存少,不会拖慢机器性能,从而能够更快的处理数据。
534 0
深入理解Python生成器和yield