黄a在线观看-黄a在线-黄a大片-黄色片在线看-黄色毛片免费-黄色大片网站

您的位置:首頁技術文章
文章詳情頁

Spring IOC原理補充說明(循環依賴、Bean作用域等)

瀏覽:73日期:2023-08-18 18:31:05

前言

通過之前的幾篇文章將Spring基于XML配置的IOC原理分析完成,但其中還有一些比較重要的細節沒有分析總結,比如循環依賴的解決、作用域的實現原理、BeanPostProcessor的執行時機以及SpringBoot零配置實現原理(@ComponentScan、@Import、@ImportSource、@Bean注解的使用和解析)等等。下面就先來看看循環依賴是怎么解決的,在此之前一定要熟悉整個Bean的實例化過程,本篇只會貼出關鍵性代碼。

正文

循環依賴

首先來看幾個問題:

什么是循環依賴?

在熟悉了Bean實例化原理后,你會怎么解決循環依賴的問題?

Spring怎么解決循環依賴?有哪些循環依賴可以被解決?哪些又不能?

什么是循環依賴?

這個概念很容易理解,簡單說就是兩個類相互依賴,類似線程死鎖的問題,也就是當創建A對象時需要注入B的依賴對象,但B同時也依賴A,那到底該先創建A還是先創建B呢?

Spring是如何解決循環依賴的?

探究Spring的解決方法之前,我們首先得搞清楚Spring Bean有幾種依賴注入的方式:

通過構造函數

通過屬性

通過方法(不一定是setter方法,只要在方法上加上了@Autowired,都會進行依賴注入)

其次,Spring作用域有singleton、prototype、request、session等等,但在非單例模式下發生循環依賴是會直接拋出異常的,下面這個代碼不知道你還有沒有印象,在AbstractBeanFactory.doGetBean中有這個判斷:

if (isPrototypeCurrentlyInCreation(beanName)) { throw new BeanCurrentlyInCreationException(beanName);}

為什么這么設計呢?反過來想,如果不這么設計,你怎么知道循環依賴到底是依賴的哪個對象呢?搞清楚了這個再來看哪些依賴注入的方式發生循環依賴是可以解決,而那些又不能。結論是構造函數方式沒辦法解決循環依賴,其它兩種都可以。

我們先來看看為什么通過屬性注入和方法注入可以解決。回憶一下Bean的實例化過程:

