Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > C/C++: Общие вопросы > вывод std::map в поток.


Автор: DukeCpp 22.12.2006, 22:02
Здравствуйте, винградовцы.

Подскажите, как вывести std::map в стандартный поток с помощью ostream_iterator?

c вектором всё ясно:


   
Код

 copy(v.begin(), v.end(), std::ostream_iterator<double>(ofs, " \n"));


а например, std::map<string, int> m хотелось бы так:

 
Код

   copy(m.begin(), m.end(), std::ostream_iterator<std::map<std::string, int> >(cout, " \n"));
но так нельзя, т.к. по понятным причинам.

Error    1    error C2679: binary '=' : no operator found which takes a right-hand operand of type 'std::pair<_Ty1,_Ty2>' (or there is no acceptable conversion)    c:\program files\microsoft visual studio 8\vc\include\xutility    2228

Можно, конечно, написать свой класс MyCout и перегрузить у него оператор =, но хотелось бы что-нибудь менее "комплексное"

Автор: Daevaorn 22.12.2006, 22:20
Самое простое, но и одно из самых нехороших:
Код

#include <iostream>
#include <map>
#include <algorithm>

namespace std
{
    template <class T, class U>
    std::ostream& operator<<(std::ostream& out, std::pair<T, U> const& p)
    {
        return out << p.first << ' ' << p.second;
    }
}

int main()
{
    std::map<int, int> m;
    std::copy(m.begin(), m.end(), std::ostream_iterator<std::map<int, int>::value_type>(std::cout, "\n" ) );
    return 0;
}

Автор: DukeCpp 22.12.2006, 23:47
Спасибо большое! пусь и не самое хорошее, но -- решение вопроса.

С удовольствием, однако, узнаю и другие способы; поэтому тему не закрываю.

Автор: DukeCpp 23.12.2006, 02:42
Цитата(Daevaorn @ 22.12.2006,  22:20)
Самое простое, но и одно из самых нехороших:


А в чём его "нехорошесть"?

Автор: Daevaorn 23.12.2006, 09:08
Цитата(DukeCpp @  23.12.2006,  03:42 Найти цитируемый пост)
А в чём его "нехорошесть"? 

Для начала в этом:
Цитата(Daevaorn @  22.12.2006,  23:20 Найти цитируемый пост)
namespace std
{


Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)