Модераторы: Daevaorn
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как работать с std::cerr, std::log? 
V
    Опции темы
Alca
Дата 19.1.2011, 11:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 3993
Регистрация: 14.6.2006

Репутация: 7
Всего: 50



Код

#include <iostream>
#include <string>
 
using namespace std;
 
string 
day_of_week(int now) {
    const string dow[] = { "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday" };
 
    if (now < 1 || now > 7)
        throw 1;
    else
        return dow[now - 1];
}
 
int 
main() {
    try {
        cout << day_of_week(1) << endl;
        cout << day_of_week(3) << endl;
        cout << day_of_week(15) << endl;
    } catch(...) {
        cout << "cout: Out of range!" << endl;
        cerr  << "cerr: Out of range!" << endl;
        clog  << "clog: Out of range!" << endl; 
    }
 
    return 0;
}

http://liveworkspace.org/code/ad45dc33a99e...6512e614714fbfd

Вывод:
Цитата

Monday
Wednesday
cout: Out of range!
cerr: Out of range!
clog: Out of range!

Вот записали мы строку в std::cerr и в  std::clog.
Что дальше дальще с ними делать? Как с этим жить?   smile 

Это сообщение отредактировал(а) Alca - 19.1.2011, 11:40


--------------------
PM WWW ICQ Skype Jabber   Вверх
xvr
Дата 19.1.2011, 11:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 7046
Регистрация: 28.8.2007
Где: Дублин, Ирландия

Репутация: 60
Всего: 223



throw без параметра допустимо звать только внутри блока catch. Дайте в throw что нибудь:
Код

string 
day_of_week(int now) {
    const string dow[] = { "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", "Sunday" };
 
    if (now < 1 || now > 7)
        throw 1;
    else
        return dow[now - 1];
}
 


PM MAIL   Вверх
Alca
Дата 19.1.2011, 11:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 3993
Регистрация: 14.6.2006

Репутация: 7
Всего: 50



Цитата

Дайте в throw что нибудь:

Отредактировал.
Какой смыл использовать std::log и std::cerr если есть std::cout.
Какие преимущества?


--------------------
PM WWW ICQ Skype Jabber   Вверх
xvr
Дата 19.1.2011, 11:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 7046
Регистрация: 28.8.2007
Где: Дублин, Ирландия

Репутация: 60
Всего: 223



Цитата(Alca @  19.1.2011,  11:41 Найти цитируемый пост)
Какой смыл использовать std::log и std::cerr если есть std::cout. 
cerr - это стандартный поток STDERR и он отличается от STDOUT. Их можно перенаправить с командной строки в файл (по отдельности)
Цитата

cmd > file.txt
перенаправит только STDOUT, а
Цитата

cmd 2> file.txt
перенаправит только STDERR
std::log смотрит туда же, куда и std::cerr, он внутри программы это другой объект.
Цитата

Какие преимущества?
Ну например, если ваша программа должна работать как фильтр (читать с cin и писать в cout), вы можете сообщения об ошибках безболезненно выводить в cerr, и они не будут смешиваться с выходными данными (из cout)

PM MAIL   Вверх
Alca
Дата 19.1.2011, 11:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 3993
Регистрация: 14.6.2006

Репутация: 7
Всего: 50



Ааа понял. Это просто разные объекты одного и того же класса. 

iostream.h
Код

  extern istream cin;        ///< Linked to standard input
  extern ostream cout;        ///< Linked to standard output
  extern ostream cerr;        ///< Linked to standard error (unbuffered)
  extern ostream clog;        ///< Linked to standard error (buffered)


Т.е. я могу создать свой объект и использовать для определенной цели.
Код

ostream сmyout;


xvr, Спасибо.


Это сообщение отредактировал(а) Alca - 19.1.2011, 11:59


--------------------
PM WWW ICQ Skype Jabber   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.0592 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.