成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

詳解Spring支持的各種數據類型的注入,你都用過哪些?

開發 前端
判斷是否有@Lazy注解,如果有該注解那么會創建代理對象,否則返回null,總結:如果注入的屬性有@Lazy注解,那么會返回由ProxyFactory對象創建的代理對象。

1 判斷類型

注入的屬性判斷其類型:

  1. Optional
  2. ObjectFactory
  3. ObjectProvider
  4. javax.inject.Provider
public class DefaultListableBeanFactory extends AbstractAutowireCapableBeanFactory implements ConfigurableListableBeanFactory, BeanDefinitionRegistry, Serializable {
    private static Class<?> javaxInjectProviderClass;


    static {
        try {
            javaxInjectProviderClass =
                    ClassUtils.forName("javax.inject.Provider", DefaultListableBeanFactory.class.getClassLoader());
        } catch (ClassNotFoundException ex) {
            javaxInjectProviderClass = null;
        }
    }
    public Object resolveDependency(DependencyDescriptor descriptor, @Nullable String requestingBeanName,
            @Nullable Set<String> autowiredBeanNames, @Nullable TypeConverter typeConverter) throws BeansException {
        if (Optional.class == descriptor.getDependencyType()) {
            return createOptionalDependency(descriptor, requestingBeanName);
        } else if (ObjectFactory.class == descriptor.getDependencyType() ||
                ObjectProvider.class == descriptor.getDependencyType()) {
            return new DependencyObjectProvider(descriptor, requestingBeanName);
        } else if (javaxInjectProviderClass == descriptor.getDependencyType()) {
            return new Jsr330Factory().createDependencyProvider(descriptor, requestingBeanName);
        } else {
            // 判斷是否有@Lazy注解,如果有該注解那么會創建代理對象,否則返回null
            // 總結:如果注入的屬性有@Lazy注解,那么會返回由ProxyFactory對象創建的代理對象
            Object result = getAutowireCandidateResolver().getLazyResolutionProxyIfNecessary(descriptor, requestingBeanName);
            if (result == null) {
                // 解析查找依賴注入的對象
                result = doResolveDependency(descriptor, requestingBeanName, autowiredBeanNames, typeConverter);
            }
            return result;
        }
    }
}

2 查找依賴對象

public class DefaultListableBeanFactory extends AbstractAutowireCapableBeanFactory implements ConfigurableListableBeanFactory, BeanDefinitionRegistry, Serializable {
  public Object doResolveDependency(DependencyDescriptor descriptor, @Nullable String beanName,
            @Nullable Set<String> autowiredBeanNames, @Nullable TypeConverter typeConverter) throws BeansException {
    InjectionPoint previousInjectionPoint = ConstructorResolver.setCurrentInjectionPoint(descriptor);
    try {
      Object shortcut = descriptor.resolveShortcut(this);
      if (shortcut != null) {
          return shortcut;
      }


      Class<?> type = descriptor.getDependencyType();


      // 判斷需要注入的類型是否是一個集合(如何:List<Users> beans)
      // 2.1 
      Object multipleBeans = resolveMultipleBeans(descriptor, beanName, autowiredBeanNames, typeConverter);
      if (multipleBeans != null) {
          return multipleBeans;
      }
      // 查找與所需類型匹配的bean實例
      // 2.2
      Map<String, Object> matchingBeans = findAutowireCandidates(beanName, type, descriptor);
      if (matchingBeans.isEmpty()) {
          if (isRequired(descriptor)) {
              raiseNoMatchingBeanFound(type, descriptor.getResolvableType(), descriptor);
          }
          return null;
      }


      String autowiredBeanName;
      Object instanceCandidate;


      // 如果找到多個
      if (matchingBeans.size() > 1) {
          // 在這里會判斷多個Bean中是否有一個@Primary注解的Bean
          // 如果沒有@Primary,繼續獲取是否有@Priority(優先級)注解
          // 如果沒有則返回null,如果有則返回值越小的優先級越高(如果有多個優先級一樣,則系統報錯)
          // 如果上面都返回的null,那么最后會通過beanName進行匹配
          autowiredBeanName = determineAutowireCandidate(matchingBeans, descriptor);
          if (autowiredBeanName == null) {
              if (isRequired(descriptor) || !indicatesMultipleBeans(type)) {
                  // 如果是必須的 或者 不是集合類型的Bean注入;那么這里拋出異常
                  return descriptor.resolveNotUnique(descriptor.getResolvableType(), matchingBeans);
              } else {
                  return null;
              }
          }
          instanceCandidate = matchingBeans.get(autowiredBeanName);
      } else {
          // We have exactly one match.
          Map.Entry<String, Object> entry = matchingBeans.entrySet().iterator().next();
          autowiredBeanName = entry.getKey();
          instanceCandidate = entry.getValue();
      }


      if (autowiredBeanNames != null) {
          autowiredBeanNames.add(autowiredBeanName);
      }
      if (instanceCandidate instanceof Class) {
          instanceCandidate = descriptor.resolveCandidate(autowiredBeanName, type, this);
      }
      Object result = instanceCandidate;
      if (result instanceof NullBean) {
          if (isRequired(descriptor)) {
              raiseNoMatchingBeanFound(type, descriptor.getResolvableType(), descriptor);
          }
          result = null;
      }
      if (!ClassUtils.isAssignableValue(type, result)) {
          throw new BeanNotOfRequiredTypeException(autowiredBeanName, type, instanceCandidate.getClass());
      }
      return result;
    } finally {
        ConstructorResolver.setCurrentInjectionPoint(previousInjectionPoint);
    }
  }
}

