Tutorial: Depuración de una aplicación de consola de .NET mediante Visual Studio
En este tutorial se presentan las herramientas de depuración disponibles en Visual Studio.
Importante
Todos los métodos abreviados de teclado se basan en los valores predeterminados de Visual Studio. Los métodos abreviados de teclado pueden variar, para obtener más información, consulte Métodos abreviados de teclado en Visual Studio.
Prerrequisitos
- Este tutorial funciona con la aplicación de consola que se crea en Creación de una aplicación de consola de .NET mediante Visual Studio.
Uso de la configuración de compilación de depuración
Debug y Release son las configuraciones de compilación integradas de Visual Studio. Use la configuración de compilación Depuración para depurar y la configuración de compilación Versión para la distribución final de la versión.
En la configuración de depuración, un programa se compila con información de depuración simbólica completa y sin optimización. La optimización complica la depuración, ya que la relación entre el código fuente y las instrucciones generadas es más compleja. La configuración de versión del programa no contiene información de depuración simbólica y está totalmente optimizada.
De forma predeterminada, Visual Studio usa la configuración de compilación Depuración, por lo que no es necesario cambiarla antes de depurar.
Inicie Visual Studio.
Abra el proyecto que creó en Creación de una aplicación de consola de .NET mediante Visual Studio.
La configuración de compilación actual se muestra en la barra de herramientas. La siguiente imagen de barra de herramientas muestra que Visual Studio está configurado para compilar la versión de depuración de la aplicación:
Establecer un punto de interrupción
Un punto de interrupción interrumpe temporalmente la ejecución de la aplicación antes de que se ejecute la línea con el punto de interrupción.
Establezca un punto de interrupción en la línea que muestre el nombre, la fecha y la hora; para ello, haga clic en el margen izquierdo de la ventana de código de esa línea. El margen izquierdo está a la izquierda de los números de línea. Otras maneras de establecer un punto de interrupción consisten en colocar el cursor en la línea de código y, después, presionar F9 o seleccionar Depurar>Alternar punto de interrupción en la barra de menú.
Como se muestra en la imagen siguiente, Visual Studio indica la línea en la que se establece el punto de interrupción resaltando y mostrando un punto rojo en el margen izquierdo.
Presione F5 para ejecutar el programa en modo de depuración. Otra manera de comenzar a depurar es seleccionando en el menú la opción Depurar>Iniciar depuración.
Cuando el sistema le pida un nombre, escriba una cadena en la ventana de consola y luego presione Entrar.
La ejecución del programa se detiene cuando alcanza el punto de interrupción y antes de que se ejecute el método
Console.WriteLine
. La ventana Variables locales muestra los valores de las variables definidas en el método que se está ejecutando actualmente.
Uso de la ventana Inmediato
La ventana Inmediato le permite interactuar con la aplicación que está depurando. Puede cambiar interactivamente el valor de las variables para ver cómo afecta al programa.
Si la ventana Inmediato no está visible, muéstrela; para ello, elija Depurar>Ventanas>Inmediato.
Escriba
name = "Gracie"
en la ventana Inmediato y presione la tecla Entrar.Escriba
currentDate = DateTime.Parse("2019-11-16T17:25:00Z").ToUniversalTime()
en la ventana Inmediato y presione la tecla Entrar.La ventana Inmediato muestra el valor de la variable de cadena y las propiedades del valor DateTime. Además, los valores de las variables se actualizan en la ventana Variables locales.
Presione F5 para continuar la ejecución del programa. Otra manera de hacerlo es elegir Depuración>Continuar en el menú.
Los valores mostrados en la ventana de la consola corresponden a los cambios realizados en la ventana Inmediato.
ventana consola de
Presione cualquier tecla para salir de la aplicación y detenga la depuración.
Establecimiento de un punto de interrupción condicional
El programa muestra la cadena que escribe el usuario. ¿Qué ocurre si el usuario no escribe nada? Puede probarlo con una característica de depuración muy útil denominada Punto de interrupción condicional.
Haga clic con el botón derecho en el punto rojo que representa el punto de interrupción. En el menú contextual, seleccione Condiciones para abrir el cuadro de diálogo Configuración del punto de interrupción. Active la casilla Condiciones si aún no está seleccionada.
En la expresión condicional , escriba el código siguiente en el campo que contiene el código de ejemplo que comprueba si
x
es 5.string.IsNullOrEmpty(name)
String.IsNullOrEmpty(name)
Cada vez que se alcanza el punto de interrupción, el depurador invoca el método
String.IsNullOrEmpty(name)
, y se detiene en esta línea solo si la invocación del método devuelvetrue
.En lugar de una expresión condicional, puede especificar un contador de ejecuciones, que interrumpe la ejecución del programa antes de que una instrucción se ejecute un número especificado de veces. Otra opción consiste en especificar una condición de filtro , que interrumpe la ejecución del programa en función de estos atributos como un identificador de subproceso, un nombre de proceso o un nombre de subproceso.
Seleccione Cerrar para cerrar el cuadro de diálogo.
Inicie el programa con la depuración presionando F5.
En la ventana de consola, cuando se le pida que escriba su nombre, presione la tecla Entrar.
Dado que se ha cumplido la condición especificada (
name
esnull
o String.Empty), la ejecución del programa se detiene cuando alcanza el punto de interrupción y antes de que se ejecute el métodoConsole.WriteLine
.Seleccione la ventana Variables locales, que muestra los valores de las variables que son locales para el método que se está ejecutando actualmente. En este caso,
Main
es el método que se está ejecutando actualmente. Observe que el valor de la variablename
es""
o String.Empty.Confirme que el valor es una cadena vacía escribiendo la siguiente instrucción en la ventana Inmediato y presionando Entrar. El resultado es
true
.? name == String.Empty
? String.IsNullOrEmpty(name)
El signo de interrogación dirige la ventana Inmediato para evaluar una expresión.
Presione F5 para continuar la ejecución del programa.
Presione cualquier tecla para cerrar la ventana de consola y detener la depuración.
Borre el punto de interrupción haciendo clic en el punto del margen izquierdo de la ventana de código. Otras formas de borrar un punto de interrupción consisten en presionar F9 o elegir Depurar > Alternar punto de interrupción mientras se selecciona la línea de código.
Ejecución paso a paso de un programa
Visual Studio también le permite recorrer paso a paso línea por línea a través de un programa y supervisar su ejecución. Normalmente, establecería un punto de interrupción y seguiría el flujo del programa a través de una pequeña parte del código del programa. Como este programa es pequeño, puede ejecutar paso a paso el programa entero.
Elija Depurar>Depurar paso a paso por instrucciones. Otra manera de depurar una instrucción cada vez es presionar F11.
Visual Studio resalta y muestra una flecha situada junto a la siguiente línea de ejecución.
C#
Visual Basic
En este momento, la ventana Variables locales muestra que la matriz de
args
está vacía yname
ycurrentDate
tienen valores predeterminados. Además, Visual Studio ha abierto una ventana de consola en blanco.Presione F11. Visual Studio ahora resalta la siguiente línea de ejecución. La ventana Variables locales no cambia y la ventana de consola permanece en blanco.
C#
Visual Basic
Presione F11. Visual Studio resalta la instrucción que incluye la asignación de variables
name
. La ventana Variables locales muestra quename
esnull
y la ventana de consola muestra la cadena "¿Cuál es tu nombre?".Para responder a la solicitud, escriba una cadena en la ventana de consola y presione Entrar. La consola no responde y la cadena especificada no se muestra en la ventana de la consola, pero el método Console.ReadLine capturará la entrada.
Presione F11. Visual Studio resalta la instrucción que incluye la asignación de variables
currentDate
. La ventana Variables locales muestra el valor devuelto por la llamada al método Console.ReadLine. La ventana de la consola también muestra la cadena que escribió en la solicitud.Presione F11. La ventana Variables locales muestra el valor de la variable
currentDate
tras la asignación desde la propiedad DateTime.Now. La ventana de la consola no cambia.Presione F11. Visual Studio llama al método Console.WriteLine(String, Object, Object). La ventana de la consola muestra la cadena con formato.
Elija Depurar>Depurar paso a paso para salir. Otra manera de detener la ejecución paso a paso es presionar Mayús+F11.
La ventana de la consola muestra un mensaje y espera a que presione una tecla.
Presione cualquier tecla para cerrar la ventana de consola y detener la depuración.
Uso de la configuración de compilación de versión
Una vez que ha probado la versión de depuración de la aplicación, también debe compilar y probar la versión de lanzamiento. La versión release incorpora optimizaciones del compilador que a veces pueden afectar negativamente al comportamiento de una aplicación. Por ejemplo, las optimizaciones del compilador diseñadas para mejorar el rendimiento pueden crear condiciones de carrera en aplicaciones multiproceso.
Para compilar y probar la versión de lanzamiento de la aplicación de la consola, cambie la configuración de compilación en la barra de herramientas de Depurar a Versión.
Cuando presiona F5 o elije Compilar solución en el menú Compilar, Visual Studio compila la versión de lanzamiento de la aplicación. Puedes probarlo igual que hiciste con la versión Debug.
Pasos siguientes
En este tutorial, usaste las herramientas de depuración de Visual Studio. En el siguiente tutorial, publicará una versión implementable de la aplicación.