DEV Community

Cover image for Debugging in .NET apps using Visual Studio Part 2
Hootan Hemmati
Hootan Hemmati

Posted on • Edited on

Debugging in .NET apps using Visual Studio Part 2

After fantastic snow in Tehran on the 12 February morning I'm writing my second part of Debugging in .Net.
Ok, let's think about snow and snowball, the snowball is round, and we shoot them to another.

Did you ever use breakpoints? If you do not, don't worry about that because we want to learn it from here.
Breakpoints are like a snowball, their circle, and we shoot in our program to stop right there and give us a look at what happens at our destination.

In the previous article, I explained breakpoints in basic, but here we want to do some cool stuff and learn new things in breakpoints.

Steps in Breakpoints

Looking at the top of the visual studio, you see the number of arrow icons. They are step arrows in our application (but keep it secret🤭).
Let's dive into our arrows and see what they are.

Image description

From left to right in the above picture, we have

  1. show next statement
  2. step in to (F11 keyboard shortcut key)
  3. step over (F10 keyboard shortcut key)
  4. step out (Shift + F11 keyboard shortcut key)
  5. step backward
  6. step forward

Show next statement: this action button moves your cursor to where the following line wants to execute.

Step in to: move you deeply into code when you have a method in your code. If you select this action button, it goes to the first line of the target method we want.

Step over: Like its name, it jumps over the extra detail in our specific block code. Like the previous example, if we select this action button, we jump from the method in the code and continue debugging after the method.

Step out: if we want to go out of our method, we use to step out to do this.

Step backward: go back to the previous step line.

Step forward: go forward to the last step line.

View results and different face shapes

When we debug our application and hover over variables, we see a little icon of the variable with the inside value.

Image description

This tool is called view result, which is our magnifier to analyze our variable to what's inside it.
With the magnifier icon side of it, we can see the detail of what we have in our variable in a large window.

We have an option inside of our magnifier, and it is called text. When we hover over that, we can see the options to choose from and determine what type we want our big window to show us.

Image description

Edit and continue debugging

Image description

We have an option in the visual studio called edit on continue in debug section that allows us to change our code and run directly in our debug mode without stopping and starting our application again.

Condition Breakpoints

Condition breakpoints are one of the best features in the visual studio, and this feature allows us to enter the breakpoints whenever our conditions happen in our code.

We can set conditions breakpoints by following these steps in our visual studio :

  1. Set a regular breakpoint on the line of code where you want to pause.
  2. Right-click on the breakpoint and select Condition from the menu.
  3. Enter an expression that evaluates to true or false in the field.
  4. Click OK.

After that, our breakpoints change the shape to the plus button, meaning we have condition breakpoints here.
You can edit or remove the Condition by right-clicking on the breakpoint again and selecting Condition from the menu.

Image description

If you want to log the particular value of the variable in the console, you can check the Actions checkbox and insert the name of the variable you want to print in the output.

After we click the Actions checkbox, you can see that our breakpoints look different, like a diamond shape.
After we run our application, if our program hits the breakpoint, we can see that our action breakpoints are working and printing the values.

Image description

We can see several different conditions breakpoints below picture.

Image description

Hit count breakpoints mean that we can calculate the loop in our programs, and when it is hit the fifth time in the breakpoint, it must be active.

Now we want to talk about function breakpoints. Imagine you have thousands of functions overloading in your C# application. What do you want to do to set the breakpoint side of each implementation?

The first way is manual, and we must find the implementation and drop the breakpoint there, but there is another intelligent way to do that: to use function breakpoints. Function breakpoints get the method name and set the breakpoint in each overloading implementation.

Image description

Export Breakpoints

Share your breakpoints with your team or specific person with the export breakpoints feature in visual studio.

If you want to select just one of the breakpoints in the list, you can right-click on the breakpoints you want and select export selected breakpoint.

Top comments (2)

Collapse
 
bseyfi profile image
Behzad Seyfi

Nice article, thanks!

Collapse
 
hootanht profile image
Hootan Hemmati

Thanks a lot dear Behzad