Мы решили следовать Python, когда дело доходит до арифметики начала и конца. 0
обозначает первый элемент (как всегда), а ^0
«длина», т. Е. Тот, который находится непосредственно с конца. Таким образом, вы получите простое отношение, где позиция элемента от начала плюс его позиция от конца равна длине. x
в ^x
- это то, что вы вычли бы из длины, если бы вы сделали математику самостоятельно.
Почему бы не использовать минус (-
) вместо оператора новой шляпы (^
)? Это в первую очередь связано с диапазонами. Опять же, в соответствии с Python и большей частью отрасли, мы хотим, чтобы наши диапазоны были включающими в начале, исключительными в конце. Какой индекс вы передаете, чтобы сказать, что диапазон должен идти до конца? В C # ответ прост: x..^0
идет от x
до конца. В Python нет явного индекса, который вы можете дать: -0
не работает, потому что он равен 0
, первый элемент! Поэтому в Python вы должны полностью отключить конечный индекс, чтобы выразить диапазон, идущий до конца: x..
. Если вычисляется конец диапазона, вам нужно помнить, чтобы иметь специальную логику на случай, если она достигнет 0
. Как и в x..-y
, где y
было вычислено и получилось 0
. Это распространенная неприятность и источник ошибок.
Наконец, обратите внимание, что индексы и диапазоны являются первыми типами классов в .NET / C #. Их поведение не связано с тем, к чему они применяются, или даже для использования в индексаторе. Вы можете полностью определить свой собственный индексатор, который использует индекс, и еще один, который принимает Range
- и мы собираемся добавить такие индексаторы, например, к. Span
. Но вы также можете иметь методы, которые принимают диапазоны, например.
Я думаю, что это соответствует классическому синтаксису, к которому мы привыкли:
Если бы он использовал 0, было бы непонятно, когда два синтаксиса использовались бок о бок. Таким образом, когнитивная нагрузка ниже .
Другие языки, такие как Python, также используют то же соглашение.