为什么 Go 中的切片语法排除高边界(hi)? Go 切片语法 s[lo:hi] 指定一个元素范围从索引 lo(包含)到 hi-1(不包含)。这与 hi 将包含在该范围内的直觉预期不同。 设计原理 独占切片的选择是一个约定问题,并具有以下几个优点: 指针算术简单性: 在 Go 中,切片本质上是具有相关长度的指针。对于 0 索引数组和独占切片,元素 i 的地址只是指针值加上 i。 方便的数组长度: 切片的长度也是它的“分割点”。 ”这意味着 arr[0:len(arr)] 等价于 arr,方便进行数组分割等操作。 非重叠索引: 独占切片确保连续的切片完全覆盖原始数组。这简化了基于非连续整数分割数组等操作。 相反,包含性切片 - 其中 [lo:hi] 包括 lo 和 hi - 会导致切片重叠并使某些操作复杂化.