170 похожих чатов

Есть интерфейс IReadOnlyList<T>. Он позволяет перечислять, получать элементы по индексу

и содержит информацию о количестве элементов.

Практически всегда под IEnumerable возвращается коллекция. Если вы возвращаете ее как IEnumerable, то с большой доле1 вероятности клиент вызовет на ней ToArray, чтобы передать в другое место. Если количество элементов большое, то будет создано log_2(n) массивов с копированием элементов из одного в другой. Также это помешает использовать такую коллекцию в цикле for.

Используйте IEnumerable для возвращения отложенных вычислений. Имея на руках массив или список возвращайте IReadOnlyList, для прочих коллекций - IReadOnlyCollection. Или не морочьте никому голову и возвращайте массив. Но не возвращайте IEnumerable для коллекций без отложенного вычисления, это породит лишнее копирование и лишние вопросы - могу ли я вернуть IEnumerable и перечислить его после закрытия коннекции? Могу ли я перечислять его одновременно с другими вызовами? Могу ли шарить энумератор между несколькими потоками.

Возврат IEnumerable затрудняет понимание кода, а не упрощает API.

5 ответов

13 просмотров

Это что, с м**та текст?

> Практически всегда под IEnumerable возвращается коллекция. На самом деле не так уж и редко клиентам бывает нужно просто проитерироваться по элементам. Но да, в большинстве случаев лучше подойдёт IReadOnlyList или IReadOnlyCollection, спасибо за развёрнутый комментарий! :)

Мы на продакшене только айнумерабл и возвращаем ....хм

Подписываюсь под каждым словом, хотя есть фигня в том что IList не реализует IReadOnlyList

Наверное, есть и другие примеры на правило "если можно конкретизировать без урезания функционала - конкретезируй"

Похожие вопросы

Обсуждают сегодня

Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
48
Всем привет! Скажите, никто не пытался уменьшить размер процесса ssl, которые ассоциируется с открытым соединением (не помню точное название этого процесса, но там была какая-...
Алексей
20
а проверьте, собирается ли у кого сейчас транк лазаря через делюкс? у меня вот: fpcupdeluxe: info: Lazarus Native Installer (BuildModuleCustom: UserIDE): LazBuild: building Us...
Iluha Companets
20
Мне тут приспичило встроить в программу форматировние текста SQL, расставить переносы строк и отступы так, чтобы лучше читалось. Я что-то свое изобразил, оно после ключевых сл...
Sergey Bodrov
11
This is a big issue. Just by being a citizen of a country, you are denied to contribute to Open Source software: https://youtu.be/L5Ec5jrpLVk?si=1iIuHnMPbCB4anV-
Sharuzzaman Ahmat Raslan
72
добрый день. возможно ли изменить цвет окон лазаруса? Как?
Budemposmotret
35
Господа, а кто-нибудь сталкивался с размещением на TTabControl/TTabSheet множества контролов (> 100) с последующими External: Access violation? Вот буквально на ровном месте. ...
Dmitry
29
А какие существуют способы обработки ошибок выделения памяти в ядре? Т.е., допустим, есть функция, которая возвращает адрес свободной страницы в физической памяти и диапазон в...
disba1ancer
51
Добрый день. Опять снова хочу обратиться к вам за помощью. После создания проэкта stack new, lazy.nvim + nvim-lspconfig/haskell-tools + hlint, ormolu из mason + hls из ghcup ...
Nannk
8
Does anyone have some zeroday's left?
Wito!d ♥️🩷
44
Карта сайта