protected Object doCreateBean(final String beanName, final RootBeanDefinition mbd, final @Nullable Object[] args) throws BeanCreationException { // Instantiate the bean. BeanWrapper instanceWrapper = null; if (mbd.isSingleton()) { instanceWrapper = this.factoryBeanInstanceCache.remove(beanName); } if (instanceWrapper == null) { //創建實例 instanceWrapper = createBeanInstance(beanName, mbd, args); } final Object bean = instanceWrapper.getWrappedInstance(); Class<?> beanType = instanceWrapper.getWrappedClass(); if (beanType != NullBean.class) { mbd.resolvedTargetType = beanType; } // Allow post-processors to modify the merged bean definition. synchronized (mbd.postProcessingLock) { if (!mbd.postProcessed) { try { // Bean實例化完成后收集類中的注解(@PostConstruct,@PreDestroy,@Resource, @Autowired,@Value) applyMergedBeanDefinitionPostProcessors(mbd, beanType, beanName); } catch (Throwable ex) { throw new BeanCreationException(mbd.getResourceDescription(), beanName, 'Post-processing of merged bean definition failed', ex); } mbd.postProcessed = true; } } // Eagerly cache singletons to be able to resolve circular references // even when triggered by lifecycle interfaces like BeanFactoryAware. // 單例bean提前暴露 boolean earlySingletonExposure = (mbd.isSingleton() && this.allowCircularReferences && isSingletonCurrentlyInCreation(beanName)); if (earlySingletonExposure) { if (logger.isTraceEnabled()) { logger.trace('Eagerly caching bean ’' + beanName + '’ to allow for resolving potential circular references'); } //這里著重理解,對理解循環依賴幫助非常大,重要程度 5 添加三級緩存 addSingletonFactory(beanName, () -> getEarlyBeanReference(beanName, mbd, bean)); } // Initialize the bean instance. Object exposedObject = bean; try { //ioc di,依賴注入的核心方法,該方法必須看 populateBean(beanName, mbd, instanceWrapper); //bean 實例化+ioc依賴注入完以后的調用,非常重要 exposedObject = initializeBean(beanName, exposedObject, mbd); } catch (Throwable ex) { if (ex instanceof BeanCreationException && beanName.equals(((BeanCreationException) ex).getBeanName())) { throw (BeanCreationException) ex; } else { throw new BeanCreationException( mbd.getResourceDescription(), beanName, 'Initialization of bean failed', ex); } } if (earlySingletonExposure) { Object earlySingletonReference = getSingleton(beanName, false); if (earlySingletonReference != null) { if (exposedObject == bean) { exposedObject = earlySingletonReference; } else if (!this.allowRawInjectionDespiteWrapping && hasDependentBean(beanName)) { String[] dependentBeans = getDependentBeans(beanName); Set<String> actualDependentBeans = new LinkedHashSet<>(dependentBeans.length); for (String dependentBean : dependentBeans) { if (!removeSingletonIfCreatedForTypeCheckOnly(dependentBean)) { actualDependentBeans.add(dependentBean); } } if (!actualDependentBeans.isEmpty()) { throw new BeanCurrentlyInCreationException(beanName, 'Bean with name ’' + beanName + '’ has been injected into other beans [' + StringUtils.collectionToCommaDelimitedString(actualDependentBeans) + '] in its raw version as part of a circular reference, but has eventually been ' + 'wrapped. This means that said other beans do not use the final version of the ' + 'bean. This is often the result of over-eager type matching - consider using ' + '’getBeanNamesOfType’ with the ’allowEagerInit’ flag turned off, for example.'); } } } } // Register bean as disposable. try { //注冊bean銷毀時的類DisposableBeanAdapter registerDisposableBeanIfNecessary(beanName, bean, mbd); } catch (BeanDefinitionValidationException ex) { throw new BeanCreationException( mbd.getResourceDescription(), beanName, 'Invalid destruction signature', ex); } return exposedObject; }

仔細看這個過程其實不難理解,首先Spring會通過無參構造實例化一個空的A對象,實例化完成后會調用addSingletonFactory存入到三級緩存中(注意這里存入的是singletonFactory對象):

protected void addSingletonFactory(String beanName, ObjectFactory<?> singletonFactory) { Assert.notNull(singletonFactory, 'Singleton factory must not be null'); synchronized (this.singletonObjects) { // 一級緩存 if (!this.singletonObjects.containsKey(beanName)) { System.out.println('========set value to 3 level cache->beanName->' + beanName + '->value->' + singletonFactory); // 三級緩存 this.singletonFactories.put(beanName, singletonFactory); // 二級緩存 this.earlySingletonObjects.remove(beanName); this.registeredSingletons.add(beanName); } } }

然后才會去依賴注入觸發類B的實例化,所以這時緩存中已經存在了一個空的A對象;同樣B也是通過無參構造實例化,B依賴注入又調用getBean獲取A的實例,而在創建對象之前,先是從緩存中獲取對象:

//從緩存中拿實例 Object sharedInstance = getSingleton(beanName); protected Object getSingleton(String beanName, boolean allowEarlyReference) { //根據beanName從緩存中拿實例 //先從一級緩存拿 Object singletonObject = this.singletonObjects.get(beanName); //如果bean還正在創建,還沒創建完成,其實就是堆內存有了,屬性還沒有DI依賴注入 if (singletonObject == null && isSingletonCurrentlyInCreation(beanName)) { synchronized (this.singletonObjects) { //從二級緩存中拿 singletonObject = this.earlySingletonObjects.get(beanName); //如果還拿不到,并且允許bean提前暴露 if (singletonObject == null && allowEarlyReference) { //從三級緩存中拿到對象工廠 ObjectFactory<?> singletonFactory = this.singletonFactories.get(beanName); if (singletonFactory != null) { //從工廠中拿到對象 singletonObject = singletonFactory.getObject(); //升級到二級緩存 System.out.println('======get instance from 3 level cache->beanName->' + beanName + '->value->' + singletonObject ); this.earlySingletonObjects.put(beanName, singletonObject); //刪除三級緩存 this.singletonFactories.remove(beanName); } } } } return singletonObject; }

很明顯,會從三級緩存中拿到singletonFactory對象并調用getObject方法,這是一個Lambda表達式,在表達式中又調用了getEarlyBeanReference方法:

protected Object getEarlyBeanReference(String beanName, RootBeanDefinition mbd, Object bean) { Object exposedObject = bean; if (!mbd.isSynthetic() && hasInstantiationAwareBeanPostProcessors()) { for (BeanPostProcessor bp : getBeanPostProcessors()) { if (bp instanceof SmartInstantiationAwareBeanPostProcessor) { SmartInstantiationAwareBeanPostProcessor ibp = (SmartInstantiationAwareBeanPostProcessor) bp; exposedObject = ibp.getEarlyBeanReference(exposedObject, beanName); } } } return exposedObject; }

這里你點進去看會發現都是返回之前我們創建的空的A對象,因此B對象能夠依賴注入完成并存入到一級緩存中,接著A對象繼續未完成的依賴注入自然是可以成功的,也存入到一級緩存中。Spring就是這樣通過緩存解決了循環依賴,但是不知道你注意到沒有在上面的getSingleton方法中,從三級緩存中拿到對象后,會添加到二級緩存并刪除三級緩存,這是為什么呢?這個二級緩存有什么用呢?

其實也很簡單,就是為了提高效率的,因為在getEarlyBeanReference方法中是循環調用BeanPostProcessor類的方法的,當只有一對一的依賴時沒有什么問題,但是當A和B相互依賴,A又和C相互依賴,A在注入完B觸發C的依賴注入時,這個循環還有必要么?讀者們可以自行推演一下整個過程。

至此,Spring是如何解決循環依賴的相信你也很清楚了,現在再來看通過構造函數依賴注入為什么不能解決循環依賴是不是也很清晰了?因為通過構造函數實例化并依賴注入是沒辦法緩存一個實例對象供依賴對象注入的。

作用域實現原理以及如何自定義作用域

作用域實現原理

在Spring中主要有reqest、session、singleton、prototype等等幾種作用域,前面我們分析了singleton創建bean的原理,是通過緩存來實現的,那么其它的呢?還是回到AbstractBeanFactory.doGetBean方法中來:

if (mbd.isSingleton()) { sharedInstance = getSingleton(beanName, () -> { try { return createBean(beanName, mbd, args); } catch (BeansException ex) { // Explicitly remove instance from singleton cache: It might have been put there // eagerly by the creation process, to allow for circular reference resolution. // Also remove any beans that received a temporary reference to the bean. destroySingleton(beanName); throw ex; } }); // 該方法是FactoryBean接口的調用入口 bean = getObjectForBeanInstance(sharedInstance, name, beanName, mbd);}else if (mbd.isPrototype()) { // It’s a prototype -> create a new instance. Object prototypeInstance = null; try { beforePrototypeCreation(beanName); prototypeInstance = createBean(beanName, mbd, args); } finally { afterPrototypeCreation(beanName); } // 該方法是FactoryBean接口的調用入口 bean = getObjectForBeanInstance(prototypeInstance, name, beanName, mbd);}else { String scopeName = mbd.getScope(); final Scope scope = this.scopes.get(scopeName); if (scope == null) { throw new IllegalStateException('No Scope registered for scope name ’' + scopeName + '’'); } try { Object scopedInstance = scope.get(beanName, () -> { beforePrototypeCreation(beanName); try { return createBean(beanName, mbd, args); } finally { afterPrototypeCreation(beanName); } }); // 該方法是FactoryBean接口的調用入口 bean = getObjectForBeanInstance(scopedInstance, name, beanName, mbd); }}

在singleton作用域下,會調用getSingleton方法,然后回調createBean創建對象,最終在getSingleton中完成緩存;而當scope為prototype時,可以看到是直接調用了createBean方法并返回,沒有任何的緩存操作,因此每次調用getBean都會創建新的對象,即使是同一個線程;除此之外都會進入到else片段中。

這個代碼也很簡單,首先通過我們配置的scopeName從scopes中拿到對應的Scope對象,如SessionScope和RequestScope(但這兩個只會在Web環境中被加載,在WebApplicationContextUtils.registerWebApplicationScopes可以看到注冊操作),然后調用對應的get方法存到對應的request或session對象中去。代碼很簡單,這里就不分析了。

自定義Scope

通過以上分析,不難發現我們是很容易實現一個自己的Scope的,首先實現Scope接口,然后將我們類的實例添加到scopes緩存中來,關鍵是怎么添加呢?在AbstractBeanFactory類中有一個registerScope方法就是干這個事的,因此我們只要拿到一個BeanFactory對象就行了,那要怎么拿?還記得在refresh中調用的invokeBeanFactoryPostProcessors方法么?因此我們只需要實現BeanFactoryPostProcessor接口就可以了,是不是So Easy!

BeanPostProcessor的執行時機

BeanPostProcessor執行點很多,根據其接口類型在不同的位置進行調用,只有熟記其執行時機,才能更好的進行擴展,這里以一張時序圖來總結:

Spring IOC原理補充說明(循環依賴、Bean作用域等)

SpringBoot零配置實現原理淺析

在SpringBoot項目中,省去了大量繁雜的xml配置,只需要使用@ComponentScan、@Configuration以及@Bean注解就可以達到和使用xml配置的相同效果,大大簡化了我們的開發,那這個實現原理是怎樣的呢?熟悉了xml解析原理,相信對于這種注解的方式基本上也能猜個大概。

首先我們進入到AnnotationConfigApplicationContext類,這個就是注解方式的IOC容器:

public AnnotationConfigApplicationContext(String... basePackages) { this(); scan(basePackages); refresh(); } public AnnotationConfigApplicationContext() { this.reader = new AnnotatedBeanDefinitionReader(this); this.scanner = new ClassPathBeanDefinitionScanner(this); }

這里ClassPathBeanDefinitionScanner在解析xml時出現過,就是用來掃描包找到合格的資源的;同時還創建了一個AnnotatedBeanDefinitionReader對象對應XmlBeanDefinitionReader,用來解析注解:

public AnnotatedBeanDefinitionReader(BeanDefinitionRegistry registry, Environment environment) { Assert.notNull(registry, 'BeanDefinitionRegistry must not be null'); Assert.notNull(environment, 'Environment must not be null'); this.registry = registry; this.conditionEvaluator = new ConditionEvaluator(registry, environment, null); AnnotationConfigUtils.registerAnnotationConfigProcessors(this.registry); } public static Set<BeanDefinitionHolder> registerAnnotationConfigProcessors( BeanDefinitionRegistry registry, @Nullable Object source) { DefaultListableBeanFactory beanFactory = unwrapDefaultListableBeanFactory(registry); if (beanFactory != null) { if (!(beanFactory.getDependencyComparator() instanceof AnnotationAwareOrderComparator)) { beanFactory.setDependencyComparator(AnnotationAwareOrderComparator.INSTANCE); } if (!(beanFactory.getAutowireCandidateResolver() instanceof ContextAnnotationAutowireCandidateResolver)) { beanFactory.setAutowireCandidateResolver(new ContextAnnotationAutowireCandidateResolver()); } } Set<BeanDefinitionHolder> beanDefs = new LinkedHashSet<>(8); if (!registry.containsBeanDefinition(CONFIGURATION_ANNOTATION_PROCESSOR_BEAN_NAME)) { RootBeanDefinition def = new RootBeanDefinition(ConfigurationClassPostProcessor.class); def.setSource(source); beanDefs.add(registerPostProcessor(registry, def, CONFIGURATION_ANNOTATION_PROCESSOR_BEAN_NAME)); } if (!registry.containsBeanDefinition(AUTOWIRED_ANNOTATION_PROCESSOR_BEAN_NAME)) { RootBeanDefinition def = new RootBeanDefinition(AutowiredAnnotationBeanPostProcessor.class); def.setSource(source); beanDefs.add(registerPostProcessor(registry, def, AUTOWIRED_ANNOTATION_PROCESSOR_BEAN_NAME)); } // Check for JSR-250 support, and if present add the CommonAnnotationBeanPostProcessor. if (jsr250Present && !registry.containsBeanDefinition(COMMON_ANNOTATION_PROCESSOR_BEAN_NAME)) { RootBeanDefinition def = new RootBeanDefinition(CommonAnnotationBeanPostProcessor.class); def.setSource(source); beanDefs.add(registerPostProcessor(registry, def, COMMON_ANNOTATION_PROCESSOR_BEAN_NAME)); } // Check for JPA support, and if present add the PersistenceAnnotationBeanPostProcessor. if (jpaPresent && !registry.containsBeanDefinition(PERSISTENCE_ANNOTATION_PROCESSOR_BEAN_NAME)) { RootBeanDefinition def = new RootBeanDefinition(); try { def.setBeanClass(ClassUtils.forName(PERSISTENCE_ANNOTATION_PROCESSOR_CLASS_NAME, AnnotationConfigUtils.class.getClassLoader())); } catch (ClassNotFoundException ex) { throw new IllegalStateException( 'Cannot load optional framework class: ' + PERSISTENCE_ANNOTATION_PROCESSOR_CLASS_NAME, ex); } def.setSource(source); beanDefs.add(registerPostProcessor(registry, def, PERSISTENCE_ANNOTATION_PROCESSOR_BEAN_NAME)); } if (!registry.containsBeanDefinition(EVENT_LISTENER_PROCESSOR_BEAN_NAME)) { RootBeanDefinition def = new RootBeanDefinition(EventListenerMethodProcessor.class); def.setSource(source); beanDefs.add(registerPostProcessor(registry, def, EVENT_LISTENER_PROCESSOR_BEAN_NAME)); } if (!registry.containsBeanDefinition(EVENT_LISTENER_FACTORY_BEAN_NAME)) { RootBeanDefinition def = new RootBeanDefinition(DefaultEventListenerFactory.class); def.setSource(source); beanDefs.add(registerPostProcessor(registry, def, EVENT_LISTENER_FACTORY_BEAN_NAME)); } return beanDefs; }

在AnnotatedBeanDefinitionReader構造方法中可以看到調用了registerAnnotationConfigProcessors注冊一些列注解解析的Processor類,重點關注ConfigurationClassPostProcessor類,該類是BeanDefinitionRegistryPostProcessor的子類,所以會在refresh中調用,該類又會委托ConfigurationClassParser去解析@Configuration、@Bean、@ComponentScan等注解,所以這兩個類就是SpringBoot實現零配置的關鍵類,實現和之前分析的注解解析流程差不多,所以具體的實現邏輯讀者請自行分析。

回頭看當解析器和掃描器創建好后,同樣是調用scan方法掃描包,然后refresh啟動容器,所以實現邏輯都是一樣的,殊途同歸,只不過通過父子容器的構造方式使得我們可以很方便的擴展Spring。

總結

本篇是關于IOC實現的一些補充,最重要的是要理解循環依賴的解決辦法,其次SpringBoot零配置實現原理雖然這里只是簡單起了個頭,但需要好好閱讀源碼分析。另外還有很多細節,不可能全都講到,需要我們自己反復琢磨,尤其是Bean實例化那一塊,這將是后面我們理解AOP的基礎。希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
主站蜘蛛池模板: 久久99热久久99精品 | 国产成人精品三级麻豆 | 久久久精品福利 | 激情六月色 | 沈阳45老熟女高潮喷水亮点 | 日本少妇bbwbbw高清 | 97国产精| 欧美激情国产精品 | 国产激情无码一区二区 | 欧美色资源 | 国产视频资源在线观看 | 日韩a片无码毛片免费看 | 伊人久久青青 | 亚洲 欧美 变态 另类 制服 | 手机在线一区二区 | 国产欧美日韩综合精品二区 | 免费中文字幕日韩欧美 | 少妇公车张开腿迎合巨大视频 | www.久久成人| 高清无码一区二区在线观看吞精 | 国内成人在线 | 潘金莲性生交大片免费看图片 | 久久强奷乱码老熟女网站 | 亚洲成人a√ | 亚洲精品综合五月久久小说 | 中文在线中文资源 | 黑人性视频 | 国产免费高清 | 中文字幕乱码一二三区 | 国产精品五月天 | 久久99精品久久久久久秒播放器 | 成人欧美一区二区三区在线观看 | 三级不卡| 国产成人在线精品 | 亚洲国产又黄又爽女人高潮的 | 日韩啪 | 丁香社区五月天 | 欧美午夜理伦三级在线观看吃奶汁 | 成人区精品一区二区婷婷 | 日本大尺度吃奶做爰视频 | 日本美女影院 | 国产日韩欧美中文另类 | 深夜国产精品 | 操小妹影院| 婷婷精品久久久久久久久久不卡 | 亚洲国产精品大学美女久久久爽 | 99热久久精品免费精品 | av久久天堂三区 | 国产一区二区日本欧美精品久久久 | 日韩精品毛片 | 国产精品不卡视频 | 成人在线污 | 四虎影视永久免费 | 精品蜜臀av在线天堂 | 久久午夜av | 久久狼人天堂 | 国产精品久久久网站 | 色噜噜狠狠色综合网 | www黄在线观看 | 国产偷窥女洗浴在线观看 | 青青草视频在线观看免费 | 无码人妻aⅴ一区二区三区69岛 | 国产亚洲一区二区在线观看 | 中文字幕av播放 | 国产视频麻豆 | 一本一本久久a久久精品综合小说 | 夜夜爽www| 亚洲婷婷综合网 | 国产亚洲片 | 亚洲人女屁股眼交3之懂色 亚洲人屁股眼子交1 | 精品国产一区二区三区忘忧草 | 狠狠操2019 | 美女18禁一区二区三区视频 | 亚洲中文精品久久久久久不卡 | 国产69精品久久久久毛片 | 一区二区三区在线 | 欧 | 少妇被躁爽到高潮无码文 | 成年女人色毛片 | 国产成人精品一区二 | 欧美成人看片一区二区三区尤物 | 欧美性生交xxxxx久久久缅北 | 亚洲自拍偷拍图 | 国产毛片18 | 国产精品热久久高潮av袁孑怡 | 精品少妇一区二区三区日产乱码 | 又粗又硬又大又爽免费视频播放 | youjizz.com在线播放 | 国产在线视频导航 | 亚洲网站av | 国产原创麻豆 | 午夜无码片在线观看影院 | 国产区在线观看 | 久久成熟 | 欧洲色播 | 免费在线黄网 | 午夜福利试看120秒体验区 | 精品一区二区三区中文字幕 | 久久久精品影视 | 欧美日本精品一区二区三区 | 国产精品欧美一区二区三区 | 在线看片日韩 | 久久久久人妻一区二区三区 | 黄色一级大片免费版 | 国产一区=区 | 男主和女配啪慎入h闺蜜宋冉 | 一本大道熟女人妻中文字幕在线 | 精品黑人一区二区三区久久 | 一本大道无码人妻精品专区 | 插b内射18免费视频 亚洲欧美另类激情综合区 很黄很色60分钟在线观看 | 内射人妻无码色ab麻豆 | 国产精品黄色裸体片 | 青草青在线视频在线观看 | 在线成人一区 | 特黄三级| 人人狠狠综合久久亚洲 | 99精品视频在线观看 | 国产性生大片免费观看性 | 九色porny丨首页在线 | 日韩中文字幕免费看 | 直接看的av | 黄色网址哪里有 | 三a级做爰 | 久久久受www免费人成 | 欧美亚洲色综久久精品国产 | 欧美xxxx18| 伊人干综合 | 亚洲作爱网| 成年在线观看免费视频 | www.17.com嫩草影院 | 日日噜噜夜夜狠狠久久蜜桃 | 黄色大片a级 | 91精品国产自产91精品 | 青青草福利视频 | jlzzjlzzjlz亚洲日本 | 一级大片免费看 | 爱看av在线| 日本黄大片在线观看 | 俺也来俺也去俺也射 | 91在线无精精品一区二区 | 国产精品久久久久久妇女 | 亚洲国产成人aⅴ毛片大全密桃 | 国产嫩草影院在线观看88 | 精品亚洲国产成人av | 91九色网站| 精品一卡2卡三卡4卡免费网站 | 狠狠色丁香婷婷久久综合 | 久久九色综合九色99伊人 | 一区二区三区在线免费观看视频 | 国产女主播视频 | 日韩在线中文字幕视频 | 91精品一区二区三区蜜臀 | 久久精品国产2020 | 婷婷夜夜躁天天躁人人躁 | 国产精品视频一区二区二 | 愉拍自拍第43页免费 | 在线天堂新版资源www在线 | 国产精品高清一区二区三区不卡 | 人体一级片 | 最新国产精品精品视频 | 肥老熟妇伦子伦456视频 | 亚洲精品视频久久 | 国产真实的和子乱拍在线观看 | 国产黄a三级三级三级老年人 | 亚洲夜夜叫 | 久久精品道一区二区三区 | 日b视频免费观看 | 成年在线观看 | 日韩午夜理论免费tv影院 | 国产免费无码一区二区 | 欧美雌雄另类xxxxx | 总裁高h震动喷水双性 | 欧美一区二区三区国产 | 国产乱子伦无套一区二区三区 | 一级片久久久 | 欧美日韩精品在线播放 | 精品国产百合女同互慰 | 欧美三级韩国三级少妇99 | 久草在线青青草 | 全部免费的毛片在线播放 | 日本在线www | 一及黄色大片 | 日韩一级欧美一级 | 国产深夜福利在线 | 中文字幕第二一区 | 亚洲精品国产自在久久 | 国产美女网 | 日韩欧美亚洲 | 色欲久久久天天天综合网精品 | 成人aaa片一区国产精品 | 肉丝美脚视频一区二区 | 就要爱爱tv | 色偷偷偷久久伊人大杳蕉 | 激情小说五月天 | 中文字幕a一二三在线 | 神马一区二区三区 | 亚洲综合久久成人a片 | 一区二区三区av在线 | 黄色a级免费 | 亚洲免费砖区 | 欧美日韩在线免费观看 | 国产一级片网站 | 91禁在线观看 | 亚洲成av人片在线观看无码 | 在线播放高清视频www | 亚洲永久精品视频 | 国产精品久草 | 中文字幕一区二区人妻电影 | 日日操夜夜草 | 青草青草久热精品视频在线观看 | 波多野结衣在线视频播放 | 懂色av一区二区三区四区五区 | 国产一区二区免费视频 | 五月婷久久 | 国内极品少妇1000激情啪啪千 | 亚洲字幕在线观看 | 欧美99视频 | 黄色av在 | 人间水蜜桃av五月色 | 搡老熟女国产 | 久久久精品久久日韩一区 | 久久99九九| 色婷婷久久综合中文久久一本 | 欧美一二三四成人免费视频 | 91porn成人精品 | 对白刺激国语子与伦 | 欧美日本在线播放 | 一本一道久久综合久久 | 国内精产品∪v | 开心色99 | 色综合88 | 国产婷婷色综合av蜜臀av | 鲁丝一区二区三区免费 | 91高清免费 | 韩国美女主播娇喘乳奶摇 | 日本理论中文字幕 | 一卡二卡三卡视频 | 日本一本久 | www欧美亚洲 | 81精品久久久久久久婷婷 | 国产精品毛片a∨一区二区三区 | 少妇无码太爽了不卡视频在线看 | 国产免费拔擦拔擦8x高清在线人 | 亚洲成av人片在线观看无码 | 欧美三级韩国三级日本三斤在线观看 | 国产成人av大片大片在线播放 | 夜夜草视频 | 国产伦精品一区二区三区免.费 | 国产欧美日韩在线视频 | 亚洲高清福利 | 五月天丁香综合久久国产 | 欧美日本免费一区二区三区 | 国产精品27p | 日韩视频在线观看一区 | 国产精品污www在线观看 | 国产免费一区二区视频 | 亚洲一区二区三区四区五区六 | 色婷婷久久一区二区三区麻豆 | 日本一区二区免费在线观看 | 性一交一乱一乱一视频 | 性生交大片免费视频网站 | 日韩精品在线网站 | 国产精品theporn | 一本一本久久a久久精品综合 | 少妇被粗大的猛进出69影院 | 国产精品亚洲一区二区三区天天看 | 天天做天天躁天天躁 | 国产精品欧美一区二区三区不卡 | 国产精品久久久不卡 | 99爱免费视频 | 色婷婷狠狠干 | 亚洲中文字幕不卡无码 | 青青艹在线观看 | 都市激情久久 | 婷婷国产在线 | 亚洲中文字幕不卡无码 | 91免费在线播放 | 国产精品色 | 99久久久精品国产一区二区 | 亚洲欧美精品久久 | 国产裸体永久免费无遮挡 | 视频区图片区小说区 | 人人爽久久涩噜噜噜小说 | 欧美性一级片 | 欧美极品在线观看 | 国产精品一区av | www.伊人网| 99久久久国产精品免费消防器 | 九九热视频精品 | 新久草在线视频 | 久久久精品国产99久久精品芒果 | 大胆欧美gogo免费视频一二区 | 看全色黄大色大片免费 | 超碰97人人人人人蜜桃 | 无码国产69精品久久久久孕妇 | 巨胸喷奶水视频www免费网站 | 91绿帽黑人系列一区 | 欧美zzz物交 | 18岁日韩内射颜射午夜久久成人 | 又黄又爽又色的免费网站 | 精品国产乱码久久久久久预案 | 欧美午夜激情影院 | 日本老太婆做爰视频 | 国产成人精品一区二三区四区五区 | 一本色道久久综合亚洲精品婷婷 | 午夜影院激情av | 欧美成人免费全部 | 亚洲成av人片一区二区三区 | 午夜在线播放 | 日韩欧美中文字幕一区二区 | 无遮无挡爽爽免费视频 | 69网址| 国产无线一二三四区手机 | 麻豆专区一区二区三区四区五区 | 久久网伊人 | 欧美高清在线精品一区 | 亚洲免费一级 | 国产黄网在线观看 | 九九精品国产 | 熟女熟妇伦av网站 | 欧洲精品国产 | 能在线观看的av网站 | 日本v片 | 国产精品一区二区三区久久 | 亚洲欧美在线成人 | 欧美精品久久 | 成人爽a毛片一区二区免费 成人爽爽爽 | 麻豆精品国产精华精华液好用吗 | 快射视频在线观看 | 欧美日韩三区 | 国产精品久久久久久一区二区三区 | 日本视频一区二区三区 | 亚洲精品97久久中文字幕无码 | 成人做爰69片免网站 | 91中文字幕永久在线 | 欧美高清免费 | 国产区图片区小说区亚洲区 | av的天堂 | 国产精品综合久久 | 69久久99精品久久久久婷婷 | 国产丝袜一区视频在线观看 | 5x社区未满十八在线视频 | 国产精品久久久久亚洲影视 | 黄色一集片 | 久久久久黑人强伦姧人妻 | 一级生性活片免费视频片 | 久久九九久久九九 | 国产精品无码久久综合网 | 国产精品久久久久久久一区二区 | 欧美xxx视频 | 在线观看免费黄色av | 18视频在线观看男男 | 91久久 | 黄色片中文字幕 | 亚洲精品久久久久久久久久久 | 国产成人资源 | 亚洲乱码在线观看 | 日韩视频在线观看 | 妩媚尤物娇喘无力呻吟在线视频 | 日韩黄色在线 | 国内少妇偷人精品视频免费 | zzijzzij亚洲日本成熟少妇 | 性无码专区无码 | 韩国不卡av| 噜噜啪永久免费视频 | 狠狠爱五月婷婷 | 精品国产一区二区三区四区vr | 一级黄色片在线播放 | 久久久妇女国产精品影视 | 亚洲精品午夜 | 人妻少妇偷人精品无码 | a免费看 | 亚洲专区欧美专区 | 亚州中文字幕蜜桃视频 | 国产精品有码 | 亚洲国产精品一区二区www | 男女后式激烈动态图片 | 热99re久久精品这里都是精品 | 三级全黄做爰在线观看 | 亚洲天堂av中文字幕 | 日韩视频在线观看免费 | 欧美激情精品久久 | 青草青在线视频在线观看 | 无码人妻精品一区二区三区不卡 | 黑人一级视频 | 91一二区| 三级黄色免费 | 久久精品播放 | 国产中文自拍 | 国产一级特黄毛片 | 日韩av影院在线观看 | 嫩草精品福利视频在线观看 | 国产精品久久久久影院嫩草 | 欧美日韩免费在线 | 国产精品久久久久久久久电影网 | 俺也去婷婷 | 国产又爽又粗又猛的视频 | 国产91精品高清一区二区三区 | 欧美精品亚洲精品日韩传电影 | 男女爽爽爽视频 | 欧美一级性生活视频 | 蜜桃日本免费看mv免费版 | 在线免费观看成年人视频 | 少妇资源 | 成人在线视频免费观看 | 国产成人a亚洲精v品无码 | 国产成人99| 香蕉视频ap | 久久精品女人的天堂av | 亚洲精品国产精品国 | 亚洲人成网站18禁止 | 久久一级黄色片 | 国产精品入口免费 | 国产ts在线视频 | 午夜大尺度做爰激吻视频 | 日韩av影片 | 在线视频久 | 色播一区二区 | 无码精品视频一区二区三区 | 欧美做爰xxxⅹ性欧美大片 | 欧美va在线观看 | 97在线观看永久免费视频 | 超碰人人草人人干 | 在线视频日韩欧美 | 欧美激情一区二区三区p站 欧美激情一区二区三区蜜桃视频 | 日本人作爰全过程 | 免费吃奶摸下激烈视频 | 法国伦理少妇愉情 | 国产精品麻豆免费观看 | 国产性猛交╳xxx乱大交 | 国内大量揄拍人妻精品視頻 | 国产精品久久久久久久久久久久午衣片 | 99精品欧美一区二区蜜桃美图 | 超碰97色 | 一本一本久久a久久精品综合麻豆 | 国产在线不卡视频 | 国产精品日韩av在线播放 | 亚洲午夜视频在线 | 久久免费视频观看 | 99re这里只有精品在线观看 | 超碰免费公开 | 真人毛片高清免费播放 | www.欧美在线观看 | 国产又黄又粗又猛又爽视频 | 永久影院 | 日韩国产一区二区三区四区五区 | 国产精品人人爽人人做av片 | 国产精品免费大片 | 免费在线你懂的 | 国产青青草视频 | 人成福利视频在线观看 | 国产成人啪精品视频免费网 | 毛片网站网址 | 免费日批视频 | 久久无码精品一区二区三区 | 性欧洲精品videos' | 新超碰97 | 精品福利一区二区三区免费视频 | 伊人网综合 | 亚洲人精品午夜射精日韩 | 毛片一级在线观看 | 亚洲大片免费看 | 大陆女明星裸体毛片 | 日本成人激情视频 | 日韩综合在线 | 午夜久久网站 | jzzjzzjzz亚洲成孰少妇 | 国产精品嫩草久久久久 | 天天躁日日躁mmmmxxxx | 午夜精品久久久久久久99樱桃 | 国产91会所女技师在线观 | 亚洲高清在线看 | 国产一区二区三区久久 | 国内毛片毛片毛片毛片毛片毛片 | 狠狠色网 | 伊人色综合一区二区三区 | 国产精品乱码一区二区视频 | 亚洲一区二区在线看 | 国产69精品久久久久99尤物 | 美一女一无一伦一性一交 | 亚 洲 视 频 高 清 无 码 | 情侣酒店偷拍一区二区在线播放 | 成人高清在线观看 | 丝袜人妻一区二区三区 | 国产性色av | 丰满少妇一级片 | 国产盗摄夫妻原创视频在线观看 | 一级成人毛片 | 亚洲国产成人久久精品软件 | 一级全黄少妇性色生活片毛片 | 在线免费观看污网站 | 日韩国产欧美一区二区 | 最新精品国产 | 欧美日本韩国一区二区三区 | 欧美成人伊人 | 色视频在线网站 | 久久久999久久久 | 久久婷婷五月综合色欧美 | 欧美精品一区二区三区四区在线 | 久久99精品国产麻豆蜜芽 | 永久免费无码av网站在线观看 | 国产欧美亚洲精品a | 欧美黑人激情性久久 | 亚洲精品美女久久久久久久 | 水蜜桃亚洲一二三四在线 | xxxx视频在线观看 | 久久狼人天堂 | 国产农村一国产农村无码毛片 | 九九99精品视频 | 亚洲www| 北京富婆泄欲对白 | 九色丨porny丨蝌蚪 | 国产免费观看久久黄av片 | 成人无码精品一区二区三区 | 日韩视频在线观看一区二区 | 成人学院中文字幕 | 性色a码一区二区三区天美传媒 | 中国a毛片 | av青草| 国产精品视频久久久久久 | 国产乱淫av蜜臂片免费 | 青青国产在线观看 | 夜色资源网 | 国产第四页 | 99久热在线精品996热是什么 | 免费看的一级视频 | 免费一级做a爰片性色毛片 免费一级做a爰片性视频 | 噜噜噜在线观看免费视频日本 | 日本少妇久久 | 婷婷色五| 老太脱裤让老头玩ⅹxxxx | 国产乱码精品一区二区三区四川人 | 三级欧美日韩 | 欧美牲交a欧美牲交aⅴ一 | 国偷自产视频一区二区久 | 亚洲区视频在线观看 | 私人午夜影院 | 精品视频在线观看一区二区 | wwwwww在线观看 | 国产露脸无套对白在线播放 | 国产手机在线视频 | 粉嫩av久久一区二区三区 | 日本一区二区视频在线 | 人人舔人人爽 | 美女视频黄的免费 | 欧美一级视频在线观看 | 日韩国产在线 | 免费在线观看av | 一本大道在线一本久道视频 | 日日夜夜超碰 | 久久精品这里有 | 日本欧美在线播放 | 天堂无乱码 | 亚洲欧洲无卡二区视頻 | 日韩视频一 | 欧美伊人| 韩国黄色片网站 | 中文字幕一区二区三区四区五区 | 国精产品一区一区三区有限公司 | 日本资源在线 | 亚洲九色 | 国产女高清在线看免费观看 | 国产一国产二 | 国产69精品久久久久孕妇大杂乱 | 大陆国语对白国产av片 | 欧美成人看片黄a免费看 | 亚洲欧美丝袜精品久久 | 夜夜春亚洲嫩草一区二区 | 欧美乱大交xxxxx潮喷 | 狠狠色综合网站久久久久久久 | 久在线播放 | 高潮久久久久久久久 | 中品极品少妇xxx | 欧美成人午夜精品免费 | 三上悠亚人妻中文字幕在线 | 色欧美片视频在线观看 | 国产欧美亚洲精品a | 女人夜夜春| 国产videos| 在线精品亚洲一区二区 | 污污网站在线观看免费 | 亚洲国产视频在线观看 | 一级色网站 | 亚洲人成在线观看 | 激情久久av一区av二区av三区 | 亚洲裸男gv网站 | 超碰aⅴ人人做人人爽欧美 狠狠亚洲婷婷综合色香五月 | 婷婷久久av | 国产91热爆ts人妖月奴 | 亚洲一区二区三区乱码aⅴ蜜桃女 | 黄色成人在线免费观看 | 亚洲一区小说 | 日本特黄特色a大片免费高清观看视频 | 国产又黄又猛视频 | 亚洲欧美一区二区三区情侣bbw | 一二三四免费观看在线视频中文版 | 成人欧美一区二区三区黑人麻豆 | 亚洲精品自产拍在线观看亚瑟 | 国产精久 | 婷婷五月色综合 | 国产成人无码区免费内射一片色欲 | 啪啪网站免费 | 可以免费看的av毛片 | 色翁荡熄又大又硬又粗又视频图片 | 亚洲视频一区在线观看 | 精品99久久 | 日韩 欧美| 五月天婷婷亚洲 | 欧美成人精品一区二区三区 | 亚洲一区免费视频 | 国产乱码精品一区二区三区中文 | 狠狠躁三区二区久久天天 | 国产成人精品亚洲日本在线观看 | 正在播放adn156松下纱荣子 | 香蕉影音 | 日韩欧美在线视频免费观看 |