template<typename FormatContext>
auto format(T & value, FormatContext & ctx) const
{
return fmt::format_to(ctx.out(), "{}", value());
}
};
auto f = [n = 0]() mutable { return n++; };
fmt::println("{1} {0} {1}", f, f);` и есть кастомный форматтер (псевдокод):
Здесь ведь выражение для первого аргумента должно быть вычислено один раз? Вывод должен быть 0 1 0?
Здесь выражения - это f: порядок их вычисления не уточняется, но их вычисление - это не вызов, а идентичность объекта. Т.е., да, n++ к этому не имеет отношения - это библиотекой определяется.
Здесь две копии передаются. Ой.... Ссылки
там точно копии? А копии в порядке перечисления аргументов создаются?
Обсуждают сегодня