Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.90
Tulosba
:)
Эксперт С++
4384 / 3227 / 297
Регистрация: 19.02.2013
Сообщений: 9,044
#1

Наследование от std::ostream - C++

27.06.2014, 12:29. Просмотров 1352. Ответов 24
Метки нет (Все метки)

Имеем код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <iostream>
 
class DebugMessage : public std::ostream
{
public:
    DebugMessage() : std::ostream( std::cout.rdbuf() ) { }
    virtual ~DebugMessage() { *this << std::endl; }
};
 
int main(int argc, char *argv[])
{
    DebugMessage() << "hello" << 42;
 
    return 0;
}
На C++11 выводит
hello42
Без С++11 выводит
0x8048e2842
т.е. аргумент const char* интерпретируется как const void* и выводится адрес, а не строка.

Кто-нибудь может объяснить, почему?
Лучшие ответы (1)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ForEveR
Модератор
Эксперт С++
 Аватар для ForEveR
7958 / 4720 / 319
Регистрация: 24.06.2010
Сообщений: 10,525
Завершенные тесты: 3
27.06.2014, 16:51     Наследование от std::ostream #21
Tulosba, А почему не взять что-нибудь готовое?) Например поразбираться с boost::log.)

Нужна перегрузка именно для манипуляторов к сожалению.

C++
1
2
3
4
5
DebugMessage& operator << (std::ostream&(*manip)(std::ostream&))
{
    stream << manip;
    return *this;
}
А вообще нужно три перегрузки по сути (std::ostream&(std::ostream&), std::ios_base&(std::ios_base&), std::ios&(std::ios&)).
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
FraidZZ
Модератор
 Аватар для FraidZZ
3892 / 1518 / 229
Регистрация: 06.01.2013
Сообщений: 4,044
Завершенные тесты: 1
27.06.2014, 17:02     Наследование от std::ostream #22
Tulosba, читерство: создать глобальный функциональный объект и юзать его...
Tulosba
:)
Эксперт С++
4384 / 3227 / 297
Регистрация: 19.02.2013
Сообщений: 9,044
27.06.2014, 17:07  [ТС]     Наследование от std::ostream #23
Цитата Сообщение от ForEveR Посмотреть сообщение
А почему не взять что-нибудь готовое?) Например поразбираться с boost::log.)
Это тоже дело хорошее конечно. Просто как бывает: начинаешь с малого, а потом всплывает что-то любопытное и приходится копаться по колено в ...
Цитата Сообщение от ForEveR Посмотреть сообщение
Нужна перегрузка именно для манипуляторов к сожалению.
Шаблонный вариант кушает, если не возникает проблем как с std::endl например. Или тут тоже какой-то может быть нюанс? Я имею в виду например с std::hex.
ForEveR
Модератор
Эксперт С++
 Аватар для ForEveR
7958 / 4720 / 319
Регистрация: 24.06.2010
Сообщений: 10,525
Завершенные тесты: 3
27.06.2014, 17:11     Наследование от std::ostream #24
Tulosba, Судя по всему проблема в том, что hex есть std::ios_base(*)(std::ios_base&).
В то время как std::endl это

C++
1
2
template< class CharT, class Traits >
std::basic_ostream<charT,traits>& endl( std::basic_ostream<CharT, Traits>& os );
Поэтому он не может зарезолвить функцию, так что с нешаблонными манипуляторами проблем быть не должно.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.06.2014, 17:25     Наследование от std::ostream
Еще ссылки по теме:

Ошибка: отсутствует оператор >>,соответствующий этим операндам типы операндов: std::ostream>>const double C++
отсутствует оператор "<<" соответствующий этим операндам (std::ostream << const std::string) C++
C++ Как можно еще использовать std::placeholders вне в связки с std::bind?
Что может выступать в качестве аргумента функции, если тип параметра указан как std::ostream? C++
C2678 бинарный ">>": не найден оператор, принимающий левый операнд типа "std::ostream" C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Tulosba
:)
Эксперт С++
4384 / 3227 / 297
Регистрация: 19.02.2013
Сообщений: 9,044
27.06.2014, 17:25  [ТС]     Наследование от std::ostream #25
Цитата Сообщение от ForEveR Посмотреть сообщение
Поэтому он не может зарезолвить функцию, так что с нешаблонными манипуляторами проблем быть не должно.
Ну я по-сути об этом и писал, static_cast'ом указываем какой вариант должен получиться из шаблона, если не получается вывести типы автоматически.
C++
1
2
3
4
5
6
7
8
9
10
11
12
#include <iostream>
 
template <typename T>
T f() { T t=42.100500; return t; }
 
int main() {
    
    std::cout << static_cast<int(*)()>(f)() << std::endl;
    std::cout << static_cast<double(*)()>(f)() << std::endl;
    
    return 0;
}
http://ideone.com/2MwRhn

Добавлено через 1 минуту
Цитата Сообщение от ForEveR Посмотреть сообщение
так что с нешаблонными манипуляторами проблем быть не должно.
Ну или если у манипулятора есть несколько перегрузок, даже когда он не является шаблонным. Если такие существуют конечно
Yandex
Объявления
27.06.2014, 17:25     Наследование от std::ostream
Ответ Создать тему
Опции темы

Текущее время: 01:28. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru