> Java > java지도 시간 > Java는 메소드 삭제로 인한 과부하 충돌을 어떻게 방지합니까?

Java는 메소드 삭제로 인한 과부하 충돌을 어떻게 방지합니까?

DDD
풀어 주다: 2024-12-17 11:35:24
원래의
523명이 탐색했습니다.

How Does Java Prevent Overload Conflicts Caused by Method Erasure?

메서드 삭제를 통한 오버로드 방지

Java 코드에서는 두 메소드의 삭제가 동일하다는 오류가 발생할 수 있습니다. 이 오류를 이해하려면 다음 예를 고려하십시오.

class Test {
  void add(Set<Integer> ii) {}
  void add(Set<String> ss) {}
}
로그인 후 복사

컴파일러는 두 개의 add 메소드가 동일한 삭제를 갖는다는 오류를 생성합니다. 이는 유형 매개변수를 제거하기 위해 두 메소드를 모두 지운 후 둘 다 시그니처 add(Set)를 갖기 때문입니다.

어떤 경우에는 이러한 메소드의 논리가 겹쳐서 단일 제네릭으로 대체하고 싶은 유혹이 생길 수 있습니다.

public void add(Set<?> set) {}
로그인 후 복사

그러나 이것이 항상 가능한 것은 아닙니다. 또한 생성자 이름 변경이 허용되지 않기 때문에 이러한 유형의 인수를 사용하는 두 생성자를 생성하려고 시도할 때 이 접근 방식은 문제가 됩니다.

레거시 코드 호환성

그 이유 동일한 삭제를 사용하는 여러 메소드는 허용되지 않습니다. 이는 원시 유형을 사용하는 레거시 코드와의 호환성을 유지하려는 Java의 목표에서 비롯됩니다. 예를 들어 제네릭이 도입되기 전에 작성된 다음 클래스를 생각해 보세요.

class CollectionConverter {
  List toList(Collection c) {...}
}
로그인 후 복사

하위 클래스가 이 클래스를 확장하고 제네릭 없이 toList 메서드를 재정의하는 경우:

class Overrider extends CollectionConverter {
  List toList(Collection c) {...}
}
로그인 후 복사

제네릭 도입 후 , 일반 유형으로 toList 메소드를 업데이트하면 원시 메소드가 효과적으로 대체됩니다.

class CollectionConverter {
  <T> List<T> toList(Collection<T> c) {...}
}
로그인 후 복사

하위 클래스가 다음과 같이 편집된 경우 원시 및 일반 toList 메소드를 모두 포함합니다.

class Overrider extends CollectionConverter {
  @Override
  List toList(Collection c) {...}
  @Override
  <T> List<T> toList(Collection<T> c) {...}
}
로그인 후 복사

두 메소드 모두 기술적으로 일반 toList 메소드를 재정의하여 컴파일러가 해결할 수 없는 모호성을 만듭니다.

이러한 혼란을 방지하기 위해 Java는 다음을 수행합니다. 클래스가 동일한 삭제로 여러 메서드를 갖는 것을 허용하지 않으므로 프로그래머는 신중하게 디자인을 고려하고 적절한 경우 일반 유형을 활용해야 합니다.

위 내용은 Java는 메소드 삭제로 인한 과부하 충돌을 어떻게 방지합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