>Java >java지도 시간 >Spring- : 왜 스프링-캐나트 매치별로의 주입

Spring- : 왜 스프링-캐나트 매치별로의 주입

DDD
DDD원래의
2025-01-28 22:08:11209검색

스프링 의존 주입 : 왜 이름과 자동으로 일치 할 수 없습니까? spring-: why-spring-cannot-match-by-name-for-injection 스프링의 종속성 주입 메커니즘은 주로 이름이 아닌 유형

를 기반으로합니다. 동일한 유형의 여러 유형 (예 : TenantDatasource)을 만나면 매개 변수 이름에 따라 자동으로 일치하지 않습니다. 스프링이 메소드의 매개 변수 이름을 콩 이름과 일치하도록 항상 보장 할 수는 없기 때문입니다.

Java 기본적으로

는 컴파일 된 바이트 코드에서 매개 변수 이름

를 유지하지 않습니다. 특수 구성이없는 경우, 컴파일 중에 매개 변수 이름 (예 : TenantAdatasource 및 TenantBdatasource)이 지워지고 Arg0 및 Arg1과 같은 범용 이름으로 대체됩니다. 따라서 Spring은 Tenantadatasource가 "Tenanta-Datasource"라는 콩을 지칭한다는 것을 알 수 없습니다. 매개 변수 이름 유지 문제를 해결하십시오 컴파일러 로고를 사용하여 바이트 코드에서 매개 변수 이름을 유지할 수 있습니다. 이 로고를 사용하더라도 구성이 명확하지 않으면 스프링이 여전히 매개 변수 이름과 일치하지 않습니다.

봄은 사고를 방지하기위한 가정을 피합니다. 예를 들어, 매개 변수 이름이 실수로 교환되거나 명명되었거나 개발자가 다른 매핑을 기대하면 어떻게됩니까? 명확한 지침이없는 경우 (예 : ), Spring은 개발자의 의도를 결정할 수 없으며 잘못된 Bean을 주입하는 대신 오류를 던지도록 선택할 수 없습니다.

봄은 "숨겨진 것보다 명시 적으로 더 나은"원리를 따릅니다. 종속 주입은 예측 가능해야하며, 매개 변수 이름의 가정에 의존하지 않습니다. 스프링은 다른 환경과 프레임 워크에서 일관성이 있습니다. 일부 언어 또는 프레임 워크 (예 : Kotlin)는 기본적으로 매개 변수 이름을 유지하지만 다른 언어는 유지되지 않으므로 스프링은 종속 매개 변수 이름을 피합니다. 이름 일치는 언제 자동으로 작동 할 수 있습니까? 스프링은 기본적으로 매개 변수 이름과 일치하지 않지만 경우에 따라 매개 변수 이름에 따라 일치 할 수 있지만 설정에 따라 다릅니다. 스프링 4.3 매개 변수 이름 발견

로고가 코드를 컴파일하면 모호성이 있으면 스프링은 매개 변수 이름에서 Bean의 이름을 유추 할 수 있습니다.

> 예 :

로고 및 매개 변수 이름 (Tenantadatasource, TenantBdatasource)과 콩 이름이 일치하면 스프링은 모호성을 해결할 수 있습니다. 그러나이 동작은 복잡한 구성에서 항상 신뢰할 수 있거나 예측 가능하지는 않으므로 선호하는 디스플레이 구성 (예 : )입니다.

왜 스프링이 @Qualifier를 사용하는 경향이 있습니까? -parameters 를 사용하여

를 사용하여 정의를 보장하고 모호성을 제거하여 개발자와 프레임 워크가 명확하게 의도 할 수 있도록합니다.
<code>javac -parameters MyClass.java</code>
> 예 :

이런 식으로 스프링은 매개 변수 이름이나 다른 요인에 관계없이 어떤 콩을 주입 해야하는지 정확하게 알 수 있습니다.

봄이 더 똑똑해야합니까?

일부 사람들은 스프링과 같은 프레임 워크가 더 똑똑해야한다고 생각할 수 있으며, 모호성이있을 때 콩 이름이 매개 변수 이름과 자동으로 일치합니다. 그러나 : <.>

뒤로 호환성

:이 동작을 자동으로 변경하면 Bean 이름과 매개 변수 이름과 일치하지 않는 기존 응용 프로그램이 파괴 될 수 있습니다.

예측 가능성
    : 개발자가 항상 어떤 콩이 주입되는지 알 수 있도록 모호성을 명시 적으로 해결합니다. 반응 가능한 가정은 특히 대규모 복잡한 응용 분야에서 디버깅에 어려움을 초래할 수 있습니다.
  1. 실제 장면의 상황 대부분의 실제 응용 분야에서 개발자는 의미있는 콩 이름과 매개 변수 이름을 사용하지만 명확성을 보장하기 위해
  2. 를 선호합니다.
  3. 멀티 샘플 장면의 경우 또는 또는 @Qualifier 기반 메소드 (예 : AbstractroutingAtasorce)를 동적으로 구성하여 각 Bean을 수동으로 연결합니다.

키 포인트

스프링 첫 번째 주입 유형 : 한 유형의 콩 만 있으면 스프링이 아무런 문제없이 주입합니다. 동일한 유형의 콩이 여러 개있는 경우 스프링에는 모호성을 해결하기 위해 추가 프롬프트 (예 :

)가 필요합니다.

매개 변수 이름은 에 신뢰할 수 없습니다. 기본적으로 매개 변수 이름은 Java Bytecode에 보관되지 않으므로 Spring은 매개 변수와 일치하는 데 사용할 수 없습니다. 매개 변수 이름 ()이 유지 되더라도 구성이 명확하지 않은 한 스프링은 잘 알려진 일치 일치를 피할 수 있습니다.
    명시 적은 숨겨진 것보다 낫습니다.
  • Spring 's Design Concept @Qualifier

위 내용은 Spring- : 왜 스프링-캐나트 매치별로의 주입의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
이전 기사:Spring- : @-depth 구성다음 기사:Spring- : @-depth 구성