как клиенту нежен IEnumerable то пишешь просто:
IEnumerable<Products> prod = rep.GetProducts()
вот и все
А если ты захочешь возвращать другую реализацию ICollection, контракт будешь ломать?
В том что "изменить уже реализацию потом просто не получится", если выяснится, что эффективней использовать массив или LinkedList, то это уже не сделать без затрагивания клиентского кода
Хм, уже второй раз такой пример в чате проскакивает. Откуда вы это берёте? Из какой-то книги сомнительного содержания? В 2019 все пишут var и применяют dependency inversion, чтобы не ломать публичный API :)
Рекомендуется возвращать как раз ICollection/IList/etc для материализованных коллекций (массивов, списков, и т.п. для которых можно обращаться по индексу) а IEnumerable для нематериализованных (различные отложенные вызовы и прочие генераторы)
Обсуждают сегодня