Как отключить диалоговое окно «Отладка / закрыть приложение» в Windows Vista?


86

Когда приложение выходит из строя в Windows и установлен отладчик, например Visual Studio, появляется следующий модальный диалог:

[Название: Microsoft Windows]

X перестал работать

Проблема привела к тому, что программа перестала правильно работать. Windows закроет программу и сообщит вам, если решение доступно.

[Отладка] [Закрыть приложение]

Есть ли способ отключить этот диалог? То есть программа просто вылетает и тихо горит?

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

Обыскивая вокруг, я думаю, что нашел решение для отключения этого в Windows XP, которое запускает этот ключ реестра:

HKLM \ Software \ Microsoft \ Windows NT \ CurrentVersion \ AeDebug \ Debugger

Однако в Windows Vista это не сработало.


Использование ключа AeDebug \ Debugger не имело для меня никакого эффекта под Windows XP ни на консольные приложения, скомпилированные с отладочными, ни на неотладочные библиотеки.
rptb1

Ответы:


56

Чтобы система отчетов об ошибках Windows (WER) создавала аварийный дамп и закрывала приложение, вместо того, чтобы предлагать вам отладить программу, вы можете установить следующие записи реестра:

Windows Registry Editor Version 5.00

[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\Windows Error Reporting]
"ForceQueue"=dword:00000001

[HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\Windows Error Reporting\Consent]
"DefaultConsent"=dword:00000001

После того, как это установлено, при сбое ваших приложений вы должны увидеть файлы * .hdmp и * .mdmp в:

%ALLUSERSPROFILE%\Microsoft\Windows\WER\

3
DefaultConsent = 1 кажется значением по умолчанию. А как насчет DontShowUI?
Zitrax

Документация ForceQueue расплывчата, я не совсем понимаю, что она означает.
Zitrax

2
@NicJ, пожалуйста, добавьте DontShowUI = 1 к своему ответу, это важный
ответ

1
Я полагаю, также может быть установлен в HKEY_CURRENT_USER
PJTraill

2
Редактирование реестра Windows - это путь в ЭТО-ад, лучше подумайте об ответе от armenzg
lowtech

45

Глянь сюда:

http://msdn.microsoft.com/en-us/library/bb513638.aspx

regedit

DWORD HKLM или HKCU \ Software \ Microsoft \ Windows \ Windows Error Reporting \ DontShowUI = "1"

сделает отчет WER молча. Затем вы можете установить

DWORD HKLM или HKCU \ Software \ Microsoft \ Windows \ Windows Error Reporting \ Disabled = "1"

чтобы он не разговаривал с MS.


У меня работал над исправлением проблемы с агентом сборки VSTS, когда я пытался запускать тесты Selenium. Благодарность!
Stu1986C 05

36

Я не уверен, относится ли это к точно такому же диалогу, но вот альтернативный подход от Раймонда Чена :

DWORD dwMode = SetErrorMode(SEM_NOGPFAULTERRORBOX);
SetErrorMode(dwMode | SEM_NOGPFAULTERRORBOX);

Да, такой вызов SetErrorMode предотвращает диалог WER, упомянутый OP.
Роман Старков

2
Проблема с SetErrorMode и флагом SEM_NOGPFAULTERRORBOX заключается в том, что он не создает файл дампа и не делает запись в журнале событий Windows. Ваша программа просто бесследно исчезнет при сбое. По этой причине я считаю, что реестр лучше.
Дерек

Это работает также для устаревших фреймворков (начиная с WinXP).
Wolf

1
Согласились, что это нехорошо для отправки. Однако действительно полезно разблокировать нестабильные задачи автоматизации.
kayleeFrye_onDeck 06

31

Мне пришлось отключить это для работы по автоматизации выпуска в 64-битной Windows для Firefox, и я сделал следующее:

  • gpedit.msc
  • Конфигурация компьютера -> Административные шаблоны
  • Компоненты Windows -> Отчеты об ошибках Windows
  • Установите для параметра «Предотвращать отображение пользовательского интерфейса для критических ошибок» значение Включено.

