Aggiornamenti per il debug di Visual Studio 2008 SP1 e i punti di interruzione

Traduzione articoli Traduzione articoli
Identificativo articolo: 957912 - Visualizza i prodotti a cui si riferisce l?articolo.
Espandi tutto | Chiudi tutto

In questa pagina

INTRODUZIONE

Microsoft ha rilasciato gli aggiornamenti per i componenti del debugger Microsoft Visual Studio 2008 SP1. Questi aggiornamenti risolvono principalmente problemi che si verificano con un'istruzione alla volta e raggiungere i punti di interruzione.

Informazioni

Installazione

Questo aggiornamento Ŕ per tutte le versioni di Visual Studio 2008 SP1 nei computer x 86 e x 64. Tuttavia, se si utilizza Visual Studio 2008 Standard Edition in un sistema operativo a 64-bit, Ŕ necessario installare il 64-bit Visual Studio 2008 SP1 Remote Debugger prima di applicare questo aggiornamento. Per informazioni su come ottenere il 64-bit Visual Studio 2008 SP1 Remote Debugger, visitare il seguente sito:
http://www.microsoft.com/downloads/details.aspx?FamilyID=440ec902-3260-4cdc-b11a-6a9070a2aaab&DisplayLang=en

Correzioni di debugger Multi-Process e multithread

Nota Le descrizioni riportato di seguito fanno riferimento a un ipotetico insieme di processi in fase di debug da un'unica istanza di Visual Studio. Quando vengono definite funzioni, si presuppone che le funzioni sono ricorsiva o che le funzioni contengono cicli. Questi scenari non sono destinati a riprodurre il problema. Vengono invece forniti per illustrare il problema.

Punti di interruzione nei cicli parallelizzati infine vengono ignorati dopo pi¨ accessi

I punti di interruzione inserire nei cicli o in ricorsiva raggiunto non funzioni in tutti i processi a ogni iterazione. Spesso, alcuni processi possono passare tramite un numero di iterazioni di un ciclo, ignorando il punto di interruzione prima che un processo venga interrotto. Si consideri lo scenario seguente:
  1. ╚ possibile avviare il debug di pi¨ processi. Uno dei processi che si siano eseguendo il debug in un ciclo ridotto o Ŕ una funzione ricorsiva.
  2. Si interrompe il thread principale del processo corrente (ultimo processo per il punto di interruzione) e procedere eseguire il debug. Ripetere questa azione per ogni processo.
  3. ╚ riavviare il thread per ogni processo.
╚ possibile notare che dopo diverse iterazioni, i punti di interruzione sono non raggiunto. Questo comportamento Ŕ imprevisto.

Interruzione e avvio thread causa punti di interruzione non essere rilevati

I punti di interruzione sono raggiunto, ma non visibili durante il debug di pi¨ processi nel debugger di Visual Studio. Si consideri il seguente scenario in cui si esegue il debug due processi, processo A e b di processo.
  1. ╚ possibile impostare un punto di interruzione su entrambi i processi e avviare il debug. Entrambi i punti di interruzione verrÓ raggiunto.
  2. Si interrompe il thread principale di un processo, selezionare il processo B e premere F11 per passaggio nel comando una sola volta.
  3. Si riavvia il thread principale di un processo, e quindi si arresta il thread principale di processo. Quindi, Ŕ possibile premere F11 per passaggio nel comando.

    ╚ possibile notare che entrambi i processi siano al medesimo.
  4. Si interrompe il thread principale di a processo. Nessun thread deve essere arrestato a questo punto.
  5. Premere F5 per continuare.
Dovrebbe terminare il processo, e Visual Studio deve restituire alla modalitÓ progettazione. Tuttavia, questo non si verifica. I processi di interrompere l'esecuzione in un secondo momento nel codice.

Nota Se si rimuovono i punti di interruzione dopo avere premuto F5 per continuare, il debugger esegue fino al completamento.

In Visual Studio potrebbe bloccarsi quando si esegue il debug pi¨ processi nello stesso momento

