Debug JIT in Visual Studio
Il debug JIT avvia Visual Studio automaticamente quando si verifica un'eccezione o un arresto anomalo in un'applicazione in esecuzione all'esterno di Visual Studio. In questo modo è possibile testare l'applicazione quando Visual Studio non è in esecuzione e avviare il debug con Visual Studio quando si verifica un problema.
Il debug JIT non è supportato dalle app Windows Store. Il debug JIT non può essere utilizzato con codice gestito ospitato in un'applicazione nativa, ad esempio visualizzatori.
Utilizzo del debug JIT
Quando si installa Visual Studio, il debug JIT è abilitato per impostazione predefinita. Se è necessario disabilitare o riabilitare il debug JIT, vedere Restrict stepping to Just My Code.
Quando il debug JIT è abilitato, è possibile testare l'applicazione all'esterno di Visual Studio. Quando si verifica un arresto anomalo o un'eccezione, verrà visualizzata una finestra di dialogo con un messaggio simile al seguente:
Eccezione non gestita ('System.TypeInitializationException') in terrarium.exe[3384]
Quando viene visualizzata questa finestra di dialogo, è possibile avviare il debug con la procedura seguente.
Per avviare il debug JIT quando si verifica un errore
Nell'elenco Debugger disponibili della finestra di dialogo Debug JIT fare clic su Nuova istanza di Visual Studio 2013 oppure fare clic su un'istanza di Visual Studio in esecuzione.
Per utilizzare automaticamente Visual Studio per tutti gli arresti anomali futuri, fare clic su Imposta il debugger selezionato come predefinito.
Se si desidera scegliere i tipi di codice di cui eseguire il debug, selezionare la casella di controllo Scegli manualmente i moduli di gestione di debug. Se non si seleziona questa opzione, verranno automaticamente selezionati i motori di debug appropriati per il tipo di codice nel programma.
Fare clic su OK.
Se l'applicazione contiene un assembly con codice non attendibile, viene visualizzata una finestra di dialogo contenente un avviso di sicurezza. Questa finestra di dialogo consente di decidere se procedere o meno con il debug. Prima di continuare con il debug, decidere se ritenere attendibile o meno il codice. Se il codice è stato scritto da altri, decidere se ritenere attendibile o meno l'autore. Se l'applicazione è in esecuzione in un computer remoto, assicurarsi di riconoscere il nome del processo. Anche se l'applicazione è in esecuzione in un computer locale, non significa che possa essere ritenuta attendibile. È infatti possibile che in Internet Explorer sia in esecuzione un controllo ActiveX dannoso. Considerare la possibilità che tale codice dannoso sia in esecuzione nel proprio computer. Se si stabilisce che il codice di cui si intende eseguire il debug è attendibile, fare clic su Debug. In caso contrario, fare clic su Non eseguire il debug.
Abilitazione o disabilitazione del debug Just-In-Time
È possibile abilitare o disabilitare il debug JIT dalla finestra di dialogo Opzioni.
Per abilitare o disabilitare il debug JIT
Scegliere Opzioni dal menu Strumenti.
Nella finestra di dialogo Opzioni selezionare la cartella Debug.
Nella cartella Debug scegliere la pagina JIT.
Nella casella Attiva debug JIT per questi tipi di codice selezionare o deselezionare i tipi di programma relativi: Gestito, Nativo o Script.
Per disabilitare il debug JIT, è necessario disporre dei privilegi di amministratore. L'attivazione del debug JIT richiede la modifica di una chiave del Registro di sistema e per eseguire tale operazione sono necessari i privilegi di amministratore.
Fare clic su OK.
Per impostazione predefinita, le applicazioni Windows Form dispongono di un gestore eccezioni di livello superiore che consente al programma di proseguire l'esecuzione quando è possibile un ripristino. Di conseguenza, è necessario effettuare i passaggi aggiuntivi seguenti per abilitare il debug JIT di un'applicazione Windows Form.
Per attivare il debug JIT di Windows Form
Impostare il valore jitDebugging su true nella sezione system.windows.form del file machine.config o del file application.exe.config:
<configuration> <system.windows.forms jitDebugging="true" /> </configuration>
In un'applicazione Windows Form C++ è anche necessario impostare DebuggableAttribute in un file con estensione config o nel codice. Se si esegue la compilazione con /Zi e senza /Og, il compilatore imposta automaticamente questo attributo. Se si desidera eseguire il debug di una build di rilascio non ottimizzata, tuttavia, è necessario procedere alla configurazione. A tale scopo, è possibile aggiungere la riga seguente al file AssemblyInfo.cpp dell'applicazione:
[assembly:System::Diagnostics::DebuggableAttribute(true, true)];
Per altre informazioni, vedere DebuggableAttribute.
Il debug JIT può comunque essere abilitato anche se Visual Studio non è più presente nel computer. Se Visual Studio non è installato, non è possibile disabilitare il debug JIT dalla finestra di dialogo Opzioni di Visual Studio. In questo caso, è possibile disabilitare il debug JIT modificando il Registro di sistema di Windows.
Per disabilitare il debug JIT modificando il Registro di sistema
Nel menu Start cercare ed eseguire regedit.exe
Nella finestra dell'Editor del Registro di sistema individuare ed eliminare le chiavi del Registro di sistema seguenti:
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\AeDebug\Debugger
HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\.NETFramework\DbgManagedDebugger
Se nel computer è in esecuzione un sistema operativo a 64 bit, eliminare anche le chiavi del Registro di sistema seguenti:
HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\Windows NT\CurrentVersion\AeDebug\Debugger
HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Microsoft\.NETFramework\DbgManagedDebugger
Fare attenzione a non eliminare o modificare altre chiavi del Registro di sistema.
Chiudere la finestra dell'Editor del Registro di sistema.
Errori del debug JIT
I messaggi di errore elencati di seguito sono associati al debug JIT.
Impossibile connettersi al processo bloccato. Il programma specificato non è un programma Windows o MS-DOS.
Questo errore si verifica quando si tenta di connettersi a un processo in esecuzione come un altro utente in Windows 2000.
Per risolvere il problema, avviare Visual Studio, aprire la finestra di dialogo Connetti a processo dal menu Debug e trovare il processo di cui si desidera eseguire il debug nell'elenco Processi disponibili. Se non si conosce il nome del processo, osservare la finestra di dialogo Debugger JIT di Visual Studio e prendere nota dell'ID del processo. Selezionare tale processo nell'elenco Processi disponibili e fare clic su Connetti. Nella finestra di dialogo Debugger JIT di Visual Studio scegliere No per chiudere la finestra di dialogo.
Impossibile avviare il debugger perché nessun utente è connesso.
Questo errore si verifica quando il debug JIT tenta di avviare Visual Studio in un computer in cui nessun utente è connesso alla console. Poiché nessun utente è connesso, non esiste una sessione utente nella quale visualizzare la finestra di dialogo del debug JIT.
Per correggere questo problema, connettersi al computer.
Classe non registrata.
Questo errore indica che il debugger ha tentato di creare una classe COM non registrata, probabilmente a causa di un problema di installazione.
Per risolvere questo problema, utilizzare il disco di installazione per reinstallare o riparare l'installazione di Visual Studio.
Vedere anche
Riferimenti
JIT, Debug, Finestra di dialogo Opzioni