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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Exception vs Error Code, Как вы реализуете Error Management? 
:(
    Опции темы
 
Как вы реализуете Error Management?
Всегда Exception-ы [ 29 ]  [39.19%]
Когда необходимо Error Codes, в остальных случаях Exception-ы [ 32 ]  [43.24%]
Когда необходимо Exception-ы, в остальных случаях Error Codes [ 8 ]  [10.81%]
Всегда Error Codes [ 5 ]  [6.76%]
Всего проголосовавших: 74
В этом опросе возможен один вариант ответа
Гости не могут голосовать 
neutrino
Дата 16.6.2008, 13:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Gothic soul
****


Профиль
Группа: Модератор
Сообщений: 3041
Регистрация: 25.3.2002
Где: Верхняя Галилея, Кармиэль

Репутация: нет
Всего: 62



Привет!

Вот собственно и вопрос. Кто чем пользуется и почему.
Про себя: всегда только Exception-ами. ИМХО нет случая, когда необходимо пользовать Error Code. Если необходимо использовать Error Code, значит ошибка в дизайне.

Или я еще не сталкивался с настоящими случаями в которых нужен Error Code.

PS: Тут не имеются в виду всякие там АПИ. Только ваш код.


--------------------
The truth comes from within ...

Покойся с миром, Vit 
PM MAIL WWW ICQ Skype GTalk   Вверх
maxim1000
Дата 16.6.2008, 22:52 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Участник
Сообщений: 3334
Регистрация: 11.1.2003
Где: Киев

Репутация: нет
Всего: 110



честно говоря, чего-то полностью устоявшегося у меня в голове нет, но придумалось такое правило:
для исключительных ситуаций - исключения
для ошибок (остальных) - коды ошибок

естественно, это - не строгое правило, но смысл передаёт

предположим есть объект, который предназначен для чтения bmp из файла
т.к. в заголовке есть достаточно информации для того, чтобы узнать, когда закончится файл, то недостача байтов вполне может считаться исключительной ситуацией

теперь рассмотрим объект читающий текстовый файл
так вот его функция чтения строки вполне может возвращать бинарный флаг, информирующий, был ли достигнут конец файла
с одной стороны, попытка чтения строки, когда конец файла достигнут - ошибка
с другой стороны подавляющее большинство файлов когда-нибудь кончаются, так что такая ситуация вполне ожидаема и исключительной её назвать сложно

вариант в голосовании так и не смог выбрать - и то, и то использую

в одном месте даже была мысль смешать два подхода: для ошибок, после которых парсинг должен прекратиться - исключения, для восстановленных - коды ошибок (чтобы верхний уровень имел эту информацию при необходимости), но это я ещё до конца не продумал, возможно, и не очень хорошая мысль...


--------------------
qqq
PM WWW   Вверх
Lazin
Дата 16.6.2008, 23:46 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 3820
Регистрация: 11.12.2006
Где: paranoid oil empi re

Репутация: 4
Всего: 154



в основном исключения, завтра напишу подробно  smile 
PM MAIL Skype GTalk   Вверх
chipset
Дата 17.6.2008, 00:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Экс. модератор
Сообщений: 4071
Регистрация: 11.1.2003
Где: Seattle, US

Репутация: 4
Всего: 164



А если пишешь DLL которая будет юзаться, к примеру дельфой или джавой?


--------------------
Цитата(Jimi Hendrix)
Well, I stand up next to a mountain
And I chop it down with the edge of my hand
PM MAIL WWW   Вверх
neutrino
Дата 17.6.2008, 07:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Gothic soul
****


Профиль
Группа: Модератор
Сообщений: 3041
Регистрация: 25.3.2002
Где: Верхняя Галилея, Кармиэль

Репутация: нет
Всего: 62



Спасибо за ответы.

Вот как мне думается все эти коды возврата делают код менее удобочитаемым. Плюс эксепшены я могу объединять в классы (наследование) ошибок и ловить скажем только ошибки ввода-вывода. Если бы я использовал коды возврата, то пришлось бы перечислять все в ифах. Эксепшены кстати можно ловить все в одной точке. А управление кодами - это еще то занятие... Короче если есть ошибка - это ексепшен. Если нужен код возврата, то это не ошибка а состояние объекта. И нужно сделать дизайн по-другому.
Цитата(maxim1000 @  16.6.2008,  21:52 Найти цитируемый пост)
теперь рассмотрим объект читающий текстовый файл
так вот его функция чтения строки вполне может возвращать бинарный флаг, информирующий, был ли достигнут конец файла

Вот так я никогда не делаю. Вместо этого я пишу отдельный метод, который проверяет достигнут ли конец файла или нет. Одно из главных правил, которым я пользуюсь - одна функция - один таск. Т.е. всегда я обхожу такие ситуации, где нужен код возврата.


--------------------
The truth comes from within ...

Покойся с миром, Vit 
PM MAIL WWW ICQ Skype GTalk   Вверх
chipset
Дата 17.6.2008, 08:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Экс. модератор
Сообщений: 4071
Регистрация: 11.1.2003
Где: Seattle, US

Репутация: 4
Всего: 164



Цитата(maxim1000 @  16.6.2008,  12:52 Найти цитируемый пост)

в одном месте даже была мысль смешать два подхода: для ошибок, после которых парсинг должен прекратиться - исключения, для восстановленных - коды ошибок (чтобы верхний уровень имел эту информацию при необходимости), но это я ещё до конца не продумал, возможно, и не очень хорошая мысль... 

ИМХО, это усложнит процесс обработки ошибок. Усложнять процесс обработки ошибок не нужно потому-что баги в ошибко-репортинге где-то хрен знает где на другом полушарии это очень и очень неприятно smile

Добавлено через 40 секунд
Цитата(neutrino @  16.6.2008,  21:41 Найти цитируемый пост)

Вот так я никогда не делаю. Вместо этого я пишу отдельный метод, который проверяет достигнут ли конец файла или нет. Одно из главных правил, которым я пользуюсь - одна функция - один таск. Т.е. всегда я обхожу такие ситуации, где нужен код возврата. 

Так построено большинство библиотек, тот-же STL smile


--------------------
Цитата(Jimi Hendrix)
Well, I stand up next to a mountain
And I chop it down with the edge of my hand
PM MAIL WWW   Вверх
Lazin
Дата 17.6.2008, 08:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 3820
Регистрация: 11.12.2006
Где: paranoid oil empi re

Репутация: 4
Всего: 154



попробую разложить по полочкам:
  • исключения очень сильно упрощают код
  • исключения делают код надежнее
  • исключения документируют код
1. исключения очень сильно упрощают код, так как позволяют разделить алгоритм нормального выполнения программы и алгоритм аварийной работы. Код получается более прозрачный, и компактный. Самое главное подсистема обработки ошибок не влияет на семантику класса.
Пример:
Код

HRESULT f1()
{
    HRESULT hr = f2();
    if ( FAILED(hr) )
    {
        return hr;
    }
    hr = f3();
    if ( FAILED(hr) )
    {
        return hr;
    }
    hr = f4();
    if ( FAILED(hr) )
    {
        return hr;
    }    
}
...
HRESULT hr = f1();
if ( FAILED(hr)
{
    //handle error
}

не очень ясный код, неправда-ли? smile 
Код

void f1()
{
    f2();
    f3();
    f4();
}
...
try
{
    f1();
}
catch( std::exception& e)
{
    //handle error
}

уже намного понятнее.. самое главное, в функции f1 вообще нет логики для обработки ошибок smile 
2. исключения делают код надежнее, в первую очередь из-за того, что исключение нельзя не обработать, как в случае с кодом ошибки, который можно легко потерять. В случае исключения проще найти причину ошибки.. так как исключение как правило несет в себе больше информации.
3. здесь все просто. 
Код

HRESULT func()
{
    ...
    if (...)
        return E_FAIL;
}

код возврата говорит только о том, что произошла какая-то ошибка и все
Код

void func()
{
    ...
    if (...)
        throw std::runtime_error("func: причина возникновения ошибки");
}

здесь, мало того, что исключение содержит диагностическую информацию, оно еще и документирует код... smile 

конечно, в некоторых случаях проще вернуть код ошибки, чем выбросить исключение, но эти случаи как правило можно отнести к нормальному выполнению программы, а не аварийному. Такой пример:
Код

int func(int key)
{
    ...
    std::map<int, int>::iterator i = data.find(key);
    //допустим data содержит положительные элементы
    if (i == data.end())//нет такого ключа
        return -1;
    return i->second;
}


Код

int func(int key)
{
    ...
    std::map<int, int>::iterator i = data.find(key); 
    if (i == data.end())//нет такого ключа
        throw std::runtime_error("func: нет значения в контейнере!");
    return i->second;
}

что из этого лучше трудно сказать, это зависит от контекста использования... например если отсутствие ключа в контейнере обычное явление, то наверное лучше первый вариант, а если отсутствие ключа означает сбой в работе программы, то второй...
PM MAIL Skype GTalk   Вверх
neutrino
Дата 17.6.2008, 09:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Gothic soul
****


Профиль
Группа: Модератор
Сообщений: 3041
Регистрация: 25.3.2002
Где: Верхняя Галилея, Кармиэль

Репутация: нет
Всего: 62



Lazin, спасибо за пост.

Цитата(Lazin @  17.6.2008,  07:36 Найти цитируемый пост)
что из этого лучше трудно сказать, это зависит от контекста использования... например если отсутствие ключа в контейнере обычное явление, то наверное лучше первый вариант, а если отсутствие ключа означает сбой в работе программы, то второй... 

Вот как раз об этом и речь. 


--------------------
The truth comes from within ...

Покойся с миром, Vit 
PM MAIL WWW ICQ Skype GTalk   Вверх
Nastya
Дата 17.6.2008, 12:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Комодератор
Сообщений: 1287
Регистрация: 27.3.2002
Где: Мариуполь

Репутация: нет
Всего: 44



п.2.
Error Code, если :
1. не всегда exception -ы возможны, помнится на PowerTV OS их юзать было нельзя :( 
2. Если изначально написание идет в си- стиле (не с++)
3. Интерфейсы типа idl и т.д.

может когда еще.
а так  exception


--------------------
Что бы понять рекурсию, надо понять рекурсию

"Профессионал - это человек сделавший все возможные ошибки в очень узкой области". Н.Бор
PM MAIL   Вверх
neutrino
Дата 17.6.2008, 12:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Gothic soul
****


Профиль
Группа: Модератор
Сообщений: 3041
Регистрация: 25.3.2002
Где: Верхняя Галилея, Кармиэль

Репутация: нет
Всего: 62



Интересно отметить, что ни в одном фундаментальном фреймворке вообще нет кодов возврата. Например в .NET-е или в Java.


--------------------
The truth comes from within ...

Покойся с миром, Vit 
PM MAIL WWW ICQ Skype GTalk   Вверх
neutrino
Дата 17.6.2008, 12:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Gothic soul
****


Профиль
Группа: Модератор
Сообщений: 3041
Регистрация: 25.3.2002
Где: Верхняя Галилея, Кармиэль

Репутация: нет
Всего: 62



Интересно отметить, что ни в одном фундаментальном фреймворке вообще нет кодов возврата. Например в .NET-е или в Java.


--------------------
The truth comes from within ...

Покойся с миром, Vit 
PM MAIL WWW ICQ Skype GTalk   Вверх
neutrino
Дата 17.6.2008, 12:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Gothic soul
****


Профиль
Группа: Модератор
Сообщений: 3041
Регистрация: 25.3.2002
Где: Верхняя Галилея, Кармиэль

Репутация: нет
Всего: 62



Интересно отметить, что ни в одном фундаментальном фреймворке вообще нет кодов возврата. Например в .NET-е или в Java.


--------------------
The truth comes from within ...

Покойся с миром, Vit 
PM MAIL WWW ICQ Skype GTalk   Вверх
LSD
Дата 17.6.2008, 13:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 9
Всего: 538



Цитата(neutrino @  17.6.2008,  13:53 Найти цитируемый пост)
Интересно отметить, что ни в одном фундаментальном фреймворке вообще нет кодов возврата. Например в .NET-е или в Java.

В Java - есть, но мало. Например функция удаления файла возвращает булево значение и выкидывает ексепшн. Или чтение из потока, тоже использует и коды возврата и ексепшены.

Хороший пример использования кодов: это библиотека HttpClient. Метод execute() возвращает код возврата связанный с ошибками HTTP протокола и выкидывает ексепшн когда происходят ошибки сети или парсинга HTTP-ответа.


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
skyboy
Дата 17.6.2008, 13:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


неОпытный
****


Профиль
Группа: Модератор
Сообщений: 9820
Регистрация: 18.5.2006
Где: Днепропетровск

Репутация: 1
Всего: 260



Цитата(neutrino @  17.6.2008,  11:53 Найти цитируемый пост)
 ни в одном фундаментальном фреймворке вообще нет кодов возврата. Например в .NET-е или в Java.

т.е. поиск позиции подстроки в строке выбрасывает Exception? smile

Добавлено через 1 минуту и 10 секунд
имел в виду ситуацию, когда подстрока в строке отсутствует
PM MAIL   Вверх
neutrino
Дата 17.6.2008, 13:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Gothic soul
****


Профиль
Группа: Модератор
Сообщений: 3041
Регистрация: 25.3.2002
Где: Верхняя Галилея, Кармиэль

Репутация: нет
Всего: 62



LSD
skyboy
Да вы правы.

Каким же правилом руководствоваться и в каких ситуациях?


--------------------
The truth comes from within ...

Покойся с миром, Vit 
PM MAIL WWW ICQ Skype GTalk   Вверх
neutrino
Дата 18.6.2008, 07:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Gothic soul
****


Профиль
Группа: Модератор
Сообщений: 3041
Регистрация: 25.3.2002
Где: Верхняя Галилея, Кармиэль

Репутация: нет
Всего: 62



Цитата(neutrino @  17.6.2008,  11:53 Найти цитируемый пост)
Интересно отметить, что ни в одном фундаментальном фреймворке вообще нет кодов возврата. Например в .NET-е или в Java. 


Цитата(neutrino @  17.6.2008,  11:53 Найти цитируемый пост)
Интересно отметить, что ни в одном фундаментальном фреймворке вообще нет кодов возврата. Например в .NET-е или в Java. 


Цитата(neutrino @  17.6.2008,  11:53 Найти цитируемый пост)
Интересно отметить, что ни в одном фундаментальном фреймворке вообще нет кодов возврата. Например в .NET-е или в Java.

Вот меня заело smile


--------------------
The truth comes from within ...

Покойся с миром, Vit 
PM MAIL WWW ICQ Skype GTalk   Вверх
skyboy
Дата 18.6.2008, 09:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


неОпытный
****


Профиль
Группа: Модератор
Сообщений: 9820
Регистрация: 18.5.2006
Где: Днепропетровск

Репутация: 1
Всего: 260



Цитата(neutrino @  18.6.2008,  06:35 Найти цитируемый пост)
Вот меня заело

видать, реально в душу запало  smile 
PM MAIL   Вверх
mr.DUDA
Дата 18.6.2008, 20:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


3D-маньяк
****


Профиль
Группа: Экс. модератор
Сообщений: 8244
Регистрация: 27.7.2003
Где: город-герой Минск

Репутация: 4
Всего: 232



Исключения нельзя использовать в real-time приложениях - слишком большие накладные расходы, по крайней мере в .NET

Но коды ошибок есть зло.  smile 


--------------------
user posted image
PM MAIL WWW   Вверх
nickless
Дата 19.6.2008, 00:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Гентозавр
****


Профиль
Группа: Участник Клуба
Сообщений: 2976
Регистрация: 29.8.2005
Где: Germany

Репутация: 2
Всего: 181



Для обработки ошибок - исключения (если они есть и их можно использовать), для всего остального - всё остальное smile 

Ситуации вроде этой
Цитата(skyboy @  17.6.2008,  12:19 Найти цитируемый пост)
имел в виду ситуацию, когда подстрока в строке отсутствует 

исключительными не являются, соответственно можно например вернуть -1 smile 


--------------------
user posted image

Real men don't use backups, they post their stuff on a public ftp server and let the rest of the world make copies
- Linus Torvalds
PM MAIL   Вверх
neutrino
Дата 19.6.2008, 09:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Gothic soul
****


Профиль
Группа: Модератор
Сообщений: 3041
Регистрация: 25.3.2002
Где: Верхняя Галилея, Кармиэль

Репутация: нет
Всего: 62



Цитата(mr.DUDA @  18.6.2008,  19:41 Найти цитируемый пост)
Исключения нельзя использовать в real-time приложениях - слишком большие накладные расходы, по крайней мере в .NET

С этим согласен. Но и с этим:

Цитата(mr.DUDA @  18.6.2008,  19:41 Найти цитируемый пост)
Но коды ошибок есть зло. 

тоже  smile 


--------------------
The truth comes from within ...

Покойся с миром, Vit 
PM MAIL WWW ICQ Skype GTalk   Вверх
LSD
Дата 19.6.2008, 12:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 9
Всего: 538



Тут есть тонкость, есть коды ошибок, а есть коды возврата. И это две большие разницы smile


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
neutrino
Дата 19.6.2008, 13:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Gothic soul
****


Профиль
Группа: Модератор
Сообщений: 3041
Регистрация: 25.3.2002
Где: Верхняя Галилея, Кармиэль

Репутация: нет
Всего: 62



Цитата(LSD @  19.6.2008,  11:10 Найти цитируемый пост)
Тут есть тонкость, есть коды ошибок, а есть коды возврата. И это две большие разницы

Гы smile Какая разница? Вон -1, если нет подстроки - это что?


--------------------
The truth comes from within ...

Покойся с миром, Vit 
PM MAIL WWW ICQ Skype GTalk   Вверх
JackYF
Дата 19.6.2008, 14:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


полуавантюрист
****


Профиль
Группа: Участник
Сообщений: 5814
Регистрация: 28.8.2004
Где: страна тысячи озё р

Репутация: 2
Всего: 162



Цитата(neutrino @  19.6.2008,  12:18 Найти цитируемый пост)
это что? 

индекс  smile 

По сабжу - больше люблю исключения. Но юзать приходится больше коды возврата - код на С ещё никто не отменял.


--------------------
Пожаловаться на меня как модератора можно здесь.
PM MAIL Jabber   Вверх
neutrino
Дата 19.6.2008, 15:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Gothic soul
****


Профиль
Группа: Модератор
Сообщений: 3041
Регистрация: 25.3.2002
Где: Верхняя Галилея, Кармиэль

Репутация: нет
Всего: 62



Мдя. Вопрос надо было перефразировать. Это касается только .NET/Java


--------------------
The truth comes from within ...

Покойся с миром, Vit 
PM MAIL WWW ICQ Skype GTalk   Вверх
LSD
Дата 19.6.2008, 17:18 (ссылка) |    (голосов:7) Загрузка ... Загрузка ... Быстрая цитата Цитата


Leprechaun Software Developer
****


Профиль
Группа: Модератор
Сообщений: 15718
Регистрация: 24.3.2004
Где: Dublin

Репутация: 9
Всего: 538



Цитата(neutrino @  19.6.2008,  14:18 Найти цитируемый пост)
Какая разница? Вон -1, если нет подстроки - это что?

Сам спросил, счас будет многа букф smile

Есть функция которая что-то делает и возвращает некий результат. При корректных: параметрах, внутреннем состоянии и внешних условиях, она возвращает некий результат работы, если какие-то условия не выполняются то надо об этом сообщить вызывающему. Вот тут и возникают вопросы:

1. Можно вообще вернуть такое значение которое бы сигнализировало об ошибке? 
Например 1 / 0 - среди целых нет такого значения которое могло бы сигнализировать о том, что произошло деление на ноль, потому тут будет ексепшн. А вот для 1.0 / 0.0 такое значение есть, и тут будет positive infinity.
Ну и конечно конструкторы из которых вообще ничего нельзя вернуть. Или прокси объекты которые осущесвляют ленивую закгрузку/инициализацию и т.п.

2. По логике работы функции: насколько эта ситуация является "черезвычайной"?
По идее при нормальной работе приложения эксепшенов должно быть минимум, только по внешним поводам котрые нельзя контролировать. Т.е. если проверили входные параметры на валидность, убедились что система в "правильном состоянии", эксепшены должны быть только если что-то не так с внешними условиями.
Тот же поиск строки в подстроке: там есть перегруженных метод который позволяет искать начиная с определенной позиции. Если строка не найдена -1 ибо проверить есть ли такая подстрока можно только самому реализовав подобный метод. А вот если индекс выходит за границы строки будет эксепшн, потому что программист может и должен следить за тем, чтобы он не выходил за границы.
Другой пример чтение из потока. Когда поток заканчивается, мы получаем -1, потому что мы совершенно точно знаем, что поток рано или поздно должен закончится. А вот когда происходят внешние проблемы (разорвалось соединение, проблемы с диском) мы получаем эксепшн ибо ситуация непредвиденная и по хорошему ее быть не должно.

Т.е. код возврата это одно из возвращаемых значение, это не ошибка в работе функции, это ее результат. А сама функция отработала корректно. Просто некоторые из значений для вызывающего кода могут обозначать ошибку (а могут и нет).


--------------------
Disclaimer: this post contains explicit depictions of personal opinion. So, if it sounds sarcastic, don't take it seriously. If it sounds dangerous, do not try this at home or at all. And if it offends you, just don't read it.
PM MAIL WWW   Вверх
mr.DUDA
Дата 23.6.2008, 19:14 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


3D-маньяк
****


Профиль
Группа: Экс. модератор
Сообщений: 8244
Регистрация: 27.7.2003
Где: город-герой Минск

Репутация: 4
Всего: 232



Плохой пример кодов возврата - COM с его HRESULT. Хороший пример - возврат функцией true/false для успеха или неудачи. ИМХО.


--------------------
user posted image
PM MAIL WWW   Вверх
Mephisto
Дата 23.6.2008, 22:34 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Волкъ
***


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

Репутация: 1
Всего: 34



Я юзаю в основном только исключения. Ибо наглядно, удобно, очевидно... Если приложение многопоточное, то отдебагить методы в которые заходят несколько потоков практически невозможно, если не использовать исключения. 
Разумно их использовать если код будет внутри либы, тогда возможен только вариант с кодами ошибок.

Цитата(chipset @  17.6.2008,  01:21 Найти цитируемый пост)
А если пишешь DLL которая будет юзаться, к примеру дельфой или джавой? 

Дельфина, между прочим, асилит показать внутреннее исключение либы. Используя апи висты, я несколько раз отлавливал внутривистовое исключение операционки. Дельфина под дебагом останавливается, но стек не раскручивается после продолжения.
PM   Вверх
neutrino
Дата 19.7.2009, 14:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Gothic soul
****


Профиль
Группа: Модератор
Сообщений: 3041
Регистрация: 25.3.2002
Где: Верхняя Галилея, Кармиэль

Репутация: нет
Всего: 62



Приветствую!

Собственно, понятное дело, что если подстрока не нашлась в строке надыть вернуть код ошибки. Но вот с этим: 
Цитата(mr.DUDA @  23.6.2008,  18:14 Найти цитируемый пост)
Хороший пример - возврат функцией true/false для успеха или неудачи. ИМХО. 

Несогласен. Если функция не выкинула эксепшн - то все чин чинарем. Иначе код, который вызывает несколько таких функций будет не очень читабелен.


--------------------
The truth comes from within ...

Покойся с миром, Vit 
PM MAIL WWW ICQ Skype GTalk   Вверх
morfus
Дата 28.8.2009, 18:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 71
Регистрация: 30.6.2007

Репутация: нет
Всего: 2



Я вообще в последнее время склоняюсь что надо брать пример с перла... (для web примерно так - нет ошибки всё хорошо, есть ошибка тупо выдавать 500 или 404 и не париться)

Т.е тупо "программа выполнила фигню и будет закрыта"

Это сообщение отредактировал(а) morfus - 28.8.2009, 18:56
PM MAIL WWW   Вверх
bilbobagginz
Дата 28.8.2009, 21:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Naughtius Maximus
****


Профиль
Группа: Экс. модератор
Сообщений: 8813
Регистрация: 2.3.2004
Где: Israel

Репутация: 6
Всего: 317



в принципе в unix есть переменная errno.
т.е. функция может вернуть какой-то код, и записать что-то в добавок в errno.
получится что-то вроде exception, но вложения перепишут errno, и фиг поймёшь что произошло точно.

Lazin
я рассуждаю проще:
язык C позволяет только коды ошибок. там - только коды ошибок.
C++,Java и т.д. позволяют коды ошибок и exceptions, которые явно более наглядны, и позволяют больше. поэтому в чисто c++/java, etc. пользуемся exception-ами,
за исключением работы с внешними модулями:
напр. приложение на C++ юзает либу на C, и т.п.

neutrino, читани, полезный материал

smile


--------------------
Я ещё не демон. Я только учусь.
PM WWW   Вверх
Alexeis
Дата 28.8.2009, 22:27 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Амеба
Group Icon


Профиль
Группа: Админ
Сообщений: 11743
Регистрация: 12.10.2005
Где: Зеленоград

Репутация: 14
Всего: 459



Цитата(bilbobagginz @  28.8.2009,  20:06 Найти цитируемый пост)
язык C позволяет только коды ошибок. там - только коды ошибок.

  Ну возможности языка С не ограничиваются CRT, под винду есть SEH, так что можно работать и с исключениями. Наверняка в других оськах есть свои нативные механизмы.


--------------------
Vit вечная память.

Обсуждение действий администрации форума производятся только в этом форуме

гениальность идеи состоит в том, что ее невозможно придумать
PM ICQ Skype   Вверх
bilbobagginz
Дата 5.9.2009, 13:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Naughtius Maximus
****


Профиль
Группа: Экс. модератор
Сообщений: 8813
Регистрация: 2.3.2004
Где: Israel

Репутация: 6
Всего: 317



Цитата(Alexeis @  28.8.2009,  21:27 Найти цитируемый пост)
 Ну возможности языка С не ограничиваются CRT, под винду есть SEH, так что можно работать и с исключениями. Наверняка в других оськах есть свои нативные механизмы. 

извратов - хватает.
http://www.nicemice.net/cexcept/



--------------------
Я ещё не демон. Я только учусь.
PM WWW   Вверх
Страницы: (3) [Все] 1 2 3 
Ответ в темуСоздание новой темы Создание опроса
Правила ведения Религиозных войн
Smartov
1. Уважайте собеседника
2. Собеседник != враг
3. Старайтесь воздерживаться от тем вида "Windows Rulez" или "Linux Rulez"

С уважением, Smartov.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Религиозные войны | Следующая тема »


 




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


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

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