Debugger di Visual Studio, potrebbe verificarsi un deadlock avviare e interrompe un thread ed eseguire al successivo punto di interruzione se pi¨ processi sono corso il debug. Si consideri lo scenario seguente:
  1. ╚ possibile impostare i punti di interruzione su tre dichiarazioni di variabile non autorizzate.
  2. ╚ possibile avviare il debug di processi di 16.
  3. Si interrompe il a uno dei processi e quindi si arresta il thread principale.
  4. Si preme F5.
  5. Ripetere i passaggi 3 e 4 tutti i processi Ŕ sono raggiunto il punto di interruzione.
  6. Si avvia il thread principale di tutti i processi.
  7. Per ogni processo, si elimina il primo punto di interruzione e premere F5.
  8. Per ogni processo ripetere i passaggi da 3 e 4. Tutti i processi devono essere il secondo punto di interruzione.
  9. Si preme F5.
  10. Per ogni processo ripetere i passaggi da 3 e 4.
Tutti i processi dovrebbero raggiungere il terzo punto di interruzione, ma almeno un processo pu˛ sembra bloccato in stato di esecuzione.

L'esecuzione su un punto di interruzione disattivato, quando si esegue il debug un'applicazione nativa assume la forma "Vai"

SarÓ il debug un nativo dell'applicazione in Visual Studio contenente un punto di interruzione disattivato. Quando passaggio il debugger oltre il punto di interruzione disattivato, gli altri passaggi vengono persi e l'applicazione rimane in esecuzione.

Un'istruzione alla volta quando si esegue un'applicazione con multithreading gestita il debug possibile trasformare in modo casuale in "go"

Durante il debug un'applicazione gestita con multithreading e si Ŕ perso passaggio in un thread mentre si verifica un evento con un altro thread, such as raggiungere un punto di interruzione, la richiesta di passaggio. E, l'applicazione rimane in esecuzione.

Messaggio MPI (Passing Interface) debugger correzioni per Visual Studio Edition offre il supporto di MPI-plug-in

In Visual Studio si blocca quando si utilizza il comando "Esegui istruzione" per avviare un programma MPI

Quando si utilizza il comando Esegui istruzione o premere F11 per eseguire pi¨ istanze di un processo MPI, il debug di Visual Studio si blocca. In alternativa, Ŕ visualizzato il seguente messaggio di errore:
Microsoft che Visual Studio si Ŕ verificato e di errore interno

Se si esegue il comando "Esegui istruzione / routine" durante il debug di pi¨ processi, un blocco critico (deadlock)

Se si esegue il comando Esegui istruzione durante il debug di pi¨ processi, Visual Studio si blocca. Si consideri lo scenario seguente:
  1. ╚ aprire un'applicazione con multithreading.
  2. ╚ possibile impostare un punto di interruzione su una chiamata di funzione ricorsiva.
  3. Eseguire il debug due processi.
  4. Si avvia il debug. Viene raggiunto il punto di interruzione nel processo di primo.
  5. Si preme F5. Viene raggiunto il punto di interruzione sul processo di secondo.
  6. ╚ interrompere il thread principale del primo processo.
  7. Esecuzione del comando Esegui istruzione / routine del secondo processo e scegliere Sospendi .

    Impossibile completare l'operazione perchÚ Ŕ in attesa per il primo processo. Fare clic su Pausa per riattivare la modalitÓ di interruzione. Il debugger utilizza una freccia verde per indicare il processo di istruzione successivo che verrÓ eseguita quando viene restituito dalla funzione.
  8. ╚ possibile aggiungere un punto di interruzione nel processo di secondo.
  9. Si interrompe il processo primo e quindi si preme F5.
A questo punto, si prevede che il debugger raggiunge il punto di interruzione in ciascun processo. Tuttavia, entrambi i processi sono deadlock all'interno della funzione e il punto di interruzione ultimo Ŕ stato aggiunto non Ŕ mai raggiunto. Inoltre, il debugger Impossibile eseguire parte dell'applicazione finale.

Correzione di interfaccia utente del punto di interruzione

I punti di interruzione disattivati non sono visibili dopo aver installato Visual Studio 2008 Service Pack 1

Se si disattiva un punto di interruzione, il punto di interruzione non viene raggiunto. Inoltre, il punto di interruzione Ŕ nascosto dal canale editor pi¨ a sinistra. Il punto di interruzione disattivato esiste ancora. Viene visualizzato nella finestra punti di interruzione Tool.

