MSDN Library
콘텐츠의 테이블 축소
콘텐츠의 테이블 확장
정보
요청한 주제가 아래에 표시됩니다. 그러나 이 주제는 이 라이브러리에 포함되지 않습니다.

EndOfStreamException 클래스

2013-12-13

읽을 때 발생되는 예외가 스트림의 끝을 지나 시도됩니다.

System.Object
  System.Exception
    System.SystemException
      System.IO.IOException
        System.IO.EndOfStreamException

Namespace:  System.IO
어셈블리:  mscorlib(mscorlib.dll)

public class EndOfStreamException : IOException

EndOfStreamException 형식에서는 다음과 같은 멤버를 노출합니다.

  이름설명
Public 메서드EndOfStreamException()시스템 제공 메시지로 설정된 메시지 문자열을 사용하여 EndOfStreamException 클래스의 새 인스턴스를 초기화합니다.
Public 메서드EndOfStreamException(String)message로 설정된 메시지 문자열과 COR_E_ENDOFSTREAM으로 설정된 HRESULT를 사용하여 EndOfStreamException 클래스의 새 인스턴스를 초기화합니다.
Public 메서드EndOfStreamException(String, Exception)지정된 오류 메시지와 해당 예외의 근본 원인인 내부 예외에 대한 참조를 사용하여 EndOfStreamException 클래스의 새 인스턴스를 초기화합니다.
맨 위

  이름설명
Public 속성Data예외에 대한 사용자 정의 추가 정보를 제공하는 키/값 쌍의 컬렉션을 가져옵니다. (Exception에서 상속됨)
Public 속성HelpLink이 예외와 관련된 도움말 파일에 대한 링크를 가져오거나 설정합니다. (Exception에서 상속됨)
Public 속성HResult특정 예외에 할당된 코드화된 숫자 값인 HRESULT를 가져오거나 설정합니다. (Exception에서 상속됨)
Public 속성InnerException현재 예외를 발생시킨 Exception 인스턴스를 가져옵니다. (Exception에서 상속됨)
Public 속성Message현재 예외를 설명하는 메시지를 가져옵니다. (Exception에서 상속됨)
Public 속성Source오류를 발생시키는 응용프로그램 또는 개체의 이름을 가져오거나 설정합니다. (Exception에서 상속됨)
Public 속성StackTrace현재 예외가 발생된 시간에 호출 스택의 프레임에 대한 문자열 표현을 가져옵니다. (Exception에서 상속됨)
맨 위

  이름설명
Public 메서드Equals(Object)지정한 Object가 현재 Object와 같은지 확인합니다. (Object에서 상속됨)
Protected 메서드Finalize가비지 수집기에서 Object를 회수하기 전에 개체가 리소스를 해제하고 다른 정리 작업을 수행할 수 있게 합니다. (Object에서 상속됨)
Public 메서드GetBaseException파생 클래스에서 재정의되었을 때, 하나 이상의 후속 예외의 근본 원인이 되는 Exception을 반환합니다. (Exception에서 상속됨)
Public 메서드GetHashCode특정 형식에 대한 해시 함수 역할을 합니다. (Object에서 상속됨)
Public 메서드GetType현재 인스턴스의 런타임 형식을 가져옵니다. (Exception에서 상속됨)
Protected 메서드MemberwiseClone현재 Object의 단순 복사본을 만듭니다. (Object에서 상속됨)
Public 메서드ToString현재 예외에 대한 문자열 표현을 만들고 반환합니다. (Exception에서 상속됨)
맨 위

EndOfStreamException은 0x80070026 값을 가지는 HRESULT COR_E_ENDOFSTREAM을 사용합니다.

다음 코드 예제에서는 MemoryStream 클래스의 맨 위에 있는 BinaryReaderBinaryWriter 클래스를 사용하여 Double 데이터를 읽고 메모리에 쓰는 방법을 보여 줍니다.

참고참고:

이 예제를 실행하려면 Windows Phone용 정적 TextBlock 컨트롤이 있는 예제 빌드를 참조하세요.


using System;
using System.IO;

class Example
{
   public static void Demo(System.Windows.Controls.TextBlock outputBlock)
   {
      int i;
      const int arrayLength = 1000;

      // Create random data to write to the stream.
      Random randomGenerator = new Random();
      double[] dataArray = new double[arrayLength];
      for (i = 0; i < arrayLength; i++)
      {
         dataArray[i] = 100.1 * randomGenerator.NextDouble();
      }

      using (BinaryWriter binWriter =
          new BinaryWriter(new MemoryStream()))
      {
         // Write the data to the stream.
         outputBlock.Text += "Writing data to the stream." + "\n";
         for (i = 0; i < arrayLength; i++)
         {
            binWriter.Write(dataArray[i]);
         }

         // Create a reader using the stream from the writer.
         using (BinaryReader binReader =
             new BinaryReader(binWriter.BaseStream))
         {
            try
            {
               // Return to the beginning of the stream.
               binReader.BaseStream.Position = 0;

               // Read and verify the data.
               outputBlock.Text += "Verifying the written data." + "\n";
               for (i = 0; i < arrayLength; i++)
               {
                  if (binReader.ReadDouble() != dataArray[i])
                  {
                     outputBlock.Text += "Error writing data." + "\n";
                     break;
                  }
               }
               outputBlock.Text += "The data was written " +
                   "and verified." + "\n";
            }
            catch (EndOfStreamException e)
            {
               outputBlock.Text += String.Format("Error writing data: {0}.",
                   e.GetType().Name) + "\n";
            }
         }
      }
   }
}


Windows Phone OS

지원되는 버전: 8.0, 7.1, 7.0

Windows Phone

이 형식의 모든 공용 static(Visual Basic의 경우 Shared) 멤버는 스레드로부터 안전합니다. 모든 인스턴스 멤버는 스레드로부터 안전하지 않을 수 있습니다.

표시:
© 2016 Microsoft