Throwable.AddSuppressed(Throwable) 메서드
정의
중요
일부 정보는 릴리스되기 전에 상당 부분 수정될 수 있는 시험판 제품과 관련이 있습니다. Microsoft는 여기에 제공된 정보에 대해 어떠한 명시적이거나 묵시적인 보증도 하지 않습니다.
이 예외를 전달하기 위해 표시되지 않은 예외에 지정된 예외를 추가합니다.
[Android.Runtime.Register("addSuppressed", "(Ljava/lang/Throwable;)V", "")]
public void AddSuppressed (Java.Lang.Throwable exception);
[<Android.Runtime.Register("addSuppressed", "(Ljava/lang/Throwable;)V", "")>]
member this.AddSuppressed : Java.Lang.Throwable -> unit
매개 변수
- exception
- Throwable
표시되지 않는 예외 목록에 추가할 예외입니다.
- 특성
예외
이면 throwable == this
입니다.
이면 throwable == null
입니다.
설명
이 예외를 전달하기 위해 표시되지 않은 예외에 지정된 예외를 추가합니다. 이 메서드는 스레드로부터 안전하며 일반적으로 -with-resources 문에 의해 try
(자동 및 암시적으로) 호출됩니다.
제거 동작은 생성자를 통해 #Throwable(String, Throwable, boolean, boolean)을 사용하지 않도록 설정하지 않는 한<> 사용하도록>설정<됩니다. 억제를 사용하지 않도록 설정하면 이 메서드는 인수의 유효성을 검사하는 것 외에는 아무 작업도 수행하지 않습니다.
한 예외 #initCause(Throwable)으로 인해 다른 예외가 발생하면 첫 번째 예외가 일반적으로 catch된 다음 두 번째 예외가 응답으로 throw됩니다. 즉, 두 예외 사이에 인과 관계가 있습니다.
반면, 형제 코드 블록, 특히 -with-resources 문의 블록try
과 리소스를 닫는 컴파일러 생성 finally
블록에서 try
두 개의 독립적인 예외를 throw할 수 있는 상황이 있습니다.
이러한 상황에서는 throw된 예외 중 하나만 전파할 수 있습니다. -with-resources try
문에서 두 개의 예외가 있는 경우 블록에서 try
발생한 예외가 전파되고 블록의 finally
예외가 블록의 예외 try
로 표시되지 않는 예외 목록에 추가됩니다. 예외가 스택을 해제하면 표시되지 않는 여러 예외가 누적될 수 있습니다.
예외가 다른 예외로 인해 발생하는 동안 예외가 표시되지 않았을 수 있습니다. 예외에 원인이 있는지 여부는 예외가 throw된 후에만 일반적으로 결정되는 다른 예외를 표시하지 않는지 여부와 달리 예외를 만들 때 의미 체계적으로 알려져 있습니다.
프로그래머가 작성한 코드는 형제 예외가 여러 개 있고 하나만 전파될 수 있는 상황에서도 이 메서드를 호출할 수 있습니다.
1.7에 추가되었습니다.
에 대한 Java 설명서입니다 java.lang.Throwable.addSuppressed(java.lang.Throwable)
.
이 페이지의 일부는 만들고 공유하며 에 설명된 조건에 따라 사용되는 작업을 기반으로 수정됩니다.