Risoluzione

╚ disponibile un hotfix supportato. Questo hotfix Ŕ tuttavia destinato esclusivamente alla risoluzione del problema descritto in questo articolo. Consente di applicare questo aggiornamento rapido (hotfix) solo ai sistemi in cui si verifica questo problema specifico. Questo aggiornamento rapido (hotfix) potrebbe essere eseguiti ulteriori test. Se non si Ŕ notevolmente interessati da questo problema, si consiglia pertanto di attendere il successivo aggiornamento di software che contiene questo aggiornamento rapido (hotfix).

Per scaricare questo aggiornamento rapido (hotfix) da MSDN Code Gallery, il seguente sito Microsoft Web:
http://code.msdn.microsoft.com/KB957912

Nota MSDN Code Gallery vengono visualizzate le lingue per i quali l'aggiornamento rapido Ŕ disponibile. Se non viene visualizzata la lingua elencata, Ŕ perchÚ la pagina di risorse di Code Gallery non Ŕ disponibile per tale lingua.

Nota Se si verificano ulteriori problemi o se la risoluzione dei problemi Ŕ necessario, potrebbe essere necessario creare una richiesta di servizio separato. I costi di supporto normale verranno applicati per eventuali ulteriori domande e problemi che non dovessero rientrare nello specifico hotfix in questione. Per un elenco completo, di Microsoft Customer Service and Support numeri di telefono o a creare una richiesta di servizio distinto, visitare il seguente sito Web Microsoft:
http://support.microsoft.com/contactus/?ws=support

Prerequisiti

╚ necessario disporre di Microsoft Visual Studio 2008 SP1 per applicare questo aggiornamento rapido (hotfix).

NecessitÓ di riavvio

Non Ŕ necessario riavviare il computer dopo avere applicato questo aggiornamento rapido (hotfix).

Informazioni sulla sostituzione della correzione

Questo aggiornamento rapido (hotfix) non sostituisce eventuali altri hotfix.

Informazioni sui file

La versione di lingua inglese di questo aggiornamento rapido (hotfix) presenta gli attributi di file (o attributi successivi) elencati nella tabella riportata di seguito. Le date e le ore per questi file sono indicati in UTC (Coordinated Universal Time). Quando si visualizzano le informazioni sul file, viene convertito in ora locale. Per trovare la differenza tra ora UTC e ora locale, utilizzare il fuso orario scheda nella Data e ora nel Pannello di controllo.
Riduci questa tabellaEspandi questa tabella
Nome del fileVersione del fileDimensione del fileDataOraPiattaforma
AvVsPkDH.dll9.0.30729.177325848-11-082: 19x 86
AvVsPkDH.dll9.0.30729.177382168-11-082: 19x 64
AvVsPkDH.dll9.0.30729.177750808-11-082: 19IA-64
AvVsPkDH.dll9.0.30729.177750808-11-082: 19x 86
AvVsPkDH.dll9.0.30729.177382168-11-082: 19x 86
AvVsPkDH.dll9.0.30729.177325848-11-082: 19x 86
cpde.dll9.0.30729.1776526088-11-082: 19x 86
mcee.dll9.0.30729.17711809928-11-082: 19x 86
mcee.dll9.0.30729.1776567048-11-082: 19x 86
mcee.dll9.0.30729.1773648648-11-082: 19x 86
mcee.dll9.0.30729.1773648648-11-082: 19x 86
mcee.dll9.0.30729.1776567048-11-082: 19x 64
mcee.dll9.0.30729.17711809928-11-082: 19IA-64
MPIShim.exe9.0.30729.177238808-11-082: 19x 86
MPIShim.exe9.0.30729.177238808-11-082: 19x 86
MPIShim.exe9.0.30729.177238808-11-082: 19x 86
MPIShim.exe9.0.30729.177238808-11-082: 19x 86
MPIShim.exe9.0.30729.177290008-11-082: 19x 64
MPIShim.exe9.0.30729.177546008-11-082: 19IA-64
msvb7.dll9.0.30729.17740871048-11-082: 19x 86
msvb7.dll9.0.30729.17757331848-11-082: 19x 86
msvb7.dll9.0.30729.17727425928-11-082: 19x 86
msvb7.dll9.0.30729.17740871048-11-082: 19x 86
msvb7.dll9.0.30729.17740871048-11-082: 19x 86
msvb7.dll9.0.30729.17727425928-11-082: 19x 64
msvb7.dll9.0.30729.17757331848-11-082: 19IA-64
msvsmon.exe9.0.30729.17799925208-11-082: 19x 86
msvsmon.exe9.0.30729.17747614168-11-082: 19x 86
msvsmon.exe9.0.30729.17732167128-11-082: 19x 86
msvsmon.exe9.0.30729.17732167128-11-082: 19x 86
msvsmon.exe9.0.30729.17747614168-11-082: 19x 64
msvsmon.exe9.0.30729.17799925208-11-082: 19IA-64
NatDbgDE.dll9.0.30729.17713479128-11-082: 19x 86
NatDbgDE.dll9.0.30729.1773141848-11-082: 19x 86
VSDebug.dll9.0.30729.17715849688-11-082: 19x 86
msvb7.dll9.0.30729.17740871048-11-082: 19x 86