2.1 判斷集合類型

判斷需要注入的屬性的數據類型是否是如下幾種。

  1. StreamDependencyDescriptor
  2. Array
  3. Collection
  4. Map
public class DefaultListableBeanFactory extends AbstractAutowireCapableBeanFactory implements ConfigurableListableBeanFactory, BeanDefinitionRegistry, Serializable {
  private Object resolveMultipleBeans(DependencyDescriptor descriptor, @Nullable String beanName,
          @Nullable Set<String> autowiredBeanNames, @Nullable TypeConverter typeConverter) {


    Class<?> type = descriptor.getDependencyType();


    if (descriptor instanceof StreamDependencyDescriptor) {
      Map<String, Object> matchingBeans = findAutowireCandidates(beanName, type, descriptor);
      if (autowiredBeanNames != null) {
        autowiredBeanNames.addAll(matchingBeans.keySet());
      }
      Stream<Object> stream = matchingBeans.keySet().stream()
              .map(name -> descriptor.resolveCandidate(name, type, this))
              .filter(bean -> !(bean instanceof NullBean));
      if (((StreamDependencyDescriptor) descriptor).isOrdered()) {
        stream = stream.sorted(adaptOrderComparator(matchingBeans));
      }
      return stream;
    } else if (type.isArray()) {
      Class<?> componentType = type.getComponentType();
      ResolvableType resolvableType = descriptor.getResolvableType();
      Class<?> resolvedArrayType = resolvableType.resolve(type);
      if (resolvedArrayType != type) {
        componentType = resolvableType.getComponentType().resolve();
      }
      if (componentType == null) {
        return null;
      }
      Map<String, Object> matchingBeans = findAutowireCandidates(beanName, componentType, new MultiElementDescriptor(descriptor));
      if (matchingBeans.isEmpty()) {
        return null;
      }
      if (autowiredBeanNames != null) {
        autowiredBeanNames.addAll(matchingBeans.keySet());
      }
      TypeConverter converter = (typeConverter != null ? typeConverter : getTypeConverter());
      Object result = converter.convertIfNecessary(matchingBeans.values(), resolvedArrayType);
      if (result instanceof Object[]) {
        Comparator<Object> comparator = adaptDependencyComparator(matchingBeans);
        if (comparator != null) {
          Arrays.sort((Object[]) result, comparator);
        }
      }
      return result;
    } else if (Collection.class.isAssignableFrom(type) && type.isInterface()) {
      Class<?> elementType = descriptor.getResolvableType().asCollection().resolveGeneric();
      if (elementType == null) {
        return null;
      }
      Map<String, Object> matchingBeans = findAutowireCandidates(beanName, elementType,new MultiElementDescriptor(descriptor));
      if (matchingBeans.isEmpty()) {
        return null;
      }
      if (autowiredBeanNames != null) {
        autowiredBeanNames.addAll(matchingBeans.keySet());
      }
      TypeConverter converter = (typeConverter != null ? typeConverter : getTypeConverter());
      Object result = converter.convertIfNecessary(matchingBeans.values(), type);
      if (result instanceof List) {
        if (((List<?>) result).size() > 1) {
          Comparator<Object> comparator = adaptDependencyComparator(matchingBeans);
          if (comparator != null) {
              ((List<?>) result).sort(comparator);
          }
        }
      }
      return result;
    } else if (Map.class == type) {
      ResolvableType mapType = descriptor.getResolvableType().asMap();
      Class<?> keyType = mapType.resolveGeneric(0);
      if (String.class != keyType) {
        return null;
      }
      Class<?> valueType = mapType.resolveGeneric(1);
      if (valueType == null) {
        return null;
      }
      Map<String, Object> matchingBeans = findAutowireCandidates(beanName, valueType,new MultiElementDescriptor(descriptor));
      if (matchingBeans.isEmpty()) {
        return null;
      }
      if (autowiredBeanNames != null) {
        autowiredBeanNames.addAll(matchingBeans.keySet());
      }
      return matchingBeans;
    } else {
      return null;
    }
  }
}

2.2 查找Bean

