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

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

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.90
Tulosba
:)
Эксперт C++
4377 / 3220 / 297
Регистрация: 19.02.2013
Сообщений: 9,044
27.06.2014, 12:29     Наследование от std::ostream #1
Имеем код:
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
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 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
3878 / 1504 / 227
Регистрация: 06.01.2013
Сообщений: 4,028
Завершенные тесты: 1
27.06.2014, 17:02     Наследование от std::ostream #22
Tulosba, читерство: создать глобальный функциональный объект и юзать его...
Tulosba
:)
Эксперт C++
4377 / 3220 / 297
Регистрация: 19.02.2013
Сообщений: 9,044
27.06.2014, 17:07  [ТС]     Наследование от std::ostream #23
Цитата Сообщение от ForEveR Посмотреть сообщение
А почему не взять что-нибудь готовое?) Например поразбираться с boost::log.)
Это тоже дело хорошее конечно. Просто как бывает: начинаешь с малого, а потом всплывает что-то любопытное и приходится копаться по колено в ...
Цитата Сообщение от ForEveR Посмотреть сообщение
Нужна перегрузка именно для манипуляторов к сожалению.
Шаблонный вариант кушает, если не возникает проблем как с std::endl например. Или тут тоже какой-то может быть нюанс? Я имею в виду например с std::hex.
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 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
Еще ссылки по теме:

Friend ostream& operator<<(ostream& stream, CArr& obj); C++
Создание своего класса исключений, наследование std::exception C++
Ошибка: отсутствует оператор >>,соответствующий этим операндам типы операндов: std::ostream>>const double C++

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

Или воспользуйтесь поиском по форуму:
Tulosba
:)
Эксперт C++
4377 / 3220 / 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
Ответ Создать тему
Опции темы

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