Självstudie: Felsöka ett .NET-konsolprogram med Visual Studio för Mac

Viktigt!

Microsoft har meddelat att Visual Studio för Mac upphör. Visual Studio för Mac stöds inte längre från och med den 31 augusti 2024. Alternativen är:

Mer information finns i Visual Studio för Mac-meddelande om pensionering.

I den här självstudien beskrivs de felsökningsverktyg som är tillgängliga i Visual Studio för Mac.

Förutsättningar

Använda konfiguration av felsökningsversion

Felsökning och lansering är Visual Studio inbyggda byggkonfigurationer. Du använder konfigurationen Felsökningsversion för felsökning och versionskonfigurationen för den slutliga versionsdistributionen.

I felsökningskonfigurationen kompileras ett program med fullständig symbolisk felsökningsinformation och ingen optimering. Optimeringen komplicerar felsökningen eftersom relationen mellan källkod och genererade instruktioner är mer komplex. Versionskonfigurationen för ett program har ingen symbolisk felsökningsinformation och är helt optimerad.

Visual Studio för Mac använder som standard konfigurationen för felsökningsversion, så du behöver inte ändra den innan du felsöker.

  1. Starta Visual Studio för Mac.

  2. Öppna projektet som du skapade i Skapa ett .NET-konsolprogram med Visual Studio för Mac.

    Den aktuella byggkonfigurationen visas i verktygsfältet. Följande verktygsfältsbild visar att Visual Studio är konfigurerat för att kompilera felsökningsversionen av appen:

    Visual Studio toolbar with debug highlighted

Ange en brytpunkt

En brytpunkt avbryter tillfälligt körningen av programmet innan raden med brytpunkten körs.

  1. Ange en brytpunkt på raden som visar namn, datum och tid. Det gör du genom att placera markören på kodraden och trycka på \ ⌘ (kommando).+\ Ett annat sätt att ange en brytpunkt är genom att välja Växla brytpunkt för felsökning>på menyn.

    Visual Studio anger den rad där brytpunkten anges genom att markera den och visa en röd punkt i vänstermarginalen.

    Visual Studio Program window with breakpoint set

  2. Tryck ⌘↵ (kommando+retur) för att starta programmet i felsökningsläge. Ett annat sätt att börja felsöka är genom att välja Felsöka>Starta felsökning från menyn.

  3. Ange en sträng i terminalfönstret när programmet frågar efter ett namn och tryck sedan på Retur.

  4. Programkörningen stoppas när den når brytpunkten innan Console.WriteLine metoden körs.

    Screenshot of a breakpoint in Visual Studio

Använd fönstret Omedelbart

Med fönstret Omedelbar kan du interagera med det program som du felsöker. Du kan interaktivt ändra värdet för variabler för att se hur det påverkar ditt program.

  1. Om fönstret Omedelbart inte visas visar du det genom att välja Visa>felsökning av Windows>Omedelbart.

  2. Ange name = "Gracie" i fönstret Omedelbart och tryck på Retur.

  3. Ange currentDate = currentDate.AddDays(1) i fönstret Omedelbart och tryck på Retur.

    Fönstret Omedelbart visar det nya värdet för strängvariabeln och egenskaperna för DateTime värdet.

    Immediate Window in Visual Studio

    Fönstret Lokalt visar värdena för variabler som definieras i metoden som körs just nu. Värdena för de variabler som du just har ändrat uppdateras i fönstret Lokal .

    Locals Window in Visual Studio

  4. Tryck ⌘↵ (kommandot+anger) för att fortsätta felsökningen.

    Värdena som visas i terminalen motsvarar de ändringar du gjorde i fönstret Omedelbart .

    Om du inte ser terminalen väljer du Terminal – HelloWorld i det nedre navigeringsfältet.

    Terminal - Hello World in bottom navigation bar

  5. Tryck på valfri tangent för att avsluta programmet.

  6. Stäng terminalfönstret.

Ange en villkorsstyrd brytpunkt

