note sulla versione di Visual Studio 2022
Siamo lieti di annunciare la disponibilità di Visual Studio 2022 v17.12. Questo aggiornamento è incentrato sulla fornitura di esperienze di sviluppo fantastiche per lavorare con progetti di .NET 9 e nuove funzionalità di produttività di intelligenza artificiale , insieme a miglioramenti continui all-around.
Tratti somatici
Elenco delle funzionalità per 17.12 rilasciato il 12 novembre 2024.
Produttività
Copia dall'elenco errori 📣
Copia di un errore dall'elenco errori copia ora solo la descrizione anziché l'intera riga negli Appunti.
Viene visualizzato un errore nell'elenco errori che non si sa come correggere. Quindi, si seleziona e si preme CTRL+C per copiare la descrizione per una ricerca Web. Dopo averlo incollato nel motore di ricerca, si rende conto che ha copiato tutte le intestazioni di colonna e i valori di riga anziché solo la descrizione. È ora necessario eliminare tutto tranne la descrizione dell'errore prima di poter eseguire la ricerca Web. Questo è complesso, ma ora abbiamo una correzione!
![]()
Quando si copia un errore dall'elenco errori usando CTRL+C, solo la descrizione viene copiata negli Appunti. In questo modo è più semplice cercare l'errore online o condividerlo con altri utenti.
È comunque possibile copiare l'intera riga facendo clic con il pulsante destro del mouse sull'errore e scegliendo Copia riga dal menu di scelta rapida o premendo CTRL+MAIUSC+C.
Se ciò che si vuole fare con la descrizione dell'errore era eseguire una ricerca Web, premere CTRL+F1 per cercare informazioni sull'errore online.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Vai a riga in qualsiasi punto del 📣
ricerca codiceIn Ricerca codice è ora possibile passare a una riga specifica nel documento corrente o in un altro documento specificato.
A volte si sa che c'è un problema in una determinata riga nel codice e si vuole ottenerlo rapidamente. Forse si è parlato di un errore generato alla riga 43 di un file o si vuole arrivare alla fine di un file specifico.
ricerca codice supporta ora lo spostamento rapido a una riga specifica nel codice.
Aprire ricerca codice e passare a una riga nel documento corrente usando i due punti e il numero di riga. Ad esempio,
:39
passerà alla riga 39 nel file attivo.
![]()
È anche possibile passare a una riga in un documento diverso usando il nome file + due punti + numero di riga. Ad esempio,
Order:43
passerà alla riga 43 in Order.cs. Se non si specifica il nome di file esatto, la ricerca tenterà di trovare la corrispondenza migliore.
![]()
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Ancorare la finestra Ricerca codice 📣
È ora possibile posizionare liberamente la finestra Ricerca codice con funzionalità come l'ancoraggio e la nascondere automaticamente.
Se hai bisogno di Codice o Ricerca funzionalità per rimanere al di fuori del tuo modo, ora hai più controllo sul comportamento della finestra di ricerca.
È ora possibile ancorare la finestra di ricerca ed eseguire azioni della finestra degli strumenti, ad esempio Esplora soluzioni e altri.
inferiore
Dopo aver aperto ricerca codice o ricerca funzionalità, fare clic sull'icona della casella in alto a destra per convertirla in una finestra degli strumenti. È possibile scegliere di ancorarlo altrove, aprirlo, nascondere automaticamente e così via. È possibile ripristinare la finestra popup non consentita facendo clic sull'icona in alto a destra.
![]()
Abbiamo anche semplificato e pulito l'esperienza di anteprima nella ricerca. È ora presente un pulsante, indicato con un'icona a forma di occhio, per attivare e disattivare l'anteprima.
![]()
Anche la posizione del pannello di anteprima verrà modificata in base alle dimensioni della finestra di ricerca.
destra
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Personalizzare l'indicatore di testo compresso 📣
Impostare colori personalizzati per l'indicatore di testo compresso nell'editor di Visual Studio.
È ora possibile personalizzare ulteriormente l'esperienza dell'editor con nuove opzioni per personalizzare l'indicatore di testo compresso:
![]()
Per provare e impostare colori di primo piano e di sfondo personalizzati per ognuno di essi, passare a Strumenti di > Opzioni > Ambiente > Tipi di carattere e colori.
![]()
Sono disponibili due nuovi elementi per la personalizzazione:
- indicatore di testo compresso (compresso)
- indicatore di testo compresso (espanso)
È possibile impostare i colori per gli indicatori compressi ed espansi in modo indipendente l'uno dall'altro usando colori predefiniti o colori personalizzati di propria scelta.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Aggiornare i risultati della ricerca 📣
È ora possibile aggiornare i risultati a una ricerca precedente per ottenere up-to-date corrispondenze di ricerca.
Abbiamo sentito parlare da molti utenti che è frustrante dover riaprire la finestra Trova e passare attraverso i movimenti di rollforward di una ricerca per ottenere risultati aggiornati. È possibile eseguire il refactoring di codice e verificare che tutto sia stato modificato come previsto oppure che siano state estratte alcune modifiche recenti e che sia necessaria l'operazione di ricerca recente per riflettere tali aggiornamenti.
Dopo aver completato Trova nei file, sarà ora possibile aggiornare i risultati della ricerca nella finestra. Si otterranno i risultati aggiornati senza dover ripetere la ricerca.
![]()
È stata riprogettata anche l'opzione Ripeti ricerca precedente per distinguerla da Refresh. Ora è rappresentato come Modifica trova con un'icona a forma di matita. Questo pulsante riaprirà comunque Trova nei file con gli stessi criteri di ricerca usati per la finestra dei risultati.
![]()
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Più spazio per la barra di scorrimento orizzontale 📣
È ora possibile controllare la visibilità degli indicatori a livello di file in CodeLens.
L'area con la barra di scorrimento orizzontale può diventare piuttosto disordinata in Visual Studio. Stiamo aiutando a semplificare la pulizia disattivando gli indicatori a livello di file in CodeLens per impostazione predefinita.
![]()
Se si desidera attivare l'opzione , è possibile trovare l'opzione Mostra indicatore codeLens a livello di file in Strumenti di opzioni > Opzioni > Editor di testo > Avanzate. Questa opzione influisce sulla visibilità dei tipi di file con il controllo CodeLens a livello di file nel margine dell'editor inferiore, ad esempio XAML, HTML e CSS e non influisce sui file che contengono CodeLens inline.
opzione
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Pulizia del codice non bloccando il salvataggio
Quando la pulizia del codice viene eseguita su Salva, ora funziona in modo non bloccante, per un'esperienza di codifica più fluida.
In precedenza, quando viene eseguita una pulizia del codice in Salva, non è possibile eseguire alcuna azione nell'IDE. Questa operazione è stata migliorata per operare in modo non bloccante.
Il processo di pulizia verrà eseguito in background e può essere annullato automaticamente se si riprende la digitazione, garantendo un'esperienza di codifica più fluida e reattiva.
![]()
dipendenze transitive nell'interfaccia utente di Gestione pacchetti a livello di soluzione
Quando si esamina la scheda Installato nell'interfaccia utente di Gestione pacchetti di Visual Studio a livello di soluzione, vengono ora visualizzati pacchetti diretti e transitivi.
In precedenza nella scheda Installato nell'interfaccia utente di Gestione pacchetti di Visual Studio è possibile visualizzare dipendenze dirette e transitive solo per i progetti. Con questa versione è stata aggiunta anche la possibilità di visualizzare le dipendenze transitive a livello di soluzione.
![]()
dipendenze transitive con vulnerabilità in Esplora soluzioni
Quando si imposta
NuGetAuditMode
suall
, Esplora soluzioni mostrerà gli indicatori per le dipendenze transitive con vulnerabilità.NuGet Audit, aggiunto per la prima volta in Visual Studio 17.8 (e .NET 8), fornisce avvisi durante il ripristino se i pacchetti usati dal progetto presentano vulnerabilità note.
Per altre informazioni sul controllo NuGet, incluse tutte le opzioni di configurazione, vedere la documentazione su Controllo NuGet.
Queste vulnerabilità possono trovarsi nelle dipendenze dirette e nelle dipendenze transitive (i pacchetti da cui dipendono le dipendenze). Ora se si imposta
NuGetAuditMode
suall
, Esplora soluzioni mostrerà gli indicatori non solo per le dipendenze dirette, ma anche per le dipendenze transitive con vulnerabilità.
![]()
GitHub Copilot
porre altre domande a GitHub
Ricerca in GitHub per trovare commit, problemi, richieste pull, repository e argomenti direttamente da Visual Studio.
È ora possibile usare GitHub Copilot Chat per eseguire ricerche in GitHub per trovare commit, problemi, richieste pull, repository e argomenti.
È possibile porre domande come:
- @github Quali sono tutte le richieste pull aperte assegnate all'utente corrente?
- @github Quali sono i problemi più recenti assegnati?
- @github Quando è stata rilasciata la versione più recente?
- @github Mostra le richieste pull unite recenti da @davidfowl
![]()
Questa funzionalità è disponibile per tutti gli utenti di GitHub Copilot. Altre informazioni sulle disponibili GitHub Skills nella documentazione di GitHub Copilot.
Importante
Per usare questa funzionalità, assicurarsi di attivare GitHub Copilot
Istruzioni personalizzate per gitHub Copilot
Creare un file che aggiunge automaticamente informazioni a tutte le domande poste a GitHub Copilot Chat.
Con GitHub Copilot è possibile ricevere risposte di chat personalizzate per il flusso di lavoro del team, strumenti preferiti e specifiche del progetto, semplicemente fornendo contesto. Anziché aggiungere questo dettaglio contestuale a ogni query di chat, è possibile creare automaticamente un file che fornisce queste informazioni. Anche se questo contesto aggiuntivo non verrà visualizzato nella chat, è disponibile per GitHub Copilot, consentendogli di generare risposte più accurate e pertinenti.
![]()
Come abilitare istruzioni personalizzate
- Abilitare la funzionalità tramite Tools > Options > GitHub > Copilot> e selezionare (anteprima) Abilitare le istruzioni personalizzate da file .github/copilot-instructions.md e aggiunte alle richieste.
- Aggiungere copilot-instruction.md nella radice del repository all'interno del file con estensione github, creare il file, se non esiste già.
![]()
Altre informazioni sulla creazione di istruzioni personalizzate qui
Importante
Per usare questa funzionalità, assicurarsi di attivare GitHub Copilot
selezione del modello
in GitHub Copilot Chat
GitHub Copilot consente ora di scegliere il modello.
OpenAI o1-preview e o1-mini sono ora disponibili per tutti gli utenti in GitHub Copilot Chat in Visual Studio.
È ora possibile provare questi modelli in prima persona usando o1-preview, o1-mini o il modello GPT-4o predefinito per alimentare GitHub Copilot Chat. Con il cambio di modello disponibile, è possibile passare facilmente dalla spiegazione delle API o dalla generazione di codice di base alla creazione di algoritmi complessi o al debug degli errori logici.
Per altre informazioni su questa funzionalità, visitare il del log delle modifiche di GitHub.
Importante
Per usare questa funzionalità, assicurarsi di attivare GitHub Copilot
di comprensione contestuale avanzata
la comprensione contestuale avanzata in GitHub Copilot offre risposte più precise.
Miglioramento della comprensione contestuale in GitHub Copilot
GitHub Copilot offre ora una migliore comprensione contestuale per offrire risposte ancora più precise. Con questo aggiornamento, GitHub Copilot può interpretare in modo intuitivo le caratteristiche chiave nel codice, adattando suggerimenti in base alle esigenze specifiche del progetto. Questo approccio più intelligente all'assistenza per il codice è progettato per facilitare il lavoro in modo più efficiente, senza la necessità di modifiche frequenti al contesto.
Prova subito con GitHub Copilot!
Importante
Per usare questa funzionalità, assicurarsi di attivare GitHub Copilot
aggiornamenti di esclusione del contenuto
l'esclusione del contenuto supporta ora i moduli secondari e i repository annidati.
È stato migliorato il modo in cui il sistema gestisce i moduli secondari e i repository annidati, semplificando l'uso di strutture di progetto complesse.
È stato inoltre aggiunto il supporto per i repository non Git, espandendo la flessibilità del flusso di lavoro e consentendo di integrare facilmente un'ampia gamma di progetti.
Importante
Per usare questa funzionalità, assicurarsi di attivare GitHub Copilot
'ispezione intelligente delle variabili di intelligenza artificiale
Ottimizzare il flusso di lavoro di debug con l'ispezione integrata delle variabili di intelligenza artificiale.
L'analisi e l'analisi dei valori da variabili locali, auto e descrizioni dati non è mai stata più semplice con Ask GitHub Copilot in Visual Studio. È sufficiente fare clic con il pulsante destro del mouse su qualsiasi valore per ottenere informazioni dettagliate basate sull'intelligenza artificiale sugli errori, sui risultati imprevisti o sulle anomalie, senza mai uscire dall'IDE.
![]()
Questa funzionalità migliorerà significativamente la velocità di risoluzione dei problemi analizzando le variabili in tempo reale all'interno dell'IDE ogni volta che si verificano valori imprevisti.
Importante
Per usare questa funzionalità, assicurarsi di attivare GitHub Copilot
visualizzatore IEnumerable basato su intelligenza artificiale
espressioni LINQ Editable basate su intelligenza artificiale nel visualizzatore IEnumerable.
È stata migliorata la funzionalità di espressione modificabile nel visualizzatore IEnumerable con l'assistenza per l'intelligenza artificiale. La nuova funzionalità di Ask Copilot consente agli utenti di sfruttare l'intelligenza artificiale direttamente nella casella di testo dell'espressione modificabile per creare espressioni LINQ complesse.
![]()
Per accedere alla chat di GitHub Copilot, è sufficiente fare clic sull'icona di GitHub Copilot nell'angolo in basso a destra della sezione dell'espressione modificabile. Nella chat sono disponibili esempi di sintassi LINQ di esempio. Inoltre, è possibile descrivere la query in linguaggio naturale e GitHub Copilot genererà la query LINQ corrispondente. Per applicare il filtro di query LINQ al visualizzatore, usare il pulsante Mostra nel visualizzatore nella chat.
Fornisce feedback istantaneo e indicazioni, rendendo il processo di creazione di filtri e trasformazioni complessi più intuitivi ed efficienti.
Importante
Per usare questa funzionalità, assicurarsi di attivare GitHub Copilot
eseguire il debug dei test con GitHub Copilot
Ottenere assistenza per il debug di test non riusciti usando i test di debug con GitHub Copilot.
Serve aiuto per eseguire il debug degli unit test non superati. GitHub Copilot può ora essere utile fornendo un piano di debug e guidando il debug del test non riuscito per avvicinarsi al passaggio facendo clic sul pulsante Debug con Copilot in Esplora test.
![]()
Dopo aver avviato la funzionalità, GitHub Copilot fornirà un piano di debug, impostare punti di interruzione appropriati e controllare le variabili e avviare la sessione di debug. Quando raggiunge il punto di interruzione, fornisce a GitHub Copilot i valori per le variabili watched e determina il passaggio successivo, continuare il debug o risolvere il codice del problema. È possibile continuare con questa conversazione fino a quando non si ha un test superato.
![]()
Importante
Per usare questa funzionalità, assicurarsi di attivare GitHub Copilot
Correggere il codice con GitHub Copilot 📣
GitHub Copilot consente di risolvere i problemi di codice.
GitHub Copilot è ora integrato nell'elenco di lampadine ed errori, fornendo correzioni rapide e spiegazioni dettagliate per i problemi di codice. Che si stia sviluppando in C# o C++, questa funzionalità consente di comprendere e risolvere i problemi nella codebase in modo più efficiente.
Per iniziare, è sufficiente richiamare la lampadina e selezionare Correzione con Copilot. Verrà avviata una chat inline con GitHub Copilot, che offre una correzione disponibile.
![]()
È anche possibile selezionare l'icona di GitHub Copilot dall'elenco degli errori per aprire il pannello della chat, in cui sono disponibili spiegazioni dettagliate e soluzioni per l'errore.
![]()
Sfruttando i moduli LLMs, GitHub Copilot fornisce spiegazioni e correzioni utili direttamente all'interno della lampadina e dell'elenco degli errori, migliorando l'esperienza di scrittura del codice.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Importante
Per usare questa funzionalità, assicurarsi di attivare GitHub Copilot
migliori completamenti di intelligenza artificiale per C#
GitHub Copilot offre un contesto aggiuntivo dai file di origine pertinenti per migliorare i completamenti per C#.
I completamenti del codice Di GitHub Copilot forniscono suggerimenti di completamento automatico inline durante il codice. Questi suggerimenti vengono generati in base al contenuto del file attualmente attivo e a qualsiasi altro file aperto nell'editor. Tuttavia, abbiamo scoperto che l'incorporazione di un contesto più rilevante migliora significativamente questi suggerimenti.
Per migliorare l'esperienza per gli sviluppatori C#, GitHub Copilot è stato aggiornato per includere un contesto C# aggiuntivo, ad esempio i tipi e i metodi disponibili nei completamenti.
Con la versione più recente di Visual Studio, GitHub Copilot ora considera automaticamente i file pertinenti in modo semantico per un contesto aggiuntivo, anche se questi file non sono aperti nell'editor. Questo miglioramento aiuta a ridurre le allucinazioni offrendo suggerimenti più pertinenti e accurati.
Before: I file semanticamente rilevanti non vengono considerati come contesto per i completamenti di GitHub Copilot
![]()
After: I file semanticamente rilevanti vengono considerati come contesto per i completamenti di GitHub Copilot
![]()
Importante
Per usare questa funzionalità, assicurarsi di attivare GitHub Copilot
codice di riferimento in GitHub Copilot
Introduzione al codice che fa riferimento in GitHub Copilot, consentendo di consentire suggerimenti di codice contenenti corrispondenze di codice pubblico durante la ricezione di informazioni dettagliate sulla corrispondenza.
Siamo lieti di annunciare che il riferimento al codice è ora disponibile in GitHub Copilot in Visual Studio.
![]()
Questa nuova funzionalità offre trasparenza per gli sviluppatori notificando loro quando i suggerimenti di GitHub Copilot corrispondono al codice pubblico. È ora possibile visualizzare il codice corrispondente, il relativo file di origine e le informazioni sulle licenze associate, consentendo loro di prendere decisioni più informate durante la codifica.
Il riferimento al codice consente di bloccare o consentire suggerimenti contenenti corrispondenze di codice pubblico, migliorando il controllo e la personalizzazione.
Integrando il codice che fa riferimento a GitHub Copilot, stiamo promuovendo la condivisione delle conoscenze, migliorando la trasparenza e consentendoti di creare con fiducia. Che si tratti di un singolo sviluppatore o di un team più ampio, questa funzionalità migliora il flusso di lavoro e consente di esplorare facilmente le complessità del codice pubblico.
Provare subito GitHub Copilot in Visual Studio e assumere il controllo del processo di sviluppo con maggiore trasparenza e fiducia.
Importante
Per usare questa funzionalità, assicurarsi di attivare GitHub Copilot
chat guidata in GitHub Copilot
Introduzione a un nuovo modo più colloquiale per chattare con GitHub Copilot.
Stiamo introducendo un nuovo modo più colloquiale per interagire con GitHub Copilot Chat.
![]()
È stato introdotto un modo più interattivo e colloquiale per usare GitHub Copilot Chat. Ora, invece di sentirsi bloccati o non sicuri, GitHub Copilot guiderà l'utente con domande chiare quando il contesto non è chiaro, assicurando risposte più accurate e utili.
Questa esperienza di chat guidata consente di perfezionare le query, offrire suggerimenti e garantire interazioni più fluide e più produttive. Con questa nuova modalità di chat, potrai usufruire di un Copilot GitHub più intelligente e intuitivo che si adatta alle tue esigenze durante il codice.
Dare la nuova esperienza di chat guidata una prova oggi e vedere la differenza per se stessi!
Importante
Per usare questa funzionalità, assicurarsi di attivare GitHub Copilot
di onboarding di GitHub Copilot
Iniziare più velocemente in GitHub Copilot Chat.
Serve aiuto per iniziare a usare GitHub Copilot Chat? Sono state introdotte due nuove funzionalità di onboarding che consentono di iniziare più rapidamente.
Prompt di avvio
Inviare il primo messaggio a GitHub Copilot facendo clic su una delle richieste di avvio. Usare queste istruzioni per visualizzare le funzionalità offerte da GitHub Copilot nel flusso di lavoro.
![]()
Raccolta prompt
Se è necessario fare di nuovo riferimento a alcune richieste predefinite, fare clic sul pulsante Raccolta prompt (icona libro) per visualizzare un elenco di tutte le richieste disponibili. Questa libreria contiene i prompt di uso comune, solo un clic!
![]()
Sia che tu stia esplorando nuove attività di codifica o semplicemente cercando ispirazione, le nostre richieste sono qui per aiutarti a approfondire e iniziare a sfruttare al meglio GitHub Copilot Chat.
Date un tentativo e vedete dove ti porta!
Importante
Per usare questa funzionalità, assicurarsi di attivare GitHub Copilot
.RETE
Ottenere di più con .NET 9 📣
.NET 9 eleva lo sviluppo di app intelligenti e native del cloud, concentrandosi sui miglioramenti della produttività, sulle distribuzioni semplificate e sull'integrazione accelerata dell'intelligenza artificiale.
.NET 9 eleva lo sviluppo di app intelligenti e native del cloud, concentrandosi sui miglioramenti della produttività, sulle distribuzioni semplificate e sull'integrazione accelerata dell'IA, offrendo prestazioni superiori in un'ampia gamma di applicazioni. Con il supporto completo per .NET 9 in Visual Studio 17.12, è possibile sfruttare facilmente tutti i miglioramenti più recenti. Per altre informazioni sulle novità, vedere Novità di .NET 9.
.NET 9
Sono inoltre disponibili aggiornamenti delle funzionalità relative all'IDE che rendono più produttiva l'uso di .NET e ASP.NET più produttivi che mai.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
l'eliminazione degli avvisi per specifici avvisi di GitHub rispettati in Visual Studio
NuGet consente di eliminare gli avvisi per avvisi specifici di GitHub Advisor e le supressioni vengono rispettate in Visual Studio.
Il controllo NuGet fornisce avvisi quando un pacchetto usato nel progetto presenta una vulnerabilità nota. È sempre consigliabile eseguire l'aggiornamento a una nuova versione del pacchetto, ma se l'aggiornamento è impossibile e si è certi che il software non sia a rischio, è possibile eliminare gli avvisi per specifici avvisi di GitHub aggiungendo
NuGetAuditSuppress
elementi al file di progetto.<Project Sdk="Microsoft.NET.Sdk"> <ItemGroup> <NuGetAuditSuppress Include="https://github.com/advisories/GHA1234" /> </ItemGroup> </Project>
Possibilità di configurare nuget.org come
di origine del controlloOra è possibile impostare nuget.org come origine di controllo per ottenere informazioni sulla vulnerabilità anche quando si usano altri feed NuGet.
Il controllo NuGet richiede un'origine del pacchetto che fornisce un database di vulnerabilità. nuget.org fornisce informazioni sulle vulnerabilità del database di Advisor di GitHub.
A partire da Visual Studio 17.12, è ora possibile specificare le origini di controllo nei file NuGet.Config, quindi non è più necessario usare nuget.org come origine del pacchetto.
Se non si usa nuget.org come origine del pacchetto e si vuole usare Il controllo NuGet per la creazione di report dei pacchetti vulnerabili durante il ripristino, aggiungere quanto segue a un file nuGet.Config nella directory della soluzione:
<confiuration> <!-- any existing config, including <packageSources> --> <auditSources> <add key="nuget.org" value="https://api.nuget.org/v3/index.json" /> </auditSources> </configuration>
Debug & diagnostica
📣
di debug Di Blazor WebAssemblyistogramma contatoreUn'esperienza di debug migliorata per le app WebAssembly Blazor destinate a .NET 9 o versione successiva.
Visual Studio offre ora un'esperienza di debug migliorata per le app WebAssembly Blazor destinate a .NET 9 o versione successiva:
- I tipi di dati visualizzati nel debugger corrispondono ora ai tipi di dati .NET previsti.
- I membri del tipo e la visibilità dei membri usano le icone previste.
- Lo stack di chiamate visualizzato viene pulito in modo da visualizzare solo lo stack di chiamate .NET e rispetta correttamente l'impostazione Just My Code.
- La finestra moduli è ora supportata.
- Il supporto della valutazione delle espressioni nella finestra Immediata e per gli orologi e i punti di interruzione condizionali viene espanso e migliorato.
![]()
Per abilitare la nuova esperienza di debug in anteprima:
- Abilitare l'impostazione Abilita nuovo debugger .NET 9+ Mono.
- Installare la versione più recente di .NET 9 SDK.
- Aggiornare l'app Blazor in modo che sia destinato a .NET 9.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
nel profiler
informazioni dettagliate sulle prestazioni migliorate usando l'istogramma del contatore del contatore del profiler.
Il recente miglioramento della suite di profilatura delle prestazioni di Visual Studio introduce la funzionalità istogramma del contatore. Questo strumento consente di identificare e analizzare i dati dell'istogramma generati dagli strumenti istogrammi. Quando si registrano dati da questi strumenti, vengono visualizzati i risultati dell'istogramma, fornendo una rappresentazione chiara della distribuzione dei dati.
![]()
Inoltre, il grafico corsia offre una visualizzazione dettagliata e segmentata delle metriche delle prestazioni, migliorando la capacità di individuare e risolvere efficacemente i problemi di prestazioni.
metodo Display restituisce valori 📣
Il debugger mostra ora i valori restituiti inline con l'assistenza di intelligenza artificiale per migliorare l'efficienza.
Il debugger di Visual Studio visualizza ora i valori inline per le istruzioni restituite, rispondendo a una delle funzionalità più richieste dalla community degli sviluppatori.
Questo miglioramento consente di visualizzare i valori esatti restituiti dalle funzioni direttamente nel codice, eliminando la necessità di codice aggiuntivo o variabili temporanee per controllare i valori restituiti.
![]()
Con GitHub Copilot, è possibile continuare usando l'opzione Ask Copilot al passaggio del mouse per analizzare i valori restituiti direttamente in Visual Studio, consentendo di risolvere immediatamente i problemi.
È supportato sia nel codice nativo che in quello gestito.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Esportare gruppi di punti di interruzione con facilità 📣
Importazione ed esportazione semplici dei gruppi di punti di interruzione.
I gruppi di punti di interruzione di Visual Studio supportano ora la funzionalità di importazione ed esportazione, consentendo di gestire e gestire facilmente le strutture dei punti di interruzione in più progetti o ambienti.
![]()
Questa nuova funzionalità consente di esportare i gruppi di punti di interruzione con le relative configurazioni e di importarli in soluzioni diverse, garantendo una configurazione di debug coerente senza dover ricreare manualmente i gruppi di punti di interruzione.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
IntelliSense per il visualizzatore IEnumerable 📣
visualizzatore IEnumerable avanzato con IntelliSense per query LINQ più veloci.
Il visualizzatore IEnumerable è stato migliorato con IntelliSense, fornendo suggerimenti di codice in tempo reale e completamento automatico, che rende la scrittura di espressioni LINQ più veloci e accurate.
![]()
Questo miglioramento semplifica il processo di compilazione e modifica delle query offrendo raccomandazioni intelligenti sul codice, riducendo la probabilità di errori e accelerando il tempo di sviluppo.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Analizzare l'uso della memoria nel tempo
Selezionare e confrontare due snapshot di memoria usando la finestra Strumento di diagnostica.
La finestra Strumento di diagnostica supporta ora il confronto degli snapshot di memoria, semplificando l'analisi delle modifiche alla memoria nel tempo.
Per usare questa funzionalità, assicurarsi di avere almeno due snapshot di memoria acquisiti nella scheda memoria nella finestra Strumento di diagnostica.
Selezione di snapshot per confronto
- Tenere premuto il tasto ctrl e fare clic sulle righe dello snapshot per selezionare due snapshot.
- In alternativa, tenere premuto il tasto maiusc e usare i tasti di direzione
up/down
per selezionare due snapshot consecutivi.Annullamento della selezione di snapshot
- Tenere premuto ctrl tasto e fare clic sullo snapshot da deselezionare.
Visualizzazione della differenza
Dopo aver selezionato gli snapshot di memoria per il confronto, fare clic sul pulsante visualizza diff che si trova sopra l'elenco di snapshot per visualizzare le differenze tra di esse.
![]()
Strumenti Git
Gestire la ridenominazione dei file con Git 📣
Ottenere tranquillità quando si rinominano i file con una nuova notifica.
Quando si rinominano i file da Esplora soluzioni, verrà visualizzato un promemoria per preparare le modifiche per visualizzare le ridenominazione in Git. In questo modo si aumenta la sicurezza che Git riconosca la modifica del file e lo stia monitorando correttamente. Abbiamo scoperto che questo è un punto di confusione per molti clienti, quindi abbiamo lavorato con gli utenti della community degli sviluppatori per produrre una nuova notifica.
![]()
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
📣
bozze e modelli di richiesta pullCreare bozze di richiesta pull e avviare le descrizioni con i modelli in Visual Studio.
È ora possibile creare bozze di richiesta pull e avviare le descrizioni con i modelli GitHub in Visual Studio. Si tratta delle due richieste principali per la creazione di un'esperienza di richiesta pull.
Richieste pull bozza
Usare il menu a discesa nel pulsante Crea per Crea come bozza.
![]()
Modelli di richiesta pull
Il modello di richiesta pull predefinito verrà usato quando si crea una nuova richiesta pull per GitHub e Azure DevOps. Altre informazioni su come aggiungere un modello di richiesta pull al repository nella documentazione di GitHub e documentazione di Azure DevOps.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.E prendere questo sondaggio per migliorare ulteriormente la funzionalità.
Creare repository GitHub interni 📣
Visual Studio supporta ora la creazione di repository interni e include indicazioni per ogni tipo di repository per offrire maggiore attendibilità all'avvio di un nuovo progetto.
Visual Studio supporta ora repository interni per le organizzazioni GitHub. Sono state inoltre fornite indicazioni per ogni tipo di repository per offrire maggiore chiarezza sulla visibilità del nuovo progetto a seconda dell'account in uso.
![]()
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Copia collegamento Git 📣
È possibile ottenere un collegamento a GitHub o Azure DevOps a una riga di codice specifica per semplificare la condivisione con i colleghi.
Ogni volta che si condividono alcune righe di codice con un collega, spesso può essere utile per ottenere un contesto aggiuntivo dal repository. Tuttavia, se stanno lavorando su qualcos'altro può richiedere troppo tempo e interrompere il loro lavoro per eseguire il checkout del ramo.
A questo punto, è possibile evidenziare il codice che si vuole condividere nell'editor, aprire il menu di scelta rapida con un clic con il pulsante destro del mouse e nel sottomenu Git ottenere un collegamento condivisibile al codice in GitHub o Azure DevOps. In questo modo è semplice e facile collaborare e semplifica il flusso tra l'IDE e i repository remoti sul Web.
![]()
È anche possibile ottenere collegamenti condivisibili direttamente dalla cronologia dei commit. Ciò consente di fare riferimento al codice non estratto esattamente come senza sforzo.
![]()
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
supporto di più repository Git 📣
È ora possibile creare richieste pull e collegare elementi di lavoro in scenari multi-repository sia per GitHub che per Azure DevOps.
È ora possibile creare richieste pull e collegare elementi di lavoro in scenari multi-repository. Sia per GitHub che per Azure DevOps, le integrazioni vengono supportate quando si usa la selezione repository per concentrarsi su un determinato repository negli scenari con più repository.
![]()
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Personalizzare il messaggio di commit git di intelligenza artificiale 📣
È possibile aggiungere istruzioni aggiuntive alla richiesta di generazione del messaggio di commit Git con GitHub Copilot.
È ora possibile aggiungere istruzioni aggiuntive alla richiesta di generazione del messaggio di commit Git con GitHub Copilot. In questo modo è possibile personalizzare il messaggio di commit in base agli standard del flusso di lavoro e del team. È possibile specificare il numero di righe da generare, la lunghezza delle righe e anche fornire uno stile di commit di esempio. Modificare il messaggio nel campo del prompt in Strumenti di opzioni >> GitHub > Copilot > Integrazione del controllo del codice sorgente.
messaggi Git
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
IDE
configurazione di avvio multiprogetto 📣
Semplificare il debug configurando e salvando i profili di avvio per progetti specifici all'interno di soluzioni multiprogetto. Condividere facilmente le configurazioni con il team.
La funzionalità Configurazione avvio multiprogetto consente di configurare e salvare profili per l'avvio di progetti specifici all'interno di una soluzione multiprogetto in stati predefiniti per il debug.
![]()
Questo semplifica il processo di utilizzo di soluzioni complesse, migliora l'efficienza del debug e consente una facile condivisione delle configurazioni tra i membri del team.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Nota
Questa funzionalità deve essere abilitata in Strumenti di -> Gestire le funzionalità di anteprima
avvisi di sicurezza MotW
Gli avvisi di sicurezza Mark of the Web (MotW) sono ora integrati nella funzionalità di attendibilità complessiva.
Visual Studio visualizzerà un avviso di sicurezza quando rileva che si sta tentando di aprire il contenuto contrassegnato con l'identificatore Mark of the Web (MotW).
Questo nuovo avviso correlato alla fiducia indica i rischi di apertura di contenuto da origini potenzialmente non sicure, ad esempio download Internet.
![]()
È possibile modificare l'esperienza di attendibilità predefinita passando alla impostazioni di attendibilità di in Strumenti > Opzioni > Ambiente.
![]()
Teams Toolkit nuovi modelli di intelligenza artificiale
Teams Toolkit esegue l'onboarding di nuovi modelli di app teams per intelligenza artificiale.
Teams Toolkit aggiunge tre nuovi modelli di app teams per intelligenza artificiale:
Sono:
![]()
Basic AI Chat Bot: i propri copiloti in Microsoft Teams creati con la libreria di intelligenza artificiale di Teams
Chat with Your Data : un modello di chatbot intelligente con informazioni sul dominio dall'origine dati personalizzata.
Teams Toolkit consente ora di creare un copilot personalizzato, un chatbot basato sull'intelligenza artificiale con funzionalità RAG, in grado di comprendere il linguaggio naturale e recuperare i dati di dominio per rispondere a domande specifiche del dominio. Questo modello supporta l'accesso ai dati personalizzati nell'app Copilot personalizzata.
Quando si seleziona questo modello, è possibile selezionare due modi per connettersi ai dati:
un. ricerca di intelligenza artificiale di Azure: il chatbot può accedere ai dati nel servizio di ricerca di intelligenza artificiale di Azure e usarlo nella conversazione con gli utenti.
b. 'origine dati personalizzata: è possibile aggiungere qualsiasi origine dati desiderata all'app Copilot personalizzata, ad esempio file system o database vettoriale.
agente di intelligenza artificiale: un agente di intelligenza artificiale in Teams che può prendere decisioni ed eseguire azioni in base al ragionamento LLM.
Provare i nuovi modelli di app di intelligenza artificiale per iniziare il percorso di intelligenza artificiale in Teams.
Copiare file tra istanze 📣
È ora possibile copiare file e cartelle da Esplora soluzioni in un'istanza di Visual Studio a un'altra.
Siamo lieti di introdurre una funzionalità molto richiesta in Visual Studio. È ora possibile copiare e incollare facilmente file di codice e cartelle tra diverse istanze di Visual Studio usando Esplora soluzioni. È sufficiente selezionare il file o la cartella desiderata, usare CTRL+C o CTRL+X, passare a un'altra istanza di Visual Studio e usare CTRL+V per includere tali file o cartelle nella nuova soluzione. Tutte le modifiche verranno riflesse accuratamente nel file system.
Oltre a copiare e incollare, è anche possibile trascinare i file e le cartelle da un'istanza di Visual Studio a un'altra.
![]()
In precedenza, questa funzionalità era disponibile solo per alcuni tipi di progetto, ma ora è stata espansa per includere tutti i tipi di progetto principali in Visual Studio.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Nuvola
servizio app di Azure pubblicare gli aggiornamenti della sicurezza
Pubblicazione nel servizio app di Azure in modo sicuro usando gli aggiornamenti della sicurezza integrati.
Le linee guida per la pubblicazione di del servizio app di Azure consigliano ai clienti di disabilitare l'autenticazione di base e abilitare la pubblicazione tramite l'autenticazione integrata.
di pubblicazione sicura di Strumenti di Azure
La nuova funzionalità di Visual Studio 2022 disabilita l'autenticazione di base e abilita la sicurezza integrata per la pubblicazione nel servizio app di Azure. Ciò garantisce che la pubblicazione delle credenziali venga gestita in modo sicuro, riducendo i rischi associati all'autenticazione di base.
Quando si esegue la pubblicazione in un servizio app di Azure con l'autenticazione di base abilitata (che non è consigliata), gli utenti visualizzeranno l'opzione Attiva autenticazione di base e verrà deselezionata per impostazione predefinita. I clienti che devono conservare l'autenticazione di base possono selezionare la casella, ma dato che è consigliabile disabilitare l'autenticazione di base, questa opzione è deselezionata per impostazione predefinita. È quindi iniziare a proteggere se è la prima volta che si pubblica o si ottenere un sicuro dopo l'aggiornamento di Visual Studio.
![]()
Se l'app Web è stata creata di recente tramite il portale o questa o una versione futura di Visual Studio, l'autenticazione di base verrà disabilitata per impostazione predefinita. Per qualsiasi app Web già disabilitata, l'autenticazione di base viene aggirata inavvertitamente rendendo l'app Web meno sicura disabilitando completamente la casella di controllo, in modo da mantenere la sicurezza.
![]()
supporto di Processi Web di Azure per Linux 📣
Pubblicazione in Processi Web di Azure in Linux è ora supportato facendo clic con il pulsante destro del mouse su Pubblica in Visual Studio.
Le app console .NET 5.0+ multipiattaforma sono supportate in Azure WebJobs Linux e ora è possibile fare clic con il pulsante destro del mouse su Pubblica il codice in Processi Web di Azure in Linux da Visual Studio.
di destinazione Linux
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
consumo di Funzioni di Azure Flex
Pubblica nel piano di hosting a consumo di Azure Flex, attualmente in anteprima.
Se si sta provando il nuovo piano di hosting a consumo di Funzioni di Azure Flex, attualmente in anteprima, sarà possibile fare clic con il pulsante destro del mouse su Pubblica in Flex da Visual Studio.
Flex Consumption estenderà ulteriormente le funzionalità delle app e fornirà quanto segue:
- Integrazione della rete virtuale senza costi aggiuntivi
- Scalabilità rapida e prevedibile con la scelta delle dimensioni dell'istanza e il controllo della concorrenza per istanza
- Serverless con scalabilità a zero e si paga solo per le istanze mentre sono attive
- Mitigazione dell'avvio a freddo con la funzionalità facoltativa delle istanze Always Ready
Altre informazioni su Flex Consumption nel post di blog dell'annuncio o documentazione e provare uno degli esempi di .
![]()
l'aggiornamento della sicurezza di Servizi connessi
Rendere le app e le esperienze di sviluppo più sicure.
In questo aggiornamento a Servizi connessi è ora possibile connettere il codice del progetto alle risorse di Azure, ad esempio Archiviazione di Azure, senza la necessità di segreti o stringhe di connessione nel codice o nella configurazione.
A questo punto, si assegna un nome alla connessione, gli endpoint vengono salvati in modo permanente nella configurazione anziché nella stringa di connessione completa. Ciò significa un minor numero di segreti su disco, quindi il tempo di sviluppo sarà più sicuro per impostazione predefinita e subisce un minor numero di errori durante il commit dei segreti nel controllo del codice sorgente.
![]()
Si usano anche gli SDK di Azure più recenti, quindi si otterrà il supporto per la connessione alle risorse di Azure usando l'account di accesso di Visual Studio (o l'interfaccia della riga di comando di Azure) anziché connettersi tramite una stringa di connessione. Durante l'esecuzione in locale, il codice userà le credenziali registrate per accedere alle risorse. Quando si esegue in Azure, Azure SDK userà l'identità gestita del servizio app per accedere alle risorse.
Servizi connessi imposta tutto per l'utente e inserisce il codice appropriato per l'uso dell'identità integrata anziché dei segreti. Durante la pubblicazione, l'app verrà configurata con l'identità e i ruoli appropriati necessari per accedere alle risorse.
Desktop
strumenti MSIX migliorati per le app UWP in .NET 9 📣
Visual Studio ora fa riferimento al nuovo strumento MSIX a progetto singolo autonomo per creare un pacchetto di app UWP in .NET 9.
Nell'anteprima iniziale del supporto UWP per .NET 9, ci siamo basati su WindowsAppSDK per fornire gli strumenti MSIX per creare pacchetti di app usando la configurazione di un singolo progetto (anziché usare un progetto di creazione pacchetti di applicazioni Windows, ad esempio un file con estensione wapproj). In questo modo sono stati introdotti diversi problemi, il principale è che anche la dipendenza transitiva WebView2 da WindowsAppSDK è stata aggiunta automaticamente a tutte le app UWP, anche quando non è necessario.
Sono stati ora separati completamente gli strumenti MSIX del progetto singolo e sono stati pubblicati come nuovo pacchetto NuGet autonomo: Microsoft.Windows.SDK.BuildTools.MSIX. Sono inclusi tutti gli elementi necessari per compilare, distribuire ed eseguire app UWP in .NET 9, nonché generare pacchetti MSIX da pubblicare in Microsoft Store o trasferire localmente. Gli strumenti UWP in .NET 9 in Visual Studio aggiungeranno automaticamente questi due riferimenti al pacchetto quando necessario:
degli strumenti MSIX
In questo modo vengono rimosse completamente la dipendenza transitiva WebView2 e l'errore di compilazione presente per i nuovi progetti nelle versioni di anteprima precedenti quando non si imposta manualmente la proprietà WindowsSdkPackageVersion nel file con estensione csproj. Con questa modifica, i nuovi progetti verranno compilati ed eseguiti senza dover apportare modifiche aggiuntive.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
di ricerca dei componenti WinUI avanzati
Migliorare la configurazione del progetto WinUI con la ricerca migliorata del programma di installazione di Visual Studio, semplificando la posizione dei componenti per gli sviluppatori.
Semplificare ulteriormente la configurazione del progetto WinUI con l'aggiornamento più recente del programma di installazione di Visual Studio. Gli sviluppatori possono ora individuare rapidamente i componenti correlati a WinUI, eliminando la frustrazione precedente di spostarsi attraverso un risultato di ricerca vuoto. Questo miglioramento semplifica la configurazione dell'ambiente di sviluppo, consentendo un'esperienza utente più intuitiva ed efficiente.
![]()
Aprire il programma di installazione di Visual Studio, passare a scheda Singoli componenti e cercare parole chiave correlate a WinUI (WinUI, WinRT)!
supporto di .NET 9 SDK per la piattaforma UWP 📣
Visual Studio include ora .NET 9 SDK con supporto UWP predefinito.
Uno dei passaggi necessari per provare UWP in .NET 9 nell'anteprima iniziale era installare una build notturna di .NET 9 SDK. Con questa nuova versione di Visual Studio, non è più necessaria.
Visual Studio include ora .NET 9 SDK, che include tutto il nuovo supporto per UWP in .NET 9 (in particolare la logica per fare riferimento alle proiezioni XAML UWP e per configurare CsWinRT in tipi di progetto per le app XAML UWP). È ora possibile compilare ed eseguire UWP in progetti .NET 9 con .NET SDK installato automaticamente con Visual Studio.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
file con estensione csproj semplificato per 📣
UWPUseUwpTools viene ora impostato automaticamente da Visual Studio per i progetti UWP moderni in .NET 9.
Le app e le librerie UWP che usano .NET 9 usano per richiedere due proprietà nei file con estensione csproj:
UseUwp
, che configura .NET SDK per le app XAML UWP eUseUwpTools
, che consente a tutti i nuovi strumenti in Visual Studio di compilare ed eseguire app XAML UWP.La proprietà
UseUwpTools
viene ora impostata automaticamente da Visual Studio quandoUseUwp
è impostata per rendere il file con estensione csproj meno dettagliato nello scenario comune. Per gli scenari avanzati, è comunque possibile rifiutare esplicitamente disabilitando manualmenteUseUwpTools
.📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
RID per UWP in .NET 9 📣
fissiUWP nelle librerie di classi .NET 9 impostare correttamente i RID sui valori corretti per AOT nativo.
È stato risolto un bug negli strumenti APPX per le librerie di classi UWP (e i componenti WinRT) in .NET 9, che applicava gli identificatori di runtime di UWP in .NET Native per impostazione predefinita (ad esempio, usando il prefisso
win10-
e incluse le piattaforme che non sono più supportate, ad esempio arm).Gli strumenti APPX ora impostano i RID corretti per i progetti .NET 9 per impostazione predefinita:
win-x86;win-x64;win-arm64
. È comunque possibile specificarli manualmente, se necessario.📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
creazione di progetti UWP fissa 📣
È stata corretta la Creazione guidata modello universale che causava la mancata visualizzazione di una finestra di dialogo di errore durante la creazione di nuovi progetti UWP in progetti .NET 9.
Se usi il anteprima vsix con i nuovi modelli di progetto per UWP in .NET 9, potresti aver notato che durante la creazione di un nuovo progetto è stata visualizzata una finestra di dialogo di errore. Ciò è particolarmente problematico quando si crea una nuova soluzione, perché Visual Studio non lo apre correttamente dopo la creazione del progetto. Questo problema è stato risolto e la creazione di nuovi progetti destinati alla piattaforma UWP in .NET 9 funzionerà correttamente.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Ragnatela
variabili di richiestanei file HTTP 📣
I file HTTP supportano ora le variabili di richiesta. In questo caso è possibile inviare una richiesta e quindi usare i dati dalla risposta o dalla richiesta nelle richieste future.
Quando si lavora con i file HTTP , uno scenario comune è chiamare un endpoint, accettando un valore dalla risposta e inviando in una richiesta successiva. Ad esempio, è possibile chiamare un endpoint per autenticare un utente e quindi nelle chiamate successive è possibile passare il token restituito dall'endpoint di accesso. Prima di questa versione non era possibile in Visual Studio. Nel frammento di codice seguente è possibile vedere un esempio di funzionamento in un file HTTP.
# @name login POST {{TodoApi_HostAddress}}/users/token Content-Type: application/json { "username": "{{myusername}}", "password": "{{mypassword}}" } ### GET {{TodoApi_HostAddress}}/todos Authorization: Bearer {{login.response.body.$.token}} ###
Nel frammento di codice precedente sono presenti due richieste, la prima chiamata all'endpoint
/users/token
per autenticare l'utente. Immediatamente sopra la riga della richiesta verrà visualizzato il commento# @name login
. Questa sintassi assegna alla richiesta un nome (login
in questo caso) e la configura come variabile richiesta. Quando la richiesta viene inviata, è possibile accedere ai valori dalla risposta o dalla richiesta, in qualsiasi richiesta futura inviata da tale file HTTP. Poiché si tratta di una richiesta di accesso, è consigliabile prestare attenzione a proteggere i segreti. In Visual Studio è disponibile il supporto per l'accesso ai segreti in modo sicuro. Per altre informazioni sulla gestione dei segreti, vedi questa sezione nella documentazione.La seconda richiesta chiama in un endpoint autenticato,
/todos
, che restituirà gli elementitodo
per tale utente. Nella richiesta il token viene passato come intestazione con la riga.Authorization: Bearer {{login.response.body.$.token}}
L'endpoint
/users/token
restituisce una risposta in JSON. Il token viene estratto con un'espressione JSON Path,$.token
, nel corpo della risposta. Se si usa un endpoint che restituisce XML, anziché un'espressione JSON Path, è possibile passare un'espressione XPath. Il supporto in Visual Studio è stato ispirato dall'estensione OSS esistente per client REST disponibile per Visual Studio Code. Altre informazioni sulle variabili di richiesta sono disponibili. Presto verrà aggiunta la documentazione per discutere questo supporto in modo molto più dettagliato.📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
supporto di Vitest in JavaScript e TypeScript 📣
Quando si usano progetti JavaScript e TypeScript è ora possibile creare test case con Vitest.
Nei progetti JavaScript e TypeScript (JSTS), i progetti con estensione esproj sono stati aggiunti il supporto per individuare ed eseguire test creati con Vitest. Per iniziare a usare i test Vitest, in un progetto JSTS aggiungere il pacchetto vitest usando npm in Esplora soluzioni e quindi modificare il file di progetto in modo che le proprietà seguenti siano dichiarate.
<JavaScriptTestRoot>test\</JavaScriptTestRoot> <JavaScriptTestFramework>Vitest</JavaScriptTestFramework>
Assicurarsi che il valore per
JavaScriptTestRoot
abbia il percorso relativo corretto in cui si trovano i file di test.Aggiungere i test alla cartella corretta e compilare il progetto/soluzione. Successivamente, i test case verranno visualizzati in Esplora test.
![]()
In Esplora test è possibile visualizzare i diversi test case individuati ed eseguiti i test case.
Non è ancora stato aggiunto il supporto per il debug, ma il supporto verrà aggiunto a breve. Un altro problema noto è che quando si fa doppio clic su un test case in Esplora test, verrà visualizzata la prima riga del file in cui è definito il test case. Stiamo migliorando anche questa esperienza.
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Hint inlay per altre lingue 📣
supporto degli hint inlay è stato aggiunto a JavaScript, TypeScript, Python e Razor, nonché a un'impostazione per controllarne il comportamento.
Gli hint di inlay mostrano informazioni aggiuntive sul codice sorgente di cui viene eseguito il rendering inline. Viene in genere usato per visualizzare tipi, nomi di parametri e altre informazioni implicite dal codice direttamente nell'editor.
È stato aggiunto il supporto per visualizzare gli hint Inlay in JavaScript, TypeScript, Razor e Python. È stata aggiunta anche una nuova impostazione in modo da poter personalizzare il comportamento degli hint in queste lingue. Questa impostazione non si applica ancora a C# e C++. Per abilitare gli hint di inlay per queste lingue, è possibile usare la nuova impostazione in Strumenti di opzioni > opzioni > Editor di testo > tutti i linguaggi > hint inlay. È possibile visualizzare la nuova opzione nell'immagine seguente.
![]()
Esistono tre valori diversi per Gli hint inlay.
- Sempre: mostra sempre gli hint di inlay.
- Premendo alt+F1 : vengono visualizzati solo gli hint di inlay mentre ALT e F1 vengono premuti. Questo è il valore predefinito.
- Mai: Hint inlay non vengono mai visualizzati.
Per JavaScript e TypeScript, è disponibile una pagina di opzioni aggiuntive per configurare il comportamento di Hint inlay. Questa opzione è disponibile in Tools > Opzioni > Editor di testo > JavaScript/TypeScript >> Generale.
Queste opzioni vengono visualizzate nell'immagine seguente.
impostazione TypeScript globale degli hint di inlay
Per impostazione predefinita, tutte queste opzioni sono disabilitate, è necessario abilitare gli hint che si desidera visualizzare per i file JavaScript e TypeScript. In un aggiornamento futuro è possibile modificare i valori predefiniti per queste opzioni. Nell'immagine seguente è possibile visualizzare un file JavaScript che mostra Hint inlay.
![]()
Nell'immagine precedente gli hint inlay visualizzati sono le caselle grigie con
: number
per indicare il tipo della variabile.📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
'ambiente condiviso dei file HTTP 📣
Nei file di ambiente HTTP è stato aggiunto il supporto per condividere le variabili tra ambienti.
Quando si usano file HTTP in Visual Studio, è possibile definire ambienti in modo da poter creare impostazioni diverse per il test api. In precedenza, la condivisione di una variabile tra questi ambienti non era possibile. È stato aggiunto il supporto per una nuova voce,
$shared
, nel file di ambiente che consente di definire i valori predefiniti per le variabili disponibili in tutti gli ambienti.Si consideri ad esempio il file di ambiente (http-client.env.json) riportato di seguito.
{ "$shared": { "HostAddress": "https://localhost:7293" }, "dev": { "username": "sayedha" }, "dev2": { "username": "madsk" }, "staging": { "username": "staginuser", "HostAddress": "https://sayedrest.example.com" } }
I valori condivisi sono stati definiti in
$shared
sopra, costituiti dalla variabileHostAddress
impostata sulocalhost:7293
.Dei tre ambienti definiti, nessuno degli ambienti di sviluppo ha specificato il valore per
HostAddress
ma la gestione temporanea ha un valore per tale ambiente.Quando si usa l'ambiente
dev
odev2
, il valore perHostAddress
proviene da$shared
poiché tali ambienti non hanno un valore perHostAddress
. Quando si usa l'ambiente di gestione temporanea, il valore perHostAddress
verrà impostato suhttps://sayedrest.example.com
.📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
Dati
progetti SQL di tipo SDK in SSDT 📣
È ora possibile usare il formato di file di progetto in stile SDK nei progetti di SQL Server Data Tools.
Questo aggiornamento aggiunge progetti SQL basati su Microsoft.Build.Sql SDK, che offre il supporto multipiattaforma e i riferimenti ai pacchetti migliorati ai progetti SQL Server Data Tools (SSDT). Con file di progetto e riferimenti di database meno verbosi ai pacchetti NuGet, i team possono collaborare in modo più efficiente su database di grandi dimensioni in un singolo progetto o compilare più set di oggetti di diversi progetti.
![]()
Le distribuzioni di database da un progetto Microsoft.Build.Sql possono essere automatizzate in ambienti Windows e Linux in cui lo strumento dotnet Microsoft.SqlPackage pubblica l'artefatto di compilazione (con estensione dacpac) dal progetto SQL. Altre informazioni sull'anteprima di progetti SQL in stile SDK e DevOps per SQL.
Microsoft.Build.Sql project SDK è open source e sviluppato in GitHub.
Assicurarsi di installare il componente più recente dell'anteprima di SSDT nel programma di installazione di Visual Studio per usare i progetti SQL in stile SDK nella soluzione.
![]()
📣 Vedere ticket di funzionalità per condividere il feedback e continuare la conversazione.
C++
impostare gli argomenti della riga di comando C++
Un nuovo modo per impostare gli argomenti della riga di comando direttamente dalla barra degli strumenti.
Impostare rapidamente gli argomenti della riga di comando per il progetto C++ con la nuova imposta argomenti elemento della barra degli strumenti. Questa casella combinata consente di impostare gli argomenti della riga di comando direttamente dalla barra degli strumenti, in modo da poter modificare rapidamente gli argomenti. Quando si esegue il progetto, tutti gli argomenti immessi nella casella verranno passati.
Questo componente della barra degli strumenti verrà visualizzato per impostazione predefinita se è installato sviluppo di giochi con il carico di lavoro C++. Se non viene visualizzata, è possibile aggiungerla facendo clic con il pulsante destro del mouse sulla barra degli strumenti e selezionando Imposta argomenti.
Nota: questa funzionalità è attualmente disponibile solo per i progetti unreal Engine. I progetti C++ generali saranno supportati nelle versioni future.
![]()
spiegazioni delle visualizzazioni di Build Insights
Informazioni su come usare ogni scheda di Build Insights tramite un collegamento alla documentazione appena aggiunto.
È ora possibile visualizzare una breve descrizione su come usare ogni scheda di Build Insights, insieme a un collegamento alla documentazione per una spiegazione dettagliata.
di spiegazioni delle visualizzazioni di Build Insights
rettifiche del percorso di Build Insights
Ottenere una visualizzazione più chiara del file in Build Insights, vedere il percorso completo al passaggio del mouse.
Abbiamo percorsi completi e relativi nascosti per ridurre la confusione. Per visualizzare i percorsi completi, è sufficiente passare il puntatore del mouse sul file. Verrà visualizzata anche una nuova colonna nome file per i file e le unità di conversione, visualizzate per impostazione predefinita per identificare rapidamente i file senza analizzare percorsi lunghi.
![]()
Apri cartella per unreal Engine uproject
Un nuovo modo di aprire il tuo uproject.
È stato aggiunto un punto di ingresso aggiuntivo per aprire il progetto uproject del motore Unreal con il supporto uproject di Visual Studio. È ora possibile aprire il progetto uproject direttamente dal menu file selezionando Apri > progetto Unreal Engine.... Verrà aperto il progetto Unreal Engine in Visual Studio.
Per altre informazioni su come usare questa funzionalità, vedere Modifica diretta di .uproject in Visual Studio.
apri cartella del motore Unreal
modifica migliorata
È ora possibile modificare le firme con l'interfaccia C++ migliorata.
È stata aggiornata l'interfaccia Change Signature per C++. È ora possibile aggiungere, rimuovere e ridisporre i parametri nella sezione di configurazione dei parametri. Inoltre, è possibile modificare l'ordine selezionandoli e trascinandoli in una nuova posizione.
I metodi di accesso rimangono invariati: premere CTRL+. attivare il menu azioni rapide e refactoring e selezionare Modifica firma.
di firma delle modifiche migliorata
Correzioni di bug segnalate dall'utente principali
- Editor C# non è in grado di trovare i controlli definiti nel file xaml
- comando GIT (sincronizzazione, pull, push) ed elenco di rami mancanti nella barra di stato
- VSSDK/CPS/Extensibility: il caricamento delle immagini nelle estensioni di Visual Studio tramite .imagemanifest è interrotto in VS2022
- Backspace e talvolta smettere di funzionare
- Esplora risorse non è in grado di aprire file resx
- Reimpostare tutte le impostazioni genera sempre un errore
- VS2022 17.10.0 Preview 7: Errore interno del compilatore
- i file Javascript perdono la codifica a colori dopo 10000 righe di codice
- L'uso di std::format in un modulo richiede l'inclusione dell'intestazione di formato nei file .cpp usando tale modulo
- errore di sintassi C++ dopo l'aggiornamento a Visual Studio 17.11.0
- impossibile spostare un blocco di codice verso l'alto e verso il basso dopo l'aggiornamento di Visual Studio
- generazione della cache CMake in un host Linux remoto non riesce in una query ctest
- errore di nelle pipeline di Azure DevOps con VSTest@2
- Non è possibile aggiungere un account Apple (VS 2022, account Enterprise)
📣 Vedere l'elenco completo di tutte le [correzioni di bug segnalate dall'utente][bugfixes] che lo hanno reso in questa versione.
Problemi noti
- L'errore "Esportazione del certificato non riuscita" si verifica quando si tenta di eseguire il debug di un progetto Web ASP.NET Core con HTTPS abilitato e usando il profilo di debug WSL. Ciò si verifica a causa di modifica di rilievo: l'esportazione del certificato di sviluppo non crea più la cartella.
Questa operazione può essere risolta creando la cartella
%appdata%\ASP.NET\Https
prima del debug.
Versione 17.12.6
data di rilascio: 11 marzo11, 2025
Correzioni di bug principali | Dalla community |
---|---|
Correzione di un problema di inizializzazione non corretto per determinati struct con membri di dimensioni zero. | |
Address Sanitizer (ASan) ora si collega a OneCoreUAP_apiset.lib , una libreria generica, anziché direttamente alle librerie Win32. Si tratta di rendere ASan più portabile su più versioni e dispositivi del sistema operativo. Se il codice dipende in modo transitivo dai moduli Win32 portati da ASan (non consigliato), potrebbe trattarsi di una modifica che causa un'interruzione. In questi casi, ti consigliamo di collegare il programma direttamente alle librerie di dipendenze Win32 necessarie. |
ticket di feedback |
È stato risolto un problema di ridenominazione inline C# in cui è stato selezionato l'intero identificatore quando erano disponibili suggerimenti per la ridenominazione. Ciò eseguirà l'override della selezione dello sviluppatore e potrebbe causare errori di digitazione, soprattutto se lo sviluppatore ha spostato il cursore all'interno dell'interfaccia di ridenominazione inline. Ora, i suggerimenti di ridenominazione di Copilot non modificheranno la selezione all'interno dell'interfaccia di ridenominazione inline. | ticket di feedback |
È stato risolto un problema a causa del quale le DLL instrumentate scaricate durante l'esecuzione del test di input di fuzzer causeranno un report di errore ASan falso positivo e un arresto anomalo. | ticket di feedback |
Ice x86 di nuovo dopo l'aggiornamento dei dati di ottimizzazione PGO | ticket di feedback |
È stato risolto un problema per cui i clienti con hardware grafico Intel potevano riscontrare lo scorrimento ritardato nell'editor dopo aver attivato un'anteprima dell'immagine al passaggio del mouse. | ticket di feedback |
VS2022 Professional - Non è possibile accedere all'account m | ticket di feedback |
Rimosso l'elenco a discesa degli argomenti della riga di comando per attenuare un blocco dell'interfaccia utente nell'esperienza unreal Engine. | |
I progetti Blazor interrompino IntelliSense 17.12.2 | ticket di feedback |
Avvisi di sicurezza risolti | CVE |
---|---|
Vulnerabilità di elevazione dei privilegi di Visual Studio | CVE-2025-25003 |
Vulnerabilità di elevazione dei privilegi .NET | CVE-2025-24070 |
Vulnerabilità di elevazione dei privilegi del programma di installazione di Visual Studio | CVE-2025-24998 |
Versione 17.12.5
data di rilascio: 11 febbraio, 2025
Correzioni di bug principali | Dalla community |
---|---|
È stato risolto un problema per cui a volte lo strumento Utilizzo CPU non visualizzava risultati anche se in precedenza sono stati acquisiti dati. | |
L'analisi del codice MSVC consente ora di rilevare l'uso di puntatori che puntano alle risorse negli oggetti temporanei eliminati quando vengono usati nell'elenco di inizializzatori di una matrice. | ticket di feedback |
Errore con String::Format nel progetto libreria di classi CLR C++ (.NET) | ticket di feedback |
Regressione nella versione 17.12.0: Errore C3699 durante la compilazione con /CLR | ticket di feedback |
Aggiornamento di Windows 11 SDK (10.0.26100.0) installato da Visual Studio alla build di manutenzione di gennaio 2025. | |
Correzione di un bug nell'utilità di ottimizzazione che comportava codicegeno non corretto ed è stato rilevato un impatto sulla funzione std::sort quando viene chiamato da una coroutine. |
Avvisi di sicurezza risolti | CVE |
---|---|
Elevazione dei privilegi del programma di installazione di Visual Studio: l'elemento Percorso di ricerca non controllato consente a un utente malintenzionato non autorizzato di elevare i privilegi in locale. | CVE-2025-21206 |
Versione 17.12.4
data di rilascio: 14 gennaio14, 2025
Correzioni di bug principali | Dalla community |
---|---|
È stata risolta un'incompatibilità tra Live++ (uno strumento di ricaricamento rapido C++ di terze parti) e Visual Studio 2022. | ticket di feedback |
È stato risolto un blocco in Tutte leIn-One Ricerca (CTRL+T, CTRL+Q). | ticket di feedback |
Il debugger di Visual Studio non può visualizzare i valori nella finestra 'Variabili locali'. | ticket di feedback |
Correzione di un bug che causava l'arresto anomalo immediato di Visual Studio e la chiusura all'apertura di Gestione pacchetti NuGet se il riquadro dei dettagli sul lato destro era molto piccolo. | ticket di feedback |
È stato risolto un problema per cui il passaggio del mouse su un file Docker poteva bloccarsi vs. | |
È stato risolto un problema relativo all'inizializzazione non corretta per determinati struct con membri di dimensioni zero. | |
È stato risolto un problema per le destinazioni x86 in cui i registri dei frame usati durante le coroutine potrebbero non essere ricaricati correttamente. | ticket di feedback |
VS include ora MAUI 8.0.100 (SR10); MAUI 9.0.14 (SR1.4) | |
Sintassi fissa sfarfallio durante lo scorrimento tramite https://github.com/dotnet/roslyn/pull/75796|| |
Avvisi di sicurezza risolti | CVE |
---|---|
Vulnerabilità di esecuzione di codice remoto di .NET e Visual Studio | CVE-2025-21172 |
Vulnerabilità di esecuzione di codice remoto di .NET, .NET Framework e Visual Studio | CVE-2025-21176 |
Vulnerabilità di esecuzione di codice remoto di Visual Studio | CVE-2025-21178 |
Il carattere ritorno a capo nell'URL remoto consente al repository dannoso di perdere credenziali | CVE-2024-50338 |
Vulnerabilità di esecuzione di codice remoto .NET | CVE-2025-21171 |
(solo Linux) Vulnerabilità di elevazione dei privilegi .NET | CVE-2025-21173 |
Vulnerabilità di elevazione dei privilegi di Visual Studio | CVE-2025-21405 |
Versione 17.12.3
rilasciata il 3 dicembrerd, 2024
Correzioni di bug principali | Dalla community |
---|---|
Errori NuGet dopo l'aggiornamento da VS v17.11.6 a v17.12 con .NET 9. | ticket di feedback |
Messaggi Unity privati contrassegnati in modo non corretto come IDE0051 inutilizzati. | ticket di feedback |
IntelliSense ha smesso di funzionare nel progetto Word C++. | ticket di feedback |
È stato risolto un problema per cui i caratteri potrebbero essere duplicati durante la digitazione in un file contenente una lingua incorporata. | ticket di feedback |
È stato risolto un problema per cui la risoluzione dei conflitti di merge nei file con estensione razor e nei file con estensione cshtml generava una finestra vuota. | ticket di feedback |
Azure Devops Permalink da Visual Studio 2022 non funziona. | ticket di feedback |
È stato risolto un problema per cui Visual Studio si arrestava in modo anomalo se la variabile di ambiente DOTNET_SYSTEM_GLOBALIZATION_INVARIANT era impostata su 1. | ticket di feedback |
Correzione dell'errore di avvio del profiler delle prestazioni per i progetti C++. | ticket di feedback |
Versione 17.12.2
rilasciato Novemeber 26th, 2024
Correzioni di bug principali | Dalla community |
---|---|
IntelliSense C++ non visualizza più errori per i progetti che funzionavano in IntelliSense in Visual Studio 17.11. | ticket di feedback |
Il processo dell'indicizzatore Copilot non blocca più i file. | ticket di feedback |
Correzione di un arresto anomalo del compilatore nel codice C++/CLI destinato a .NET Core e usa matrici param. | ticket di feedback |
note sulla versione di .NET per iOS/tvOS/macOS/macCatalyst | |
Dopo l'aggiornamento di Windows KB5041580, Visual Studio si arresta automaticamente all'apertura di una finestra dell'editor di merge. | ticket di feedback |
[LKG18] Alcune funzioni con wrapping ridotto contengono informazioni di rimozione incomplete nei frammenti secondari. | ticket di feedback |
Errore interno del compilatore C1001 per la build arm64. | ticket di feedback |
Arresto anomalo di SSDT con errore critico rilevato in VS17.12. | ticket di feedback |
Versione 17.12.1
rilasciato Novemeber 19th, 2024
Correzioni di bug principali | Dalla community |
---|---|
È stato risolto il problema di sintassi di sfarfallio del colore durante lo scorrimento tramite https://github.com/dotnet/roslyn/pull/75796 | |
Questa versione include gli aggiornamenti per mantenere la conformità alle leggi internazionali sulla lingua. |
Da tutti noi del team, grazie per aver scelto Visual Studio. Per eventuali domande, contattare Microsoft Twitter o Developer Community.
Codice felice!
il team di Visual Studio
Nota
Questo aggiornamento può includere un nuovo software Microsoft o di terze parti concesso in licenza separatamente, come indicato nella avvisi di terze parti o nella licenza associata.