Procedura: connettere il profiler a un'applicazione autonoma nativa e raccogliere dati di concorrenza tramite la riga di comando
In questo argomento viene illustrato come utilizzare gli strumenti da riga di comando disponibili negli strumenti di profilatura di Visual Studio per connettere il profiler a un'applicazione autonoma (C/C++) nativa e raccogliere dati su conflitti di thread.
Nota
Gli strumenti da riga di comando degli strumenti di profilatura sono contenuti nella sottodirectory \Team Tools\Performance Tools della directory di installazione di Visual Studio. Nei computer a 64 bit gli strumenti sono disponibili nelle versioni a 32 e 64 bit. Per utilizzare gli strumenti da riga di comando del profiler, è necessario aggiungere il percorso degli strumenti alla variabile di ambiente PATH della finestra Prompt dei comandi oppure aggiungerlo al comando stesso. Per ulteriori informazioni, vedere Specifica del percorso degli strumenti da riga di comando degli strumenti di profilatura.
Quando il profiler è connesso all'applicazione, è possibile sospendere e riprendere la raccolta dei dati. Per terminare una sessione di profilo, è necessario che il profiler non sia più connesso all'applicazione e che venga arrestato in modo esplicito.
Connessione del profiler a un'applicazione nativa in esecuzione
Per connettere il profiler a un'applicazione nativa in esecuzione
Al prompt dei comandi digitare il comando seguente:
VSPerfCmd /start:concurrency[,{ResourceOnly|ThreadOnly}] **/output:**OutputFile [Options]
L'opzione /start consente di inizializzare il profiler. Utilizzare una delle opzioni riportate nella tabella seguente per specificare i dati di concorrenza da raccogliere.
/start:concurrency
Abilita la raccolta dei dati di esecuzione thread e dei conflitti di risorse.
/start:concurrency,resourceonly
Abilita la raccolta dei soli dati dei conflitti di risorse.
/start:concurrency,threadonly
Abilita la raccolta dei soli dati di esecuzione thread.
L'opzione /output**:**OutputFile è obbligatoria con /start. OutputFile specifica il nome e il percorso del file dei dati di profilo (vsp).
È possibile utilizzare qualsiasi opzione riportata nella tabella seguente con l'opzione /start:contention .
Opzione
Descrizione
/user:[Domain\]Username
Specifica il dominio e il nome utente facoltativi dell'account per ottenere l'accesso al profiler.
Abilita il profilo dei processi in altre sessioni di accesso.
/wincounter:WinCounterPath
Specifica un contatore delle prestazioni Windows di cui raccogliere i dati durante il profilo.
/automark:Interval
Utilizzare unicamente con /wincounter. Specifica il numero di millisecondi tra gli eventi di raccolta dati del contatore delle prestazioni Windows. Il valore predefinito è 500.
/events:Config
Specifica un evento Traccia eventi per Windows (ETW) di cui raccogliere i dati durante il profilo. Gli eventi ETW vengono raccolti in un file separato con estensione etl.
Connettere il profiler all'applicazione di destinazione digitando il comando seguente:
VSPerfCmd /attach:{PID|ProcName}
PID specifica l'ID processo dell'applicazione di destinazione. È possibile visualizzare gli ID processo di tutti i processi in esecuzione in Gestione attività di Windows.
Controllo della raccolta di dati
Quando l'applicazione di destinazione è in esecuzione, è possibile controllare la raccolta dei dati avviando e interrompendo la scrittura di dati nel file utilizzando le opzioni di VSPerfCmd.exe. Controllando la raccolta dei dati, è possibile raccogliere dati per una parte specifica dell'esecuzione del programma, ad esempio l'avvio o l'arresto dell'applicazione.
Per avviare e interrompere la raccolta dei dati
Le coppie di opzioni nella tabella seguente avviano e interrompono la raccolta dei dati. Specificare ogni opzione in una riga di comando separata. È possibile attivare e disattivare più volte la raccolta dei dati.
Opzione
Descrizione
Avvia (/globalon) o interrompe (/globaloff) la raccolta dei dati per tutti i processi.
/processon:PID /processoff:PID
Avvia (/processon) o interrompe (/processoff) la raccolta dei dati per il processo specificato dall'ID processo (PID).
/attach avvia la raccolta di dati per il processo specificato da ID processo (PID) o da nome processo (ProcName). /detach interrompe la raccolta di dati per il processo specificato o per tutti i processi se non è specificato alcun processo.
Fine della sessione di profilo
Per terminare una sessione di profilo, non deve essere in corso alcuna raccolta di dati. È possibile interrompere la raccolta dei dati da un'applicazione profilata con il metodo di campionamento chiudendo l'applicazione o richiamando l'opzione VSPerfCmd /detach. Richiamare quindi l'opzione VSPerfCmd /shutdown per disattivare il profiler e chiudere il file dei dati di profilo.
Per terminare una sessione di profilo
Disconnettere il profiler dall'applicazione di destinazione chiudendolo o digitando il comando seguente:
VSPerfCmd /detach
Arrestare il profiler digitando il comando seguente:
VSPerfCmd /shutdown