이 문서에서는 단계별 연습에서 Visual Studio 디버거의 기능을 소개합니다. 디버거 기능의 상위 수준 보기를 원하는 경우 먼저 디버거살펴보세요. 앱을 디버그할 때 일반적으로 디버거가 연결된 애플리케이션을 실행하고 있음을 의미합니다. 이 작업을 수행할 때 디버거는 코드가 실행되는 동안 수행하는 작업을 확인하는 여러 가지 방법을 제공합니다. 코드를 단계별로 실행하고 변수에 저장된 값을 살펴보고, 변수에 대한 감시를 설정하여 값이 변경되는 시기를 확인하고, 코드의 실행 경로를 검사하고, 코드 분기가 실행 중인지 등을 확인할 수 있습니다. 이 연습이 처음으로 코드를 디버그하려고 시도하는 경우 이 문서를 진행하기 전에 절대 초보자를 위한 디버깅 을 읽어보는 것이 좋습니다.
데모 앱은 Visual Basic이지만 대부분의 기능은 C#, C++, F#, Python, JavaScript 및 Visual Studio에서 지원하는 기타 언어에 적용됩니다(F#에서는 편집 및 계속을 지원하지 않음). F# 및 JavaScript는 자동 창을 지원하지 않습니다.) 스크린샷은 Visual Basic에 있습니다.
이 자습서에서는 다음을 수행합니다.
- 디버거를 시작하고 중단점을 만납니다.
- 디버거에서 코드를 단계별로 실행하기 위한 명령 알아보기
- 데이터 팁 및 디버거 창에서 변수 검사
- 호출 스택 검사
필수 조건
Visual Studio 2019와 .NET Core 플랫폼 간 개발 워크로드가 설치되어 있어야 합니다.
Visual Studio를 아직 설치하지 않은 경우 Visual Studio 다운로드 페이지로 이동하여 무료로 설치합니다.
워크로드를 설치해야 하지만 Visual Studio가 이미 있는 경우 도구>가져오기 도구 및 기능...으로 이동하여 Visual Studio 설치 관리자를 엽니다. Visual Studio 설치 관리자가 시작됩니다. .NET 데스크톱 개발 워크로드를 선택한 후 수정을 클릭하세요.
프로젝트 만들기
먼저 .NET Core 콘솔 애플리케이션 프로젝트를 만듭니다. 프로젝트 유형은 아무것도 추가하기 전에 필요한 모든 템플릿 파일을 제공합니다.
Visual Studio를 엽니다. 시작 창이 열려 있지 않으면 파일>시작 창을 선택합니다.
시작 창에서 새 프로젝트 만들기를 선택합니다.
새 프로젝트 만들기 창의 검색 상자에 콘솔을 입력합니다. 다음으로 언어 목록에서 Visual Basic 을 선택한 다음 플랫폼 목록에서 Windows 를 선택합니다.
언어 및 플랫폼 필터를 적용한 후 .NET Core용 콘솔 앱 템플릿을 선택한 다음, 다음을 선택합니다.
비고
콘솔 앱 템플릿이 표시되지 않으면 새 프로젝트 만들기 창에서 설치할 수 있습니다. 원하는 항목을 찾지 못하시겠습니까? 메시지에서 추가 도구 및 기능 설치 링크를 선택합니다. 그런 다음 Visual Studio 설치 관리자에서 .NET 데스크톱 개발 워크로드를 선택합니다.
새 프로젝트 구성 창의 프로젝트 이름 상자에 get-started-debugging을 입력합니다. 그런 후에 다음을 선택합니다.
추가 정보 창의 프레임워크 드롭다운 메뉴에서 .NET 8.0이 선택되어 있는지 확인하고 만들기를 선택합니다.
Visual Studio에서 새 프로젝트를 엽니다.
애플리케이션 만들기
Program.vb 모든 기본 코드를 대신 다음 코드로 바꿉다.
Imports System
Class ArrayExample
Public Shared Sub Main()
Dim letters As Char() = {"f"c, "r"c, "e"c, "d"c, " "c, "s"c, "m"c, "i"c, "t"c, "h"c}
Dim name As String = ""
Dim a As Integer() = New Integer(9) {}
For i As Integer = 0 To letters.Length - 1
name += letters(i)
a(i) = i + 1
SendMessage(name, a(i))
Next
Console.ReadKey()
End Sub
Private Shared Sub SendMessage(ByVal name As String, ByVal msg As Integer)
Console.WriteLine("Hello, " & name & "! Count to " & msg)
End Sub
End Class
디버거를 시작합니다.
F5 키를 누르거나(디버그 > 시작 디버깅) 디버그 도구 모음에서 녹색 디버깅 시작 단추를 선택합니다.
F5 는 앱 프로세스에 연결된 디버거로 앱을 시작하지만, 지금은 코드를 검사하기 위해 특별한 작업을 수행하지 않았습니다. 따라서 앱이 로드되고 콘솔 출력이 표시됩니다.
Hello, f! Count to 1 Hello, fr! Count to 2 Hello, fre! Count to 3 Hello, fred! Count to 4 Hello, fred ! Count to 5 Hello, fred s! Count to 6 Hello, fred sm! Count to 7 Hello, fred smi! Count to 8 Hello, fred smit! Count to 9 Hello, fred smith! Count to 10이 자습서에서는 디버거를 사용하여 이 앱을 자세히 살펴보고 디버거 기능을 살펴보겠습니다.
(Shift + F5) 키를 눌러 디버거를 중지하거나 디버그 도구 모음에서 빨간색 디버깅 중지 단추를 선택합니다.
콘솔 창에서 키를 눌러 콘솔 창을 닫습니다.
중단점 설정 및 디버거 시작
For함수 루프Main에서 다음 코드 줄의 왼쪽 여백을 클릭하여 중단점을 설정합니다.name += letters(i)중단점을 설정하는 빨간색 원이 나타납니다.
중단점은 신뢰할 수 있는 디버깅의 가장 기본적이고 필수적인 기능 중 하나입니다. 중단점은 변수 값이나 메모리 동작을 살펴볼 수 있도록 Visual Studio에서 실행 중인 코드를 일시 중단해야 하는 위치 또는 코드 분기가 실행되고 있는지 여부를 나타냅니다.
디버그 도구 모음에서 F5 (디버그 > 시작 디버깅) 또는 디버깅 시작 단추를 누르면 앱이 시작되고 디버거가 중단점을 설정한 코드 줄로 실행됩니다.
노란색 화살표는 디버거가 일시 중지된 문을 나타내며, 동일한 지점에서 앱 실행을 일시 중단합니다(이 문은 아직 실행되지 않음).
앱이 아직 실행되지 않는 경우 F5 는 디버거를 시작하고 첫 번째 중단점에서 중지합니다. 그렇지 않은 경우 F5 는 다음 중단점까지 앱을 계속 실행합니다.
중단점은 코드 줄 또는 자세히 검사하려는 코드 섹션을 알고 있는 경우 유용한 기능입니다. 조건부 중단점과 같이 설정할 수 있는 다양한 유형의 중단점에 대한 자세한 내용은 중단점 사용을 참조하세요.
단계 명령을 사용하여 디버거에서 코드 탐색
이 문서에서는 디버거에서 앱을 빠르게 실행하는 좋은 방법이기 때문에 바로 가기 키를 사용합니다(메뉴 명령과 같은 동일한 명령은 괄호로 표시됨).
코드 실행이
For루프에서Main메서드 내에 일시 중지될 때, F11 키를 두 번 눌러서 또는 디버그 > 단계별 진입을 선택하여SendMessage메서드 호출로 진행합니다.F11 키를 두 번 누르면 다음 코드 줄에 있어야 합니다.
SendMessage(name, a(i))F11 키를 한 번 더 눌러 메서드를 한 단계씩 실행합니다
SendMessage.노란색 포인터가
SendMessage메서드로 들어갑니다.
F11 은 Step Into 명령으로, 앱 실행을 한 문씩 진행합니다. F11 은 실행 흐름을 가장 자세하게 검사하는 좋은 방법입니다. (코드를 통해 더 빠르게 이동하기 위해 몇 가지 다른 옵션도 보여 줍니다.) 기본적으로 디버거는 비사용자 코드를 건너뜁니다(자세한 내용은 내 코드만 참조).
메서드 검사를
SendMessage마친 후, 메서드에서 벗어나면서도 디버거에 계속 머물고 싶다고 가정해 보겠습니다. 이 작업은 Step Out 명령을 사용하여 수행할 수 있습니다.Shift + F11 (또는 디버그 > 스텝 아웃)을 누릅니다.
이 명령은 현재 메서드 또는 함수가 반환될 때까지 앱 실행을 다시 시작하고 디버거를 진행합니다.
For루프에서Main메서드로 돌아가SendMessage메서드 호출 시 일시 중지되어 있어야 합니다.메서드 호출로 돌아갈 때까지 F11 키를
SendMessage여러 번 누릅니다.메서드 호출 시 코드 실행이 일시 중지되는 동안 F10 키를 한 번 누르거나 디버그 > 스텝오버를 선택합니다.
이번에는 디버거가
SendMessage메서드를 한 단계씩 실행하지 않습니다. F10 은 앱 코드에서 함수 또는 메서드를 한 단계씩 실행하지 않고 디버거를 진행합니다(코드는 계속 실행됨). F11 대신 메서드 호출에서SendMessage키를 눌러 구현 코드를SendMessage건너뜁니다(지금은 관심이 없을 수도 있음). 코드를 이동하는 다양한 방법에 대한 자세한 내용은 디버거코드 탐색을 참조하세요.
코드에서 클릭하여 탐색
F5 키를 눌러 중단점으로 다시 진행합니다.
코드 편집기에서 아래로 스크롤하여
Console.WriteLine메서드의SendMessage메서드를 마우스로 가리키면 녹색 클릭까지 실행 단추가 나타납니다. 단추의 도구 설명에는 "여기까지 실행"이 표시됩니다.
런 투 클릭 버튼을 선택합니다.
디버거가
Console.WriteLine메서드로 이동합니다.이 단추를 사용하는 것은 임시 중단점을 설정하는 것과 유사합니다. 클릭으로 실행 은 앱 코드의 표시되는 영역 내에서 빠르게 탐색하는 데 유용합니다(열려 있는 파일에서 선택할 수 있음).
앱을 빠르게 다시 시작합니다.
앱을 다시 시작하려면 Ctrl + Shift + F5 키 조합을 누르면 앱을 중지하고 디버거를 다시 시작하는 것과 시간을 절약할 수 있습니다. 디버거는 코드를 실행하여 적중된 첫 번째 중단점에서 일시 중지됩니다.
디버거는 이전에 루프 내에서 For 설정한 중단점에서 다시 중지됩니다.
데이터 팁을 사용하여 변수 검사
변수를 검사할 수 있는 기능은 디버거의 가장 유용한 기능 중 하나이며 다양한 방법으로 수행할 수 있습니다. 종종 문제를 디버그하려고 할 때 변수가 특정 시간에 가질 것으로 예상되는 값을 저장하고 있는지 확인하려고 합니다.
문에서
name += letters[i]코드 실행이 일시 중지되는 동안 변수를letters마우스로 가리키면 배열"f"c의 첫 번째 요소 값인 기본값이 표시됩니다.다음으로 변수를
name마우스로 가리키면 현재 값인 빈 문자열이 표시됩니다.F5 키(또는 계속 디버그>)를 몇 번 눌러 루프를
For여러 번 반복하고 중단점에서 다시 일시 중지하고 매번 변수를name마우스로 가리켜 값을 확인합니다.
변수 값은
For루프를 반복할 때마다 변경되어f값을 표시한 다음,fr,fre등의 값을 표시합니다.디버깅할 때 변수의 속성 값을 빠르게 확인하고, 변수가 저장하려는 값을 저장하고 있는지 확인하고, 데이터 팁이 이를 수행하는 좋은 방법입니다.
자동 및 지역 창으로 변수 검사
코드 편집기의 아래쪽에 있는 자동 창을 살펴봅 니다 .
닫힌 경우 디버거에서 코드 실행이 일시 중지되는 동안 Debug>Windows>Autos를 선택하여 엽니다.
자동 창에 변수와 해당 현재 값이 표시됩니다. 자동 창에는 현재 줄 또는 이전 줄에 사용된 모든 변수가 표시됩니다(언어별 동작에 대한 설명서 확인).
다음으로 자동 창 옆 탭으로 로컬 창을 살펴보십시오.
변수를
letters확장하여 포함된 요소를 표시합니다.
Locals 창에는 현재 범위, 즉 현재 실행 컨텍스트에 있는 변수가 표시됩니다.
시계 설정
코드를 단계별로 실행할 때 감시 창에 추가하여 주시하려는 변수 또는 식을 지정할 수 있습니다.
디버거가 일시 중지된 동안
name변수를 마우스 오른쪽 버튼으로 클릭하여 조사식 추가를 선택합니다.기본적으로 코드 편집기 아래쪽에 Watch 창이 열립니다.
이제 변수에 대한
name감시를 설정했으므로 코드를 단계별로 실행하여 각name루프 반복에 따라 변수의for값이 변경되는지 확인합니다.다른 변수 창과 달리 감시 창에는 항상 관찰 중인 변수들이 표시됩니다. 범위를 벗어난 변수는 사용할 수 없는 것으로 표시됩니다.
감시식 창에 대한 자세한 내용은 감시식 창으로 변수 감시하기를 참조하세요.
호출 스택 검사
코드 실행이 루프에서
For일시 중지되는 동안 오른쪽 아래 창에서 기본적으로 열려 있는 호출 스택 창을 선택합니다.닫혀 있는 경우, 디버거에서 코드 실행이 일시 중지된 동안 디버그>윈도우>호출 스택을 선택하여 엽니다.
메서드에서 디버거가 일시 중지될 때까지 F11 을
SendMessage몇 번 선택합니다. 호출 스택 창을 살펴봅니다.
호출 스택 창에는 메서드 및 함수가 호출되는 순서가 표시됩니다. 위쪽 줄에는 현재 함수(이 앱의
SendMessage메서드)가 표시됩니다. 두 번째 줄은SendMessage가Main메서드에서 호출되었다는 것을 보여줍니다.비고
호출 스택 창은 Eclipse와 같은 일부 IDE의 디버그 큐브 뷰와 비슷합니다.
호출 스택은 앱의 실행 흐름을 검사하고 이해하는 좋은 방법입니다.
코드 줄을 두 번 클릭하여 해당 소스 코드를 살펴보고 디버거에서 검사 중인 현재 범위도 변경할 수 있습니다. 이 작업은 디버거를 다음 단계로 이동시키지 않습니다.
호출 스택 창에서 마우스 오른쪽 단추 클릭 메뉴를 사용하여 다른 작업을 수행할 수도 있습니다. 예를 들어 지정된 함수에 중단점을 삽입하고 커서로 실행을 사용하여 디버거를 진행한 다음 소스 코드를 검사 할 수 있습니다. 자세한 내용은 방법: 호출 스택 검사를 참조하세요.
실행 흐름 변경
F11 키를 두 번 눌러 메서드를 실행합니다
Console.WriteLine.메서드 호출 중
SendMessage에서 디버거가 일시 중지된 상태에서, 마우스를 사용하여 왼쪽 여백에 있는 노란색 화살표 또는 실행 포인터를 잡고, 포인터를Console.WriteLine문으로 한 줄 위까지 끕니다.F11 키를 누릅니다.
디버거는 메서드를 다시 실행합니다
Console.WriteLine(콘솔 창 출력에 이 작업이 표시됨).실행 흐름을 변경하여 디버거를 다시 시작하지 않고 다른 코드 실행 경로를 테스트하거나 코드를 다시 실행하는 등의 작업을 수행할 수 있습니다.
경고
이 기능에 주의해야 하는 경우가 많으며 도구 설명에 경고가 표시됩니다. 다른 경고도 표시될 수 있습니다. 포인터를 이동하면 애플리케이션을 이전 앱 상태로 되돌릴 수 없습니다.
F5 키를 눌러 앱을 계속 실행합니다.
이 자습서를 완료해 주셔서 감사합니다.
다음 단계
이 자습서에서는 디버거를 시작하고, 코드를 단계별로 실행하고, 변수를 검사하는 방법을 알아보았습니다. 자세한 정보에 대한 링크와 함께 디버거 기능을 개략적으로 살펴볼 수 있습니다.
먼저 디버거 살펴보기