Throwable.AddSuppressed(Throwable) 메서드

정의

이 예외를 전달하기 위해 표시되지 않은 예외에 지정된 예외를 추가합니다.

[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).

이 페이지의 일부는 만들고 공유하며 에 설명된 조건에 따라 사용되는 작업을 기반으로 수정됩니다.

적용 대상