|
1 | 1 | /*
|
2 |
| - * Copyright 2002-2014 the original author or authors. |
| 2 | + * Copyright 2002-2015 the original author or authors. |
3 | 3 | *
|
4 | 4 | * Licensed under the Apache License, Version 2.0 (the "License");
|
5 | 5 | * you may not use this file except in compliance with the License.
|
|
17 | 17 | package org.springframework.beans.factory.annotation;
|
18 | 18 |
|
19 | 19 | import java.lang.reflect.Method;
|
20 |
| -import java.util.Map; |
21 | 20 |
|
22 | 21 | import org.springframework.beans.factory.BeanFactory;
|
23 | 22 | import org.springframework.beans.factory.BeanFactoryUtils;
|
@@ -77,19 +76,19 @@ else if (beanFactory.containsBean(qualifier)) {
|
77 | 76 | * @throws NoSuchBeanDefinitionException if no matching bean of type {@code T} found
|
78 | 77 | */
|
79 | 78 | private static <T> T qualifiedBeanOfType(ConfigurableListableBeanFactory bf, Class<T> beanType, String qualifier) {
|
80 |
| - Map<String, T> candidateBeans = BeanFactoryUtils.beansOfTypeIncludingAncestors(bf, beanType); |
81 |
| - T matchingBean = null; |
82 |
| - for (String beanName : candidateBeans.keySet()) { |
| 79 | + String[] candidateBeans = BeanFactoryUtils.beanNamesForTypeIncludingAncestors(bf, beanType); |
| 80 | + String matchingBean = null; |
| 81 | + for (String beanName : candidateBeans) { |
83 | 82 | if (isQualifierMatch(qualifier, beanName, bf)) {
|
84 | 83 | if (matchingBean != null) {
|
85 | 84 | throw new NoSuchBeanDefinitionException(qualifier, "No unique " + beanType.getSimpleName() +
|
86 | 85 | " bean found for qualifier '" + qualifier + "'");
|
87 | 86 | }
|
88 |
| - matchingBean = candidateBeans.get(beanName); |
| 87 | + matchingBean = beanName; |
89 | 88 | }
|
90 | 89 | }
|
91 | 90 | if (matchingBean != null) {
|
92 |
| - return matchingBean; |
| 91 | + return bf.getBean(matchingBean, beanType); |
93 | 92 | }
|
94 | 93 | else if (bf.containsBean(qualifier)) {
|
95 | 94 | // Fallback: target bean at least found by bean name - probably a manually registered singleton.
|
|
0 commit comments