Это похоже на то, что было сделано для отчета об опыте работы с клиентами в: http://www.blogsdna.com/2137/fix-windows-installer-explorer-update-has-stopped-working-in-windows-7.htm


13

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

#include <windows.h>
#include <rtcapi.h>
int exception_handler(LPEXCEPTION_POINTERS p)
{
    printf("Exception detected during the unit tests!\n");
    exit(1);
}
int runtime_check_handler(int errorType, const char *filename, int linenumber, const char *moduleName, const char *format, ...)
{
    printf("Error type %d at %s line %d in %s", errorType, filename, linenumber, moduleName);
    exit(1);
}

int main()
{
    DWORD dwMode = SetErrorMode(SEM_NOGPFAULTERRORBOX);
    SetErrorMode(dwMode | SEM_NOGPFAULTERRORBOX);
    SetUnhandledExceptionFilter((LPTOP_LEVEL_EXCEPTION_FILTER)&exception_handler); 
    _RTC_SetErrorFunc(&runtime_check_handler);

    // Run your tests here

    return 0;
}

8

В приложении WPF

[DllImport("kernel32.dll", SetLastError = true)]
static extern int SetErrorMode(int wMode);

[DllImport("kernel32.dll")]
static extern FilterDelegate SetUnhandledExceptionFilter(FilterDelegate lpTopLevelExceptionFilter);
public delegate bool FilterDelegate(Exception ex);

public static void DisableChashReport()
{
 FilterDelegate fd = delegate(Exception ex)
 {
  return true;
 };
 SetUnhandledExceptionFilter(fd);
 SetErrorMode(SetErrorMode(0) | 0x0002 );
}

Не похоже, что там есть что-то специфическое для WPF, и, похоже, оно отлично работает и в моем консольном приложении (.NET 4.6.2 в Windows 10)
mookid8000

4

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

Если вы используете безопасный CRT, вам также необходимо предоставить свой собственный обработчик недопустимых параметров и установить его с помощью _set_invalid_parameter_handler ().

В этом сообщении в блоге также есть информация: http://blog.kalmbachnet.de/?postid=75


4

Во время теста вы можете запустить «отладчик», например ADPlus, который можно настроить многими полезными способами для сбора данных (минидампов) об ошибках и, тем не менее, для предотвращения проблем с модальным диалоговым окном, которые вы указали выше.

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


4

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

Я использовал переносной autohotkey и создал макрос, который раз в минуту проверяет, существует ли всплывающее окно, и, если да, нажимает кнопку, чтобы закрыть программу. В моем случае этого достаточно, и я оставляю эту функцию включенной для других пользователей. Это требует, чтобы я запускал сценарий при запуске программы, подверженной риску, но он работает для моих нужд.

Сценарий выглядит следующим образом:

sleep_duration = 60000 ; how often to check, in milliseconds.
                       ; 60000 is a full minute

Loop
{
    IfWinExist, ahk_class #32770 ; use autohotkey's window spy to confirm that
                ; ahk_class #32770 is it for you. This seemed to be consistent
                ; across all errors like this on Windows Server 2008
    {
        ControlClick, Button2, ahk_class #32770 ; sends the click.
                ; Button2 is the control name and then the following
                ; is that window name again
    }
    Sleep, sleep_duration ; wait for the time set above
}

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


3

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

Перейдите в панель управления. Перейдите в раздел "Администрирование". Перейдите к службам. Посмотрите список Machine Debug Manager. Щелкните правой кнопкой мыши по нему и выберите "Свойства". На вкладке "Общие" найдите "Тип запуска". Нажмите "Отключить". Нажмите Применить и ОК.

С тех пор я не видел сообщения отладчика, и мой компьютер работает отлично.


Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.