Status

Microsoft ha confermato che questo problema riguarda i prodotti sono elencati nella sezione "Si applica a".

ProprietÓ

Identificativo articolo: 957912 - Ultima modifica: mercoledý 4 febbraio 2009 - Revisione: 2.0
Le informazioni in questo articolo si applicano a:
  • Microsoft Visual Studio 2008 Service Pack 1
Chiavi:á
kbmt kbsurveynew kbhotfixserver kbexpertiseadvanced kbqfe KB957912 KbMtit
Traduzione automatica articoli
Il presente articolo Ŕ stato tradotto tramite il software di traduzione automatica di Microsoft e non da una persona. Microsoft offre sia articoli tradotti da persone fisiche sia articoli tradotti automaticamente da un software, in modo da rendere disponibili tutti gli articoli presenti nella nostra Knowledge Base nella lingua madre dell?utente. Tuttavia, un articolo tradotto in modo automatico non Ŕ sempre perfetto. Potrebbe contenere errori di sintassi, di grammatica o di utilizzo dei vocaboli, pi¨ o meno allo stesso modo di come una persona straniera potrebbe commettere degli errori parlando una lingua che non Ŕ la sua. Microsoft non Ŕ responsabile di alcuna imprecisione, errore o danno cagionato da qualsiasi traduzione non corretta dei contenuti o dell?utilizzo degli stessi fatto dai propri clienti. Microsoft, inoltre, aggiorna frequentemente il software di traduzione automatica.
Clicca qui per visualizzare la versione originale in inglese dell?articolo: 957912
LE INFORMAZIONI CONTENUTE NELLA MICROSOFT KNOWLEDGE BASE SONO FORNITE SENZA GARANZIA DI ALCUN TIPO, IMPLICITA OD ESPLICITA, COMPRESA QUELLA RIGUARDO ALLA COMMERCIALIZZAZIONE E/O COMPATIBILITA' IN IMPIEGHI PARTICOLARI. L'UTENTE SI ASSUME L'INTERA RESPONSABILITA' PER L'UTILIZZO DI QUESTE INFORMAZIONI. IN NESSUN CASO MICROSOFT CORPORATION E I SUOI FORNITORI SI RENDONO RESPONSABILI PER DANNI DIRETTI, INDIRETTI O ACCIDENTALI CHE POSSANO PROVOCARE PERDITA DI DENARO O DI DATI, ANCHE SE MICROSOFT O I SUOI FORNITORI FOSSERO STATI AVVISATI. IL DOCUMENTO PUO' ESSERE COPIATO E DISTRIBUITO ALLE SEGUENTI CONDIZIONI: 1) IL TESTO DEVE ESSERE COPIATO INTEGRALMENTE E TUTTE LE PAGINE DEVONO ESSERE INCLUSE. 2) I PROGRAMMI SE PRESENTI, DEVONO ESSERE COPIATI SENZA MODIFICHE, 3) IL DOCUMENTO DEVE ESSERE DISTRIBUITO INTERAMENTE IN OGNI SUA PARTE. 4) IL DOCUMENTO NON PUO' ESSERE DISTRIBUITO A SCOPO DI LUCRO.

Invia suggerimenti

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com