public class DefaultListableBeanFactory extends AbstractAutowireCapableBeanFactory implements ConfigurableListableBeanFactory, BeanDefinitionRegistry, Serializable {
  protected Map<String, Object> findAutowireCandidates(
          @Nullable String beanName, Class<?> requiredType, DependencyDescriptor descriptor) {
    // 通過類型獲取指定類型的Bean
    String[] candidateNames = BeanFactoryUtils.beanNamesForTypeIncludingAncestors(
            this, requiredType, true, descriptor.isEager());
    Map<String, Object> result = CollectionUtils.newLinkedHashMap(candidateNames.length);
    // resolvableDependencies 集合中保存了,容器內置的和自定義注冊的依賴注入對象
    //(如:HttpServletRequest對象的注入為該集合內部指定的對象)
    for (Map.Entry<Class<?>, Object> classObjectEntry : this.resolvableDependencies.entrySet()) {
        Class<?> autowiringType = classObjectEntry.getKey();
      if (autowiringType.isAssignableFrom(requiredType)) {
        Object autowiringValue = classObjectEntry.getValue();
        autowiringValue = AutowireUtils.resolveAutowiringValue(autowiringValue, requiredType);
        if (requiredType.isInstance(autowiringValue)) {
          result.put(ObjectUtils.identityToString(autowiringValue), autowiringValue);
          break;
        }
      }
    }
    for (String candidate : candidateNames) {
      // 判斷是否自己引用自己
      if (!isSelfReference(beanName, candidate) && isAutowireCandidate(candidate, descriptor)) {
        addCandidateEntry(result, candidate, descriptor, requiredType);
      }
    }
    if (result.isEmpty()) {
      boolean multiple = indicatesMultipleBeans(requiredType);
      // Consider fallback matches if the first pass failed to find anything...
      DependencyDescriptor fallbackDescriptor = descriptor.forFallbackMatch();
      for (String candidate : candidateNames) {
        if (!isSelfReference(beanName, candidate) && isAutowireCandidate(candidate, fallbackDescriptor) &&
                (!multiple || getAutowireCandidateResolver().hasQualifier(descriptor))) {
          addCandidateEntry(result, candidate, descriptor, requiredType);
        }
      }
      if (result.isEmpty() && !multiple) {
        // Consider self references as a final pass...
        // but in the case of a dependency collection, not the very same bean itself.
        for (String candidate : candidateNames) {
          if (isSelfReference(beanName, candidate) &&
                  (!(descriptor instanceof MultiElementDescriptor) || !beanName.equals(candidate)) &&
                  isAutowireCandidate(candidate, fallbackDescriptor)) {
            addCandidateEntry(result, candidate, descriptor, requiredType);
          }
        }
      }
    }
    return result;
  }
}

以上就是Spring在注入屬性的時候會判斷是什么數據類型進行相應的操作

完畢!!!

責任編輯:武曉燕 來源: Spring全家桶實戰案例源碼
相關推薦

2011-07-01 15:32:58

Qt 數據類型

2024-02-22 08:15:49

Spring對象代理

2023-12-22 16:39:47

Java函數式接口開發

2023-11-22 07:42:01

2020-08-16 10:58:20

Pandaspython開發

2024-09-13 09:59:27

2020-08-23 09:18:30

Pandas函數數據分析

2023-01-28 10:27:04

2010-05-31 10:35:12

MySQL數據類型

2010-05-26 17:05:48

MySQL數據類型

2022-06-20 08:26:39

Spring容器類型轉換

2016-03-21 17:08:54

Java Spring注解區別

2024-11-07 12:33:47

2020-06-03 16:50:09

Node.js框架開發

2020-12-02 14:50:50

Windows 10Windows微軟

2023-04-06 07:49:23

Python數據類型

2011-08-24 13:23:35

Access 2010

2011-03-31 15:53:39

設計視圖Access

2009-06-12 12:56:29

Java類Java教程

2024-03-14 11:54:37

C++數據類型
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 在线不卡av | 麻豆天堂| 免费视频成人国产精品网站 | 免费一区二区三区在线视频 | 玖玖操| 狠狠做六月爱婷婷综合aⅴ 国产精品视频网 | 免费高清av | 91超碰caoporn97人人 | 五月天天色 | 天天干天天色 | 涩涩视频在线播放 | 国产精品久久免费观看 | 成人综合一区 | 亚洲免费一区二区 | 81精品国产乱码久久久久久 | 日本欧美在线视频 | 欧美日韩精品亚洲 | 亚欧洲精品在线视频免费观看 | 成人午夜免费视频 | 亚洲高清在线 | 国产精品精品 | 一区二区三区精品视频 | 欧美一区日韩一区 | 亚洲国产成人av好男人在线观看 | 精品99久久久久久 | 久草精品视频 | av毛片| 久久精品av麻豆的观看方式 | 成人亚洲 | 天堂在线免费视频 | 欧美不卡在线 | 久久亚洲综合 | 国产精品久久亚洲 | 搞av.com| 国产片一区二区三区 | 日韩一区二区在线播放 | 性高朝久久久久久久3小时 av一区二区三区四区 | 麻豆久久久9性大片 | 精品免费在线 | 日日夜夜精品免费视频 | 天堂一区二区三区 |