当前位置: 首页 > 知识库问答 >
问题:

对…的`的迭代顺序。。。范围`当索引是隐式的

鄢子平
2023-03-14

https://golang.org/ref/spec#For_range

对于带有range子句的语句

对于数组、指向数组的指针或切片值a,索引迭代值按递增顺序生成,从元素索引0开始。如果最多存在一个迭代变量,范围循环将生成从0到len(a)-1的迭代值,并且不会索引到数组或切片本身。对于nil切片,迭代次数为0。

根据规范,遍历Go中的线性数据结构(数组、切片或字符串)将始终按索引增加的顺序获取其中的每个元素。

for i, v := range []int{11, 22, 33, 44} {
    fmt.Println(i, v)
}

但问题是我在说明书中找不到保证,

这个带有隐式索引迭代值的范围迭代结束子句也将始终保持相同的顺序:

for _, v := range []int{11, 22, 33, 44} {
    fmt.Println(v)
}

我上面的两个例子总是以同样的顺序执行吗?

我想他们知道,但我还没听到promise。

对。。。当索引迭代值由空白标识符(下划线<代码> <代码> >表示时,范围< /代码>工作?


共有1个答案

孔礼骞
2023-03-14

这在规范中,但我认为你忽略了一些东西。有迭代值和迭代变量。

对于每个条目,它将迭代值分配给相应的迭代变量(如果存在),然后执行块。

您的报价是指迭代值:

对于数组、指向数组的指针或切片值a,从元素索引0开始按递增顺序生成索引迭代值。如果最多存在一个迭代变量,范围循环将生成从0到len(a)-1的迭代值,并且不会索引到数组或切片本身。

如您所见,无论迭代变量有多少,迭代值总是以递增的顺序,从元素索引0开始。

第二个迭代值总是a[i],其中i对应于第一个迭代值,索引:

Range expression                          1st value          2nd value

array or slice  a  [n]E, *[n]E, or []E    index    i  int    a[i]       E

 类似资料:
  • 问题 你有一系列排序序列,想将它们合并后得到一个排序序列并在上面迭代遍历。 解决方案 heapq.merge() 函数可以帮你解决这个问题。比如: >>> import heapq >>> a = [1, 4, 7, 10] >>> b = [2, 5, 6, 11] >>> for c in heapq.merge(a, b): ... print(c) ... 1 2 4 5 6 7

  • 有一个非常常见且简单的任务是在两个方向上通过某个范围进行循环迭代: 上面的代码运行完美,但我花了大约一个小时试图摆脱双重检查。 有没有办法解决如果没有如果?也许是一句话?

  • 我有一个bean,我用它作为传输对象。bean的类定义为- 我正在使用这个bean,在带有Model属性注释的Spring控制器中。对于JSP,我有JSTL。我已经用这样的字段填充了JSP。 当我提交表单时,我得到Java . lang . indexoutofboundsexception:Index:0,Size: 0。

  • 问题内容: 因此,在Java中,每当给出索引范围时,上限几乎总是排他的。 来自: 返回一个新字符串,该字符串是该字符串的子字符串。子字符串从指定的字符串开始,并扩展到索引的字符 来自: -要复制的范围的初始索引(包括两端) - 要复制的范围的最终索引,包括高端。 来自: -要设置的第一位的索引。 -要设置的最后一位之后的索引。 如您所见,它看起来确实像Java试图使它成为一致的约定,即上限是互斥的

  • 我需要分析Word文档的文本,并在分析器检测到的文本范围内创建书签(几乎像语法检查器)。 我不想使用实用程序,因为我的需求太具体了。 为此,, 1/检索纯文本文档 我检索文档主要故事的纯文本: 字符串明文=活动文档。范围().文本; 2/分析纯文本并得到结果 我将其发送到analyzer工具,该工具返回一个带位置的标记集合:例如,如果我想在文档文本中检测到模式“my pattern”,analyz

  • 问题内容: 我正在尝试创建一个函数,该函数将计算多维numpy数组中元素之间的晶格距离(水平和垂直步数)。为此,我需要在遍历数组时从每个元素的索引中检索实际数字。我想将这些值存储为可以通过距离公式运行的数字。 对于示例数组A 我想创建一个循环遍历每个元素的循环,对于第一个元素1,它将检索a = 0,b = 0,因为1处于A [0,0],然后对于元素来说a = 0,b = 1 2,因为它位于A [0