std::mem_fun
принимает указатель.Так что
bind(std::mem_fun(&istream::get), &cin)
где
template <typename F, typename Res, typename Arg>
struct binder
{
binder(F const& f, Arg const& arg) : f(f), arg(arg) {}
Res operator()() { return f(arg); }
private:
F f; Arg arg;
};
template <typename F, typename Arg>
binder<F, typename F::result_type, Arg> bind(F const& f, Arg const& arg)
{ return binder<F, typename F::result_type, Arg>(f, arg); }
Вы также можете использовать std::istream_iterator
с пользовательским / украденным copy_n
алгоритмом (который, к сожалению, не является стандартным):
template <typename I, typename O>
O copy_n(size_t n, I first, I last, O result)
{
size_t k = 0;
while (first != last && k++ < n) *result++ = *first++;
return result;
}