298 / 107 / 31
Регистрация: 12.03.2012
Сообщений: 449
1

Передать stringstream аргументом

22.04.2017, 11:53. Показов 2530. Ответов 6
Метки нет (Все метки)

Есть абстрактный логгер с перегрузкой оператора ()
Хочется передавать в него любые аргументы, для которых у ostream есть перегрузка
Пытаюсь сделать так:
C++
1
2
3
4
5
    void operator()(std::ostream& msg)
    {
        logFile << dynamic_cast<std::ostringstream&>(msg).str() << std::endl;
        return;
    };
Но приходится писать:
C++
1
log(std::ostringstream().flush() << "test";
Не очень здорово
Со string такая же ситуация, приходится создавать std::string() и потом конкатенировать аргументы
Костыль
C++
1
#define logging_printStream(token) { std::stringstream o; o << token; logging::print(o.str().c_str()); }
Не годится
простая перегрузка << с ostream& тоже не годится т.к. нужно определять начало и конец сообщения
Существует человеческий вариант решения?
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
22.04.2017, 11:53
Ответы с готовыми решениями:

Как передать в stringstream переменную типа int?
Как запихнуть в stringstram int? Не находит такой перегруженной функции. sstream заинклудил....

Нужно передать вторым аргументом char, а не int в метод ignore()
Здравствуйте, в общем пытаюсь записывать и считать из файла. Записывается все как надо и сейчас...

Как передать аргументы в метод с params аргументом?
Доброго вечера, форумчане Нужна помощь с задачей с применением метода params. Даны натуральные...

Копирование файла, указанного первым аргументом, в папку, часть пути к которой указана вторым аргументом
Добрый день. Есть два задания из лабораторной работы. Я бы с радостью их сделал где угодно, кроме...

6
Любитель чаепитий
3726 / 1786 / 561
Регистрация: 24.08.2014
Сообщений: 5,983
Записей в блоге: 1
22.04.2017, 11:58 2
C++
1
2
3
4
5
6
template<typename T>
loggerT & operator <<(loggerT & logger, const T & msg)
{
  logger.stream << msg;
  return logger;
}
0
298 / 107 / 31
Регистрация: 12.03.2012
Сообщений: 449
22.04.2017, 12:02  [ТС] 3
Цитата Сообщение от GbaLog- Посмотреть сообщение
C++
1
2
3
4
5
6
template<typename T>
loggerT & operator <<(loggerT & logger, const T & msg)
{
  logger.stream << msg;
  return logger;
}
Написал же...
Простая перегрузка << с ostream& тоже не годится т.к. нужно определять начало и конец сообщения
может немного некорректно, но имел ввиду именно это.
вначале сообщения должен вписываться префикс, в конце - перенос строки
0
7166 / 6141 / 2802
Регистрация: 14.04.2014
Сообщений: 26,462
22.04.2017, 12:08 4
Для чего вообще передаётся ostream как параметр? logFile не может, что ли, сам параметры принять?
0
Любитель чаепитий
3726 / 1786 / 561
Регистрация: 24.08.2014
Сообщений: 5,983
Записей в блоге: 1
22.04.2017, 12:14 5
Лучший ответ Сообщение было отмечено h3mbr0 как решение

Решение

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
//g++  5.4.0
 
#include <iostream>
#include <sstream>
 
struct Logger
{
    template<typename ... Args>
    void log(Args &&... args)
    {
        strm << "[some prefix] ";
        
        using dummy = char[];
        
        (void)dummy{ (strm << std::forward<Args>(args) << " ", static_cast<char>(0))... };
        
        strm << "\n";
    }
    
    void flush()
    {
        std::cout << strm.str();
        strm.clear();
    }
    
private:
    std::ostringstream strm;
};
 
int main()
{
    std::cout << "Hello, world!\n";
    
    Logger l;
    
    l.log("ololo", 123, 3.14, '1');
    l.flush();
}
1
298 / 107 / 31
Регистрация: 12.03.2012
Сообщений: 449
22.04.2017, 12:22  [ТС] 6
Хотелось бы не как аргументы, но это вполне подойдет, спасибо
только не до конца понятно, что делает
C++
1
2
using dummy = char[];
(void)dummy{ (strm << std::forward<Args>(args) << " ", static_cast<char>(0))... };
Вернее так, предназначение понятно, но что происходит - нет
0
Любитель чаепитий
3726 / 1786 / 561
Регистрация: 24.08.2014
Сообщений: 5,983
Записей в блоге: 1
22.04.2017, 12:29 7
Цитата Сообщение от h3mbr0 Посмотреть сообщение
что происходит
Функция принимает любое количество строк а затем складывает их
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
22.04.2017, 12:29
Помогаю со студенческими работами здесь

С# stringstream
Доброго времени суток! Не могу разобраться с отличием синтаксиса с С++ и С#. Подскажите,...

Stringstream C++
Доброго времени суток! Совсем недавно мне понадобились преобразования int to string и наоборот....

Stringstream и оператор >>
Доброго времени. Код: #include &lt;iostream&gt; #include &lt;sstream&gt; using namespace std; int...

Std::stringstream
Добрый день! Я не понимаю почему я ввожу в поток std::stringstream три элемента, число, строку и...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru