Отправляет email-рассылки с помощью сервиса Sendsay

RFpro.ru: Microsoft .NET

  Все выпуски  

RusFAQ.ru: .NET


Хостинг Портала RusFAQ.ru:
MosHoster.ru - Профессиональный хостинг на Windows 2008

РАССЫЛКИ ПОРТАЛА RUSFAQ.RU

Чемпионы рейтинга экспертов в этой рассылке

Micren
Статус: Практикант
Рейтинг: 107
∙ повысить рейтинг >>
Evgenijm
Статус: 4-й класс
Рейтинг: 37
∙ повысить рейтинг >>
DrakoN
Статус: Практикант
Рейтинг: 25
∙ повысить рейтинг >>

/ КОМПЬЮТЕРЫ И ПО / Языки программирования / .NET

Выпуск № 128
от 14.04.2009, 14:05

Администратор:Grigory
В рассылке:Подписчиков: 253, Экспертов: 10
В номере:Вопросов: 1, Ответов: 2

Нам важно Ваше мнение об этой рассылке.
Оценить этот выпуск рассылки >>

Вопрос № 164510: А как вообще словить переполнение стека в C#? Простой try его в помине не берет......


Вопрос № 164.510
А как вообще словить переполнение стека в C#? Простой try его в помине не берет...
Отправлен: 09.04.2009, 12:10
Вопрос задал: Immortal (статус: Посетитель)
Всего ответов: 2
Мини-форум вопроса >>> (сообщений: 3)

Отвечает: Челноков Виктор Альбертович
Здравствуйте, Immortal!
Вот что советует MSDN
Вопросы, связанные с версиями
В предыдущей версии платформы .NET Framework приложение могло перехватывать объект StackOverflowException (например, для выхода из состояния неограниченной рекурсии). Однако в данный момент такой подход не одобряется, поскольку для надежного перехвата исключения переполнения стека и продолжения выполнения программы необходимо значительное количество дополнительного кода.

Начиная с платформы .NET Framework версии 2.0 объект StackOverflowException нельзя перехватывать с помощью блока try-catch и соответствующий процесс по умолчанию завершается. Поэтому пользователям рекомендуется писать код, который будет обнаруживать и предотвращать переполнение стека. Например, если приложение зависит от рекурсии, для завершения рекурсивного цикла следует использовать счетчик или условие состояния. Обратите внимание, что в приложении, в котором расположена среда CLR, можно настроить выгрузку этой сред ой домена приложения, в котором произошло исключение переполнения стека, разрешив продолжение выполнения соответствующего процесса. Дополнительные сведения см. в разделах Интерфейс ICLRPolicyManager и Размещение среды CLR.

Примечание для платформы Windows 95, Windows 98, Windows 98, второе издание, Windows Millennium Edition:

Исключение StackOverflowException нельзя перехватывать с помощью блока try-catch. Поэтому исключение приводит к немедленному завершению процесса.

Ответ отправил: Челноков Виктор Альбертович (статус: Студент)
Ответ отправлен: 09.04.2009, 12:33

Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 247143 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!

    Оценка за ответ: 4


    Отвечает: Evgenijm
    Здравствуйте, Immortal!
    К сожалению, ни в МСДН, ни в интернете я так и не смог найти удовлетворительную информацию. Похоже, со стеком действительно приходится действовать вслепую. Можно лишь примерно представить себе поведение программы профилированием. Хотя, сегмент стека - штука не константная, так что есть другие инструменты его менять. В C++, вроде, можно устроить автоматическое удлинение стека.
    Я так понимаю, Ваша программа в данный момент периодически вылетает?
    Вообще, проблема упора в границу стека обычно указывает на неправильный дизайн программы. Столь длинные цепочки вызовов функций очень необычны. Зачастую используется хвостовая рекурсия, которую легко можно заменить на цикл. Думаю, что Вам следует дать свой код и перефразировать вопрос так: "Что мне сделать, чтобы избавиться от рекурсии?"
    Если потребности в стеке всеже ограничены, Вы можете использовать шаблон 2, который я привел ниже.
    Если раскомментировать вызов на главном потоке - про грамма под ХР вылетит между 12000 и 13000. Под Вистой должно быть еще меньше: там стандартный стек вроде 256К, а не 1М.
    Второй вариант выполняет код на стеке нужного размера. Основной поток ждет его выполнения - псевдолинейный код.
    Если код нельзя избавить от рекурсии, можно использовать старую добрую эмуляцию: цикл и контейнер-стек для хранения данных. Такая конструкция часто работает даже быстрее, но код будет уже менее наглядным. Для сложных рекурсий может понадобиться несколько специализированных стеков и вложенные циклы. Третий вариант показывает это. Скорость значительно выше и программа меньше нагружает систему. На Атоме это очень хорошо заметно. Стек можно заменить на кластерный односвязный список - дольше продержится.
    Более четко можно ответить только имея Ваш код. Наверняка, его нужно просто переписать.

    Приложение:

    Ответ отправил: Evgenijm (статус: 4-й класс)
    Ответ отправлен: 11.04.2009, 19:33

    Как сказать этому эксперту "спасибо"?
  • Отправить SMS #thank 247283 на номер 1151 (Россия) | Еще номера >>
  • Отправить WebMoney:
  • Вам помогли? Пожалуйста, поблагодарите эксперта за это!


    Вы имеете возможность оценить этот выпуск рассылки.
    Нам очень важно Ваше мнение!
    Оценить этот выпуск рассылки >>

    Отправить вопрос экспертам этой рассылки

    Приложение (если необходимо):

    * Код программы, выдержки из закона и т.п. дополнение к вопросу.
    Эта информация будет отображена в аналогичном окне как есть.

    Обратите внимание!
    Вопрос будет отправлен всем экспертам данной рассылки!

    Для того, чтобы отправить вопрос выбранным экспертам этой рассылки или
    экспертам другой рассылки портала RusFAQ.ru, зайдите непосредственно на RusFAQ.ru.


    Форма НЕ работает в почтовых программах The BAT! и MS Outlook (кроме версии 2003+)!
    Чтобы отправить вопрос, откройте это письмо в браузере или зайдите на сайт RusFAQ.ru.

    Скажите "спасибо" эксперту, который помог Вам!

    Отправьте СМС-сообщение с тестом #thank НОМЕР_ОТВЕТА
    на короткий номер 1151 (Россия)

    Номер ответа и конкретный текст СМС указан внизу каждого ответа.

    Полный список номеров >>

    * Стоимость одного СМС-сообщения от 7.15 руб. и зависит от оператора сотовой связи. (полный список тарифов)
    ** При ошибочном вводе номера ответа или текста #thank услуга считается оказанной, денежные средства не возвращаются.
    *** Сумма выплаты эксперту-автору ответа расчитывается из суммы перечислений на портал от биллинговой компании.


    © 2001-2009, Портал RusFAQ.ru, Россия, Москва.
    Авторское право: ООО "Мастер-Эксперт Про"
    Техподдержка портала, тел.: +7 (926) 535-23-31
    Хостинг: "Московский хостер"
    Поддержка: "Московский дизайнер"
    Авторские права | Реклама на портале

    ∙ Версия системы: 5.13 от 01.12.2008

    Яндекс Rambler's Top100
    RusFAQ.ru | MosHoster.ru | MosDesigner.ru
    RusIRC.ru | Kalashnikoff.ru | RadioLeader.ru

    В избранное