如何解决 "Stack Too Deep(堆栈太深)" 的问题
- 原文链接:https://soliditydeveloper.com/stacktoodeep 作者:Markus Waas
- 译者:Tiny 熊
- 译文出自:登链翻译计划
- 本文永久链接:learnblockchain.cn/article…
你只需要在合约中添加一个微小的更改即可。你认为这只需要几秒钟。没错,添加代码只花了不到一分钟的时间。你很高兴你快速解决了这个问题,你输入了compile命令。这么小的更改,你确信代码是正确的。
然而,你确看到以下错误消息:
<center><b>InternalCompilerError:Stack Too Deep, try removing local variables.(堆栈太深,请尝试删除一些局部变量。)</b></center></br>
哎哟。这里发生了什么?如果你之前写过智能合约,这很可能是一个非常熟悉的错误消息,并且在不可预测的时间出现。但是通常在你时间紧迫的时候。
不过请放心,这不是你的错。如果你正在为这个错误而苦苦挣扎,那么你不是唯一的一个。
看看最近的调查,您最讨厌Solidity哪个方面:
原因是在EVM堆栈中如何引用变量方面存在限制。尽管其中可以包含16个以上的变量,但是一旦尝试引用16或更高槽位中的变量,将失败。因此,并非总是很清楚为什么某些代码会失败,然后进行一些随机更改似乎可以解决问题。
但是我不想介绍太多让你厌倦的理论。这是一篇实用的博客文章。
现在到底有什么通用方法可以解决此问题?让我们看一下处理错误的五种方法:
利用函数
代码块作用域范围
利用结构体
一些黑技巧
好吧,第一个显而易见。如果可以,请尝试重构代码以使用更少的变量。办法很直接,让我们继续前进看看其他 4 个方法。
对于其他四个,我们来看一个堆栈太深的示例代码以及四种修复它的方法。
让我们看下面的代码。它将抛出困扰我们的堆栈太深的错误消息。我们可以对它可以做些什么呢?
// SPDX-License-Identifier: MIT
pragma solidity 0.7.1;
contract StackTooDeepTest1 {
function addUints(
uint256 a,uint256 b,uint256 c,uint256 d,uint256 e,uint256 f,uint256 g,uint256 h,uint256 i
) external pure returns(uint256) {
retur...
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!