try/catch 블록을 사용하여 예외를 catch하는 방법

예외를 발생시키거나 throw할 수 있는 모든 코드 문을 try 블록에 배치하고, 예외를 처리하는 데 사용되는 명령문을 try 블록 아래에 있는 하나 이상의 catch 블록에 배치합니다. 각 catch 블록은 예외 형식을 포함하고 해당 예외 형식을 처리하는 데 필요한 추가 명령문을 포함할 수 있습니다.

다음 예제에서 StreamReaderdata.txt라는 파일을 열고 해당 파일에서 줄을 검색합니다. 코드는 세 가지 예외 중 하나를 throw할 수 있으므로 try 블록에 위치합니다. 세 개 catch 블록이 예외를 catch하고 콘솔에 결과를 표시하여 예외를 처리합니다.

using namespace System;
using namespace System::IO;

public ref class ProcessFile
{
public:
    static void Main()
    {
        try
        {
            StreamReader^ sr = File::OpenText("data.txt");
            Console::WriteLine("The first line of this file is {0}", sr->ReadLine());
            sr->Close();
        }
        catch (Exception^ e)
        {
            Console::WriteLine("An error occurred: '{0}'", e);
        }
    }
};

int main()
{
    ProcessFile::Main();
}
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 블록에서 처리되지 않은 예외를 catch합니다. CLR에서 예외를 catch하는 경우 CLR 구성에 따라 다음 결과 중 하나가 발생할 수 있습니다.

  • 디버그 대화 상자가 나타납니다.
  • 프로그램이 실행을 중지하고 예외 정보가 포함된 대화 상자가 나타납니다.
  • 오류가 표준 오류 출력 스트림으로 출력됩니다.

참고 항목

대부분의 코드가 예외를 throw할 수 있고, OutOfMemoryException과 같은 일부 예외는 언제든지 CLR에서 throw될 수 있습니다. 애플리케이션은 이러한 예외를 처리할 필요가 없지만 다른 사용자가 사용할 라이브러리를 작성하는 경우 이러한 가능성에 유의해야 합니다. try 블록에서 코드를 설정하는 경우에 대한 제안 사항은 예외에 대한 모범 사례를 참조하세요.

참고 항목