try
블록에는 예외를 발생시키거나 throw할 가능성이 있는 코드 문을 배치하고, catch
블록 아래에 try
블록 하나 이상을 두어 예외를 처리하는 문을 배치합니다. 각 catch
블록은 예외 형식을 포함하며 해당 예외 유형을 처리하는 데 필요한 추가 문을 포함할 수 있습니다.
다음 예제 StreamReader 에서는 data.txt 파일을 열고 파일에서 줄을 검색합니다. 코드는 세 가지 예외 중 어느 것을 발생시킬 수 있으므로 해당 try
블록에 배치됩니다. 세 개의 catch
블록은 예외를 포착하고 콘솔에 결과를 표시하여 처리합니다.
using System;
using System.IO;
public class ProcessFile
{
public static void Main()
{
try
{
using (StreamReader sr = File.OpenText("data.txt"))
{
Console.WriteLine($"The first line of this file is {sr.ReadLine()}");
}
}
catch (FileNotFoundException e)
{
Console.WriteLine($"The file was not found: '{e}'");
}
catch (DirectoryNotFoundException e)
{
Console.WriteLine($"The directory was not found: '{e}'");
}
catch (IOException e)
{
Console.WriteLine($"The file could not be opened: '{e}'");
}
}
}
Imports System.IO
Public Class ProcessFile
Public Shared Sub Main()
Try
Using sr As StreamReader = File.OpenText("data.txt")
Console.WriteLine($"The first line of this file is {sr.ReadLine()}")
End Using
Catch e As FileNotFoundException
Console.WriteLine($"The file was not found: '{e}'")
Catch e As DirectoryNotFoundException
Console.WriteLine($"The directory was not found: '{e}'")
Catch e As IOException
Console.WriteLine($"The file could not be opened: '{e}'")
End Try
End Sub
End Class
CLR(공용 언어 런타임)은 catch
블록으로 처리되지 않는 예외를 처리합니다. CLR에서 예외를 catch하는 경우 CLR 구성에 따라 다음 결과 중 하나가 발생할 수 있습니다.
- 디버그 대화 상자가 나타납니다.
- 프로그램이 실행을 중지하고 예외 정보가 있는 대화 상자가 나타납니다.
- 오류가 표준 오류 출력 스트림에 출력됩니다.
비고
대부분의 코드는 예외를 throw할 수 있으며, CLR 자체에 의해 언제든지 throw될 수 있는 예외(예: OutOfMemoryException일부 예외)가 있습니다. 애플리케이션에서 이러한 예외를 처리할 필요는 없지만 다른 사용자가 사용할 라이브러리를 작성할 때 발생할 수 있습니다. 블록에서 try
코드를 설정하는 시기에 대한 제안 사항은 예외에 대한 모범 사례를 참조하세요.
참고하십시오
GitHub에서 Microsoft와 공동 작업
이 콘텐츠의 원본은 GitHub에서 찾을 수 있으며, 여기서 문제와 끌어오기 요청을 만들고 검토할 수도 있습니다. 자세한 내용은 참여자 가이드를 참조하세요.
.NET