Bon*_*tin -1 for-loop go slice goland
我编写了以下代码来获取数组中的下一项。
count:=len(value.Values)
for index, currentRow := range value.Values {
var nextRow Value
if index< count{
nextRow = value.Values[index+1]
fmt.Print(nextRow)
}
}
Run Code Online (Sandbox Code Playgroud)
运行上面的代码时我感到恐慌。
Goroutine 恐慌:运行时错误:索引超出范围
知道如何从切片中获取下一个项目。
下一项确实是value.Values[index+1]
,但如果index
是最后一个元素的索引,则没有下一项,在这种情况下是index+1
无效索引value.Values
并尝试使用它会导致运行时恐慌。
所以请检查索引:
for index, currentRow := range value.Values {
var nextRow Value
if index < timeSeriesDataCount && index < len(value.Values)-1 {
nextRow = value.Values[index+1]
fmt.Print(nextRow)
}
}
Run Code Online (Sandbox Code Playgroud)
另一种选择是在一个少一个的切片上进行范围(排除最后一个元素),因此不需要检查index
,肯定还有另一个元素:
for index, currentRow := range value.Values[:len(value.Values)-1] {
var nextRow Value
if index < timeSeriesDataCount {
nextRow = value.Values[index+1]
fmt.Print(nextRow)
}
}
Run Code Online (Sandbox Code Playgroud)
在这种情况下你必须考虑的是是否value.Values
为空,因为如果是的话,上面的切片操作将再次出现恐慌,所以请检查:
if len(value.Values) > 0 {
for index, currentRow := range value.Values[:len(value.Values)-1] {
var nextRow Value
if index < timeSeriesDataCount {
nextRow = value.Values[index+1]
fmt.Print(nextRow)
}
}
}
Run Code Online (Sandbox Code Playgroud)
请注意,我们可以检查 if len(value.Values) > 1
,因为即使 if 不会出现恐慌len = 1
,也会出现0
迭代。
另请注意,范围排除最后一个元素的切片不会访问最后一个元素(显然),因此如果您对元素执行其他任何操作,这可能不可行,但在您的示例中它们是等效的。