Java 7에서 Java 8로 업그레이드하면 읽기 작업 중에 스트림 종료를 나타내는 예외가 발생할 수 있습니다. 이는 종료 스레드가 스트림을 보유하는 개체에 대해 finalize()를 호출한 후 닫히기 때문에 발생합니다.
제공된 코드를 고려하면 MIMEBodyPart로 확장된 HTTPMessage의 finalize() 메서드는 close()를 호출합니다. 연관된 스트림을 닫습니다. MIMEWriter.writePart()를 실행하는 동안 IOUtils.copy는 고갈될 때까지 입력 스트림에서 청크를 읽습니다.
IOUtils.copy가 실행되는 동안 HTTPMessage.finalize()가 실행되면 문제가 발생하여 스트림이 닫힙니다. 예외. MIMEBodyPart 객체가 스택 프레임에서 도달할 수 있는 동안 JVM은 finalize()를 호출합니다. 이 동작은 당혹스럽습니다.
잠재적 설명
로컬 스택 변수 및 활성 메서드 호출의 개체에 대한 참조가 있어도 "도달할 수 없는 것으로 간주되는 경우 개체를 마무리하고 가비지 수집할 수 있습니다." ." 객체에 접근할 수 없는 경우 후속 코드는 해당 참조와 상호 작용하지 않습니다.
이 특정한 경우 MimeBodyPart 객체는 로컬 변수에 저장될 수 있습니다. IOUtils.copy의 후속 코드는 MimeBodyPart 객체를 참조하지 않으므로 JVM은 해당 객체에 도달할 수 없는 것으로 간주하여 종료를 트리거할 수 있습니다.
예제 및 코드 수정
예제가 제공됩니다. 활성 메서드 호출 중에 개체를 마무리하는 방법을 보여줍니다. stack.
또한 로컬 변수 대신 필드에 FinalizeThis 객체에 대한 참조를 보유하도록 코드를 수정하면 종료가 관찰됩니다.
결론
모범 사례에 따라 finalize()를 사용하지 않는 것이 좋습니다. 그러나 특정 상황에서는 Java 8이 도달 가능한 객체를 마무리하는 것이 가능합니다. 이는 코드를 검토하고 객체 마무리와 관련된 예외 문제를 해결할 때 고려해야 합니다.
위 내용은 강력하게 연결 가능한 Java 객체가 Java 8에서 완성된 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!