CPPPROGLIB Telegram 6270
🍪 Чем ranges::iota отличается от std::iota под капотом?

C++20 принёс std::ranges::iota, который выглядит как улучшенная версия старого std::iota. Но это не просто API-обёртка — механизм работы совершенно другой.

✏️ std::iota — eager алгоритм:
std::iota(v.begin(), v.end(), 0);


Выполняется немедленно, проходит по контейнеру один раз, записывает значения. После вызова вектор заполнен.

✏️ ranges::iota — ленивая view:
auto view = std::views::iota(0, 10);


Возвращает view — лёгкий объект, который генерирует значения по требованию.

Внутри это просто два поля:

struct iota_view {
T current_;
T bound_;

T operator*() const { return current_; }
void operator++() { ++current_; }
};


Никакого выделения памяти! View не хранит элементы, он вычисляет их при обращении. Это O(1) по памяти против O(N) для std::iota.

💡 Композиция views:

auto result = views::iota(0, 100) 
| views::filter([](int x) { return x % 2 == 0; })
| views::take(10);


Компилятор inline'ит всю цепочку в один проход. Нет промежуточных контейнеров, нет лишних аллокаций. Просто счётчик и предикат.

❗️Практический вывод: если вам нужен материализованный контейнер — std::iota. Если цепочка преобразований — ranges::iota. Разные инструменты для разных задач.

❗️Ranges — это не замена алгоритмов, это другая парадигма.


🔹 Курс «Алгоритмы и структуры данных»
🔹 Получить консультацию менеджера
🔹 Сайт Академии🔹Сайт Proglib

Библиотека C/C++ разработчика

#под_капотом
Please open Telegram to view this post
VIEW IN TELEGRAM
👍62



tgoop.com/cppproglib/6270
Create:
Last Update:

🍪 Чем ranges::iota отличается от std::iota под капотом?

C++20 принёс std::ranges::iota, который выглядит как улучшенная версия старого std::iota. Но это не просто API-обёртка — механизм работы совершенно другой.

✏️ std::iota — eager алгоритм:

std::iota(v.begin(), v.end(), 0);


Выполняется немедленно, проходит по контейнеру один раз, записывает значения. После вызова вектор заполнен.

✏️ ranges::iota — ленивая view:
auto view = std::views::iota(0, 10);


Возвращает view — лёгкий объект, который генерирует значения по требованию.

Внутри это просто два поля:

struct iota_view {
T current_;
T bound_;

T operator*() const { return current_; }
void operator++() { ++current_; }
};


Никакого выделения памяти! View не хранит элементы, он вычисляет их при обращении. Это O(1) по памяти против O(N) для std::iota.

💡 Композиция views:

auto result = views::iota(0, 100) 
| views::filter([](int x) { return x % 2 == 0; })
| views::take(10);


Компилятор inline'ит всю цепочку в один проход. Нет промежуточных контейнеров, нет лишних аллокаций. Просто счётчик и предикат.

❗️Практический вывод: если вам нужен материализованный контейнер — std::iota. Если цепочка преобразований — ranges::iota. Разные инструменты для разных задач.

❗️Ranges — это не замена алгоритмов, это другая парадигма.


🔹 Курс «Алгоритмы и структуры данных»
🔹 Получить консультацию менеджера
🔹 Сайт Академии🔹Сайт Proglib

Библиотека C/C++ разработчика

#под_капотом

BY Библиотека C/C++ разработчика | cpp, boost, qt


Share with your friend now:
tgoop.com/cppproglib/6270

View MORE
Open in Telegram


Telegram News

Date: |

“Hey degen, are you stressed? Just let it all out,” he wrote, along with a link to join the group. Some Telegram Channels content management tips The best encrypted messaging apps The SUCK Channel on Telegram, with a message saying some content has been removed by the police. Photo: Telegram screenshot. Write your hashtags in the language of your target audience.
from us


Telegram Библиотека C/C++ разработчика | cpp, boost, qt
FROM American