Programmet visar en sträng som användaren anger. Vad händer om användaren inte anger något? Du kan testa detta med en användbar felsökningsfunktion som kallas villkorlig brytpunkt.

  1. ctrl-klicka på den röda punkt som representerar brytpunkten. I snabbmenyn väljer du Redigera brytpunkt.

  2. I dialogrutan Redigera brytpunkt anger du följande kod i fältet som följer Och följande villkor är sant och väljer Tillämpa.

    String.IsNullOrEmpty(name)
    

    Editor showing breakpoint settings panel

    Varje gång brytpunkten slås anropar String.IsNullOrEmpty(name) felsökningsprogrammet metoden och den bryts endast på den här raden om metodanropet returnerar true.

    I stället för ett villkorsuttryck kan du ange ett antal träffar, vilket avbryter programkörningen innan en instruktion körs ett angivet antal gånger.

  3. Tryck ⌘↵ (kommando+retur) för att börja felsöka.

  4. I terminalfönstret trycker du på Retur när du uppmanas att ange ditt namn.

    Eftersom villkoret du angav (name är antingen null eller String.Empty) har uppfyllts stoppas programkörningen när den når brytpunkten.

  5. Välj fönstret Lokal , som visar värdena för variabler som är lokala för den metod som körs just nu. I det här fallet Main är den metod som körs för närvarande. Observera att värdet för variabeln name är "", d.v.s String.Empty. .

  6. Du kan också se att värdet är en tom sträng genom att ange name variabelnamnet i fönstret Omedelbart och trycka på Retur.

    Immediate window showing name is an empty string

  7. Tryck ⌘↵ (kommandot+anger) för att fortsätta felsökningen.

  8. I terminalfönstret trycker du på valfri tangent för att avsluta programmet.

  9. Stäng terminalfönstret.

  10. Rensa brytpunkten genom att klicka på den röda punkten i vänstermarginalen i kodfönstret. Ett annat sätt att rensa en brytpunkt är genom att välja Växla brytpunkt för felsökning > medan kodraden är markerad.

Stega igenom ett program

Med Visual Studio kan du också stega rad för rad genom ett program och övervaka dess körning. Vanligtvis anger du en brytpunkt och följer programflödet genom en liten del av programkoden. Eftersom det här programmet är litet kan du gå igenom hela programmet.

  1. Ange en brytpunkt på klammerparentesen som markerar början av Main metoden (tryck på kommandot+\).

  2. Tryck ⌘↵ (kommando+retur) för att börja felsöka.

    Visual Studio stannar på raden med brytpunkten.

  3. Tryck ⇧⌘I (skiftkommando++I) eller välj Felsöka>Steg till för att gå vidare med en rad.

    Visual Studio markerar och visar en pil bredvid nästa körningsrad.

    Visual Studio step into method

    Nu visar fönstret Locals att matrisen args är tom och namecurrentDate har standardvärden. Dessutom har Visual Studio öppnat en tom terminal.

  4. Tryck på ⇧⌘I (skiftkommando++I).

    Visual Studio visar instruktionen som innehåller variabeltilldelningen name . Fönstret Locals visar att name är null, och terminalen visar strängen "Vad är ditt namn?".

  5. Svara på uppmaningen genom att ange en sträng i konsolfönstret och trycka på Retur.

  6. Tryck på ⇧⌘I (skiftkommando++I).

    Visual Studio visar instruktionen som innehåller variabeltilldelningen currentDate . Fönstret Locals visar det värde som returneras av anropet till Console.ReadLine metoden. Terminalen visar strängen som du angav i kommandotolken.

  7. Tryck på ⇧⌘I (skiftkommando++I).

    Fönstret Lokala värden visar värdet för variabeln currentDate efter tilldelningen DateTime.Now från egenskapen. Terminalen är oförändrad.

  8. Tryck på ⇧⌘I (skiftkommando++I).

    Visual Studio anropar Console.WriteLine(String, Object, Object) metoden. Terminalen visar den formaterade strängen.

  9. Tryck ⇧⌘U (skiftkommando++U) eller välj Kör>steg ut.

    Terminalen visar ett meddelande och väntar på att du ska trycka på en tangent.

  10. Tryck på valfri tangent för att avsluta programmet.

Använda Versionsversionskonfiguration

När du har testat felsökningsversionen av ditt program bör du också kompilera och testa versionsversionen. Versionsversionen innehåller kompilatoroptimeringar som kan påverka beteendet för ett program negativt. Kompilatoroptimeringar som är utformade för att förbättra prestanda kan till exempel skapa konkurrensvillkor i flertrådade program.

Utför följande steg för att skapa och testa versionen av konsolprogrammet:

  1. Ändra byggkonfigurationen i verktygsfältet från Felsökning till Version.

    default Visual Studio toolbar with release highlighted

  2. Tryck på ⌥⌘ (alternativkommando+retur+) för att köra utan felsökning.

Nästa steg

I den här självstudien använde du Felsökningsverktyg för Visual Studio. I nästa självstudie publicerar du en distributionsbar version av appen.