久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

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

spring 如何解決循環依賴

瀏覽:99日期:2023-07-22 15:07:07

首先解釋下什么是循環依賴,其實很簡單,就是有兩個類它們互相都依賴了對方,如下所示:

@Componentpublic class AService { @Autowired private BService bService;}

@Componentpublic class BService { @Autowired private AService aService;}

AService和BService顯然兩者都在內部依賴了對方,單拎出來看仿佛看到了多線程中常見的死鎖代碼,但很顯然Spring解決了這個問題,不然我們也不可能正常的使用它了。

所謂創建Bean實際上就是調用getBean() 方法,這個方法可以在AbstractBeanFactory這個類里面找到,這個方法一開始會調用getSingleton()方法。

// Eagerly check singleton cache for manually registered singletons.Object sharedInstance = getSingleton(beanName);

這個方法的實現長得很有意思,有著一堆if語句。

protected Object getSingleton(String beanName, boolean allowEarlyReference) { Object singletonObject = this.singletonObjects.get(beanName); if (singletonObject == null && this.isSingletonCurrentlyInCreation(beanName)) { singletonObject = this.earlySingletonObjects.get(beanName); if (singletonObject == null && allowEarlyReference) { synchronized(this.singletonObjects) {singletonObject = this.singletonObjects.get(beanName);if (singletonObject == null) { singletonObject = this.earlySingletonObjects.get(beanName); if (singletonObject == null) { ObjectFactory<?> singletonFactory = (ObjectFactory)this.singletonFactories.get(beanName); if (singletonFactory != null) { singletonObject = singletonFactory.getObject(); // 從三級緩存里取出放到二級緩存中 this.earlySingletonObjects.put(beanName, singletonObject); this.singletonFactories.remove(beanName); } }} } } } return singletonObject;}

但這一坨if很好理解,就是一層層的去獲取這個bean,首先從singletonObjects中獲取,這里面存放的是已經完全創建好的單例Bean;如果取不到,那么就往下走,去earlySingletonObjects里面取,這個是早期曝光的對象;如果還是沒有,那么再去第三級緩存singletonFactories里面獲取,它是提前暴露的對象工廠,這里會從三級緩存里取出后放到二級緩存中。那么總的來說,Spring去獲取一個bean的時候,其實并不是直接就從容器里面取,而是先從緩存里找,而且緩存一共有三級。那么從這個方法返回的并不一定是我們需要的bean,后面會調用getObjectForBeanInstance()方法去得到實例化后的bean,這里就不多說了。

但如果緩存里面的確是取不到bean呢?那么說明這個bean的確還未創建,需要去創建一個bean,這樣我們就會去到前一篇生命周期中的創建bean的方法了?;仡櫹铝鞒蹋簩嵗?屬性注入?初始化?銷毀。那么我們回到文章開頭的例子,有ServiceA和ServiceB兩個類。一般來說,Spring是按照自然順序去創建bean,那么第一個要創建的是ServiceA。顯然一開始緩存里是沒有的,我們會來到創建bean的方法。首先進行實例化階段,我們會來到第一個跟解決循環依賴有關的代碼,在實例化階段的代碼中就可以找到。

// Eagerly cache singletons to be able to resolve circular references// even when triggered by lifecycle interfaces like BeanFactoryAware.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'); } addSingletonFactory(beanName, () -> getEarlyBeanReference(beanName, mbd, bean));}

首先看看第一行,earlySingletonExposure這個變量它會是什么值?

它是有一個條件表達式返回的,一個個來看,首先,mbd.isSingleton()。我們知道Spring默認的Bean的作用域都是單例的,因此這里正常來說都是返回true沒問題。第二個,this.allowCircularReference,這個變量是標記是否允許循環引用,默認也是true。第三個,調用了一個方法,isSingletonCurrentlyInCreation(beanName),進入該代碼可以看出它是返回當前的bean是不是正常創建,顯然也是true。因此這個earlySingletonExposure返回的就是true。

接下來就進入了if語句的實現里面了,也就是addSingletonFactory()這個方法??吹嚼锩娴拇a中出現singletonFactories這個變量是不是很熟悉?翻到上面的getSingleton()就知道了,其實就是三級緩存,所以這個方法的作用是通過三級緩存提前暴露一個工廠對象。

/** * Add the given singleton factory for building the specified singleton * if necessary. * <p>To be called for eager registration of singletons, e.g. to be able to * resolve circular references. * @param beanName the name of the bean * @param singletonFactory the factory for the singleton object */protected void addSingletonFactory(String beanName, ObjectFactory<?> singletonFactory) { Assert.notNull(singletonFactory, 'Singleton factory must not be null'); synchronized (this.singletonObjects) { if (!this.singletonObjects.containsKey(beanName)) { this.singletonFactories.put(beanName, singletonFactory); this.earlySingletonObjects.remove(beanName); this.registeredSingletons.add(beanName); } }}

接下來,回憶下上一章節說的實例化之后的步驟,就是屬性注入了。這就意味著ServiceA需要將ServiceB注入進去,那么顯然又要調用getBean()方法去獲取ServiceB。ServiceB還沒有創建,則也會進入這個createBean()方法,同樣也會來到這一步依賴注入。ServiceB中依賴了ServiceA,則會調用getBean()去獲取ServiceA。此時的獲取ServiceA可就不是再創建Bean了,而是從緩存中獲取。這個緩存就是上面getSingleton()這個方法里面我們看到的singletonFactory。那么這個singletonFactory哪里來的,就是這個addSingletonFactory()方法的第二個參數,即getEarlyBeanReference()方法。

/** * Obtain a reference for early access to the specified bean, * typically for the purpose of resolving a circular reference. * @param beanName the name of the bean (for error handling purposes) * @param mbd the merged bean definition for the bean * @param bean the raw bean instance * @return the object to expose as bean reference */protected Object getEarlyBeanReference(String beanName, RootBeanDefinition mbd, Object bean) { Object exposedObject = bean; if (!mbd.isSynthetic() && hasInstantiationAwareBeanPostProcessors()) { for (SmartInstantiationAwareBeanPostProcessor bp : getBeanPostProcessorCache().smartInstantiationAware) { exposedObject = bp.getEarlyBeanReference(exposedObject, beanName); } } return exposedObject;}

查看bp.getEarlyBeanReference(exposedObject, beanName)的實現,發現有兩個,一個是spring-beans下的SmartInstantiationAwareBeanPostProcessor,一個是spring-aop下的AbstractAutoProxyCreator。我們在未使用AOP的情況下,取的還是第一種實現。

default Object getEarlyBeanReference(Object bean, String beanName) throws BeansException { return bean;}

那么令人驚訝的是,這方法直接返回了bean,也就是說如果不考慮AOP的話,這個方法啥都沒干,就是把實例化創建的對象直接返回了。如果考慮AOP的話調用的是另一個實現:

public Object getEarlyBeanReference(Object bean, String beanName) { Object cacheKey = getCacheKey(bean.getClass(), beanName); this.earlyProxyReferences.put(cacheKey, bean); return wrapIfNecessary(bean, beanName, cacheKey);}

可以看出,如果使用了AOP的話,這個方法返回的實際上是bean的代理,并不是它本身。那么通過這部分我們可以認為,在沒有使用AOP的情況下,三級緩存是沒有什么用的,所謂三級緩存實際上只是跟Spring的AOP有關的。

好了我們現在是處于創建B的過程,但由于B依賴A,所以調用了獲取A的方法,則A從三級緩存進入了二級緩存,得到了A的代理對象。當然我們不需要擔心注入B的是A的代理對象會帶來什么問題,因為生成代理類的內部都是持有一個目標類的引用,當調用代理對象的方法的時候,實際上是會調用目標對象的方法的,所以所以代理對象是沒影響的。當然這里也反應了我們實際上從容器中要獲取的對象實際上是代理對象而不是其本身。

那么我們再回到創建A的邏輯往下走,能看到后面實際上又調用了一次getSingleton()方法。傳入的allowEarlyReference為false。

if (earlySingletonExposure) { Object earlySingletonReference = getSingleton(beanName, false); if (earlySingletonReference != null) { if (exposedObject == bean) { exposedObject = earlySingletonReference; } ... }}

翻看上面的getSingleton()代碼可以看出,allowEarlyReference為false就相當于禁用三級緩存,代碼只會執行到通過二級緩存get。

singletonObject = this.earlySingletonObjects.get(beanName);

因為在前面我們在創建往B中注入A的時候已經從三級緩存取出來放到二級緩存中了,所以這里A可以通過二級緩存去取。再往下就是生命周期后面的代碼了,就不再繼續了。

那么現在就會有個疑問,我們為什么非要三級緩存,直接用二級緩存似乎就足夠了?

看看上面getEarlyBeanReference()這個方法所在的類,它是SpringAOP自動代理的關鍵類,它實現了SmartInstantiationAwareBeanPostProcessor,也就是說它也是個后置處理器BeanPostProcessor,它有著自定義的初始化后的方法。

/** * Create a proxy with the configured interceptors if the bean is * identified as one to proxy by the subclass. * @see #getAdvicesAndAdvisorsForBean */@Overridepublic Object postProcessAfterInitialization(@Nullable Object bean, String beanName) { if (bean != null) { Object cacheKey = getCacheKey(bean.getClass(), beanName); if (this.earlyProxyReferences.remove(cacheKey) != bean) { return wrapIfNecessary(bean, beanName, cacheKey); } } return bean;}

很明顯它這里是earlyProxyReferences緩存中找不到當前的bean的話就會去創建代理。也就是說SpringAOP希望在Bean初始化后進行創建代理。如果我們只使用二級緩存,也就是在這個地方

addSingletonFactory(beanName, () -> getEarlyBeanReference(beanName, mbd, bean));

直接調用getEarlyBeanReference()并將得到的早期引用放入二級緩存。這就意味著無論bean之間是否存在互相依賴,只要創建bean走到這一步都得去創建代理對象了。然而Spring并不想這么做,不信自己可以動手debug一下,如果ServiceA和ServiceB之間沒有依賴關系的話,getEarlyBeanReference()這個方法壓根就不會執行??偟膩碚f就是,如果不使用三級緩存直接使用二級緩存的話,會導致所有的Bean在實例化后就要完成AOP代理,這是沒有必要的。

最后我們重新梳理下流程,記得Spring創建Bean的時候是按照自然順序的,所以A在前B在后:

spring 如何解決循環依賴

我們首先進行A的創建,但由于依賴了B,所以開始創建B,同樣的,對B進行屬性注入的時候會要用到A,那么就會通過getBean()去獲取A,A在實例化階段會提前將對象放入三級緩存中,如果沒有使用AOP,那么本質上就是這個bean本身,否則是AOP代理后的代理對象。三級緩存singletonFactories會將其存放進去。那么通過getBean()方法獲取A的時候,核心其實在于getSingleton()方法, 它會將其從三級緩存中取出,然后放到二級緩存中去。而最終B創建結束回到A初始化的時候,會再次調用一次getSingleton()方法,此時入參的allowEarlyReference為false,因此是去二級緩存中取,得到真正需要的bean或代理對象,最后A創建結束,流程結束。

所以Spring解決循環依賴的原理大致就講完了,但根據上述的結論,我們可以思考一個問題,什么情況的循環依賴是無法解決的?

根據上面的流程圖,我們知道,要解決循環依賴首先一個大前提是bean必須是單例的,基于這個前提我們才值得繼續討論這個問題。然后根據上述總結,可以知道,每個bean都是要進行實例化的,也就是要執行構造器。所以能不能解決循環依賴問題其實跟依賴注入的方式有關。

依賴注入的方式有setter注入,構造器注入和Field方式。

Filed方式就是我們平時用的最多的,屬性上加個@Autowired或者@Resource之類的注解,這個對解決循環依賴無影響;

如果A和B都是通過setter注入,顯然對于執行構造器沒有影響,所以不影響解決循環依賴;

如果A和B互相通過構造器注入,那么執行構造器的時候也就是實例化的時候,A在自己還沒放入緩存的時候就去創建B了,那么B也是拿不到A的,因此會出錯;

如果A中注入B的方式為setter,B中注入A為構造器,由于A先實例化,執行構造器,并創建緩存,都沒有問題,繼續屬性注入,依賴了B然后走創建B的流程,獲取A也可以從緩存里面能取到,流程一路通暢。

如果A中注入B的方式為構造器,B中注入A為setter,那么這個時候A先進入實例化方法,發現需要B,那么就會去創建B,而A還沒放入三級緩存里,B再創建的時候去獲取A就會獲取失敗。

好了,以上就是關于Spring解決循環依賴問題的所有內容,這個問題的答案我是很久之前就知道了,但真的只是知道答案,這次是自己看源碼加debug一點點看才知道為啥是這個答案,雖然還做不到徹底學的通透,但的確能對這個問題的理解的更為深刻一點,再接再厲吧。

以上就是spring 如何解決循環依賴的詳細內容,更多關于spring 循環依賴的資料請關注好吧啦網其它相關文章!

標簽: Spring
相關文章:
主站蜘蛛池模板: 久久久久久国产免费视网址 | 91久久精品日日躁夜夜躁欧美 | 99精品久久久国产一区二区三 | 日韩精品免费 | 国产aⅴ一区二区 | 亚洲综合色网 | 在线碰| 亚洲永久免费 | 精品久久久久久久久久久久 | 久久久久久久久久久久福利 | 日日操天天爽 | 少妇色欲网 | av色资源 | 国外成人在线视频网站 | 成人一区二区三区久久精品嫩草 | 夜夜夜夜夜操 | 欧美一级日韩片 | 一区二区三区四区免费观看 | www伊人| 久久久tv| 日韩一级电影在线 | 丝袜久久 | 精品一区在线视频 | 性视频网 | www.亚洲一区二区 | 免费一区二区三区 | 国产亚洲精品久久久久久豆腐 | 99精品视频在线 | 欧美成人中文字幕 | 日本黄色免费大片 | 日本亚洲欧美 | av大全在线 | 国产一区二区av | 91在线播| 亚洲视频在线免费观看 | 久久久www成人免费精品 | 夜夜操操操 | 色婷婷国产精品久久包臀 | 久久99国产精一区二区三区 | 日韩欧美一级精品久久 | 亚洲精品在线成人 | 午夜成人免费电影 | 在线观看中文字幕 | 国产成人啪精品午夜在线观看 | 视频在线一区二区三区 | 成人福利在线观看 | 国产精品乱码人人做人人爱 | 羞羞视频网站 | 黄网站免费在线观看 | 国产综合精品视频 | 久久久久av | 中文字幕不卡在线88 | 日韩一区二区在线视频 | 亚洲成人黄色 | 毛片一区二区 | 成人av播放 | 亚洲人成人一区二区在线观看 | 国产精品18久久久 | 婷婷五月色综合香五月 | 国产v日产∨综合v精品视频 | 香蕉大人久久国产成人av | 免费观看的av | 午夜视频一区二区三区 | av综合在线观看 | 久久久久久这里只有精品 | 成人av网页 | 国产色婷婷精品综合在线播放 | 久草视频在线观 | 欧美久久成人 | 免费av播放| 日日日操 | 日韩特黄一级欧美毛片特黄 | 精品亚洲精品 | 亚洲国产成人av好男人在线观看 | 亚洲精品综合 | 国产日韩一区二区三区 | 亚洲国产精品99久久久久久久久 | 一区二区在线 | 欧美一区二区日韩 | 一级做a| 伊人精品视频在线观看 | 欧美一级精品 | www.国产在线 | 国产成人精品一区二 | 一级黄色爱爱视频 | 色综合天天天天做夜夜夜夜做 | 91久久精品一区二区三区 | 久久porn| 亚洲一区二区三区视频免费观看 | 日本淫视频 | 欧美日韩精品一区 | 91最新| 夜夜艹日日艹 | 成人午夜免费视频 | 91精品国产乱码久久蜜臀 | 国产成人精品一区二区三区视频 | 久久毛片| 日韩一级| 国产精品免费在线 | 一级黄色片子看看 | 亚洲精品1| 欧美九九九 | 99re6在线视频精品免费 | 色无欲天天天影视综合网 | 日本黄色片免费 | 午夜剧| 国产中文区二幕区2012 | 亚洲国产成人av | 日本高清视频在线播放 | 夜夜视频| 在线观看亚洲视频 | 免费av播放 | 精品中文字幕一区二区 | 欧美色视频在线观看 | 国产精一区二区 | 六月婷婷综合 | 亚洲一区| 一级a性色生活片毛片 | 色站综合| 亚洲视频1 | 丁香五月网久久综合 | 色黄网站 | 男人的天堂中文字幕 | 欧洲一级黄 | 亚洲中午字幕在线观看 | 在线免费黄 | 精品99视频 | 成人影音| 国产精品视频入口 | 欧美午夜视频在线观看 | 国产一级中文字幕 | 免费一区二区三区 | 日韩欧美一区二区三区 | 91精品国产乱码久久久久久久久 | 91视频网 | 国产成人精品久久 | 久久另类 | 夜夜爽99久久国产综合精品女不卡 | 成人免费小视频 | 免费毛片一区二区三区久久久 | 成年人在线视频 | 亚洲综合精品 | 国产高清精品在线 | 成人精品 | 午夜亚洲电影 | 成人精品视频在线 | 亚洲视频在线视频 | 亚洲视频在线免费观看 | 亚洲免费人成在线视频观看 | 日韩大片免费播放 | 欧美日韩三级 | 国产一级毛片国语一级 | 日韩av视屏 | 九九在线视频 | 久久久免费视频看看 | 999久久久国产999久久久 | 久久久久精| 国产不卡免费视频 | 色五月激情五月 | 久久精品系列 | 中文字幕av一区二区 | 久久久成人av | 亚洲精品免费视频 | 天天摸夜夜操 | 国产视频久久久 | 爱爱免费视频网站 | 成人午夜免费视频 | 成人做爰69片免费 | av影片在线 | 日韩精品一区在线 | 中文在线一区二区 | 深夜福利1000 | 亚洲综合电影 | 国产精品久久久久久亚洲调教 | 国产一区二区三区久久久久久久久 | 色偷偷噜噜噜亚洲男人 | 中文字幕在线免费 | 日本亚洲精品一区二区三区 | 黄色一级免费观看 | www一区二区 | 亚洲 成人 av | 日韩免费 | 久在线| 亚洲欧洲精品一区二区 | 欧洲视频一区二区三区 | 天天舔日日干 | 欧洲免费av| 久久国内精品 | 久久亚洲国产精品日日av夜夜 | 欧美一级片在线观看 | aa级毛片毛片免费观看久 | 黄色一级网站 | 国产目拍亚洲精品99久久精品 | 天天精品在线 | 久久精品视 | 99久久精品一区二区成人 | 91久久久久久久久久久久久久久久 | 久久va | 欧美一区二区三区黄 | 欧美亚洲免费 | 精品久久久久久亚洲综合网站 | 国产一区二区在线播放 | 日韩福利在线 | 黑人精品视频 | 亚洲综合大片69999 | 国产色| 久在线观看 | 中文字幕一区在线观看视频 | 欧美国产综合 | 久久久精品456亚洲影院 | 麻豆产精国品免费入口 | 日本在线免费观看 | 91在线视频在线 | aⅴ色国产 欧美 | 欧美一级二级视频 | www.久草| 夜本色| 伊人一区二区三区 | 91高清在线| 国产在线精品一区二区 | 黄色片视频免费 | 午夜精品久久久久久久久 | 亚洲一区在线视频 | 日本高清视频在线播放 | 激情视频在线观看免费 | 亚洲国产精品久久久久 | 欧美日韩一级二级三级 | 日韩欧美一区二区三区免费观看 | 国产精品久久久久影院色老大 | 伊人天天操| 91性高湖久久久久久久久网站 | 亚洲不卡视频在线 | 亚洲精品久久久久久下一站 | 久久久久久亚洲一区二区三区蜜臀 | 在线永久免费观看日韩a | 99精品欧美一区二区蜜桃免费 | 日韩国产在线播放 | 久久涩 | 国产精品久久9 | 欧美视频免费在线观看 | 日韩av免费看 | 天天操天天舔天天爽 | 国产精选一区二区三区不卡催乳 | 亚洲一区中文 | 精品免费视频一区二区 | 日韩激情视频一区二区 | 国产日韩欧美一区 | www.久久| 亚洲日本乱码在线观看 | 国产在亚洲 线视频播放 | 欧美成人免费视频 | 奇米影视77 | 狠狠爱天天操 | 欧美精品一区二 | 久久影院国产 | 亚洲国产精品99久久久久久久久 | 国产91视频一区二区 | 成人午夜免费视频 | av影片在线 | 一区二区三区免费 | 午夜视频在线观看网站 | 久久综合久久久 | 亚洲国产高清在线 | 亚洲人在线观看视频 | 日韩精品一二三区 | 操皮视频 | 国产日韩欧美一区二区 | 亚洲一区二区三区久久久 | 综合久久精品 | 免费观看一级淫片 | 欧美肉体xxxx肉交高潮 | 日韩精品一区在线 | 成人欧美一区二区三区在线播放 | 韩国精品| 精品久久一级片 | 免费国产成人 | 精品视频在线观看 | 日韩第一区 | 成人不卡 | 制服 丝袜 激情 欧洲 亚洲 | 日韩成人小视频 | 中文字幕乱码一区二区三区 | 免费av在线| 99久久精品一区二区 | 看亚洲a级一级毛片 | 欧美精品中文字幕久久二区 | 国产成人精品综合 | 中文av字幕 | 久久99热精品免费观看牛牛 | 久久91精品国产 | 国产亚洲欧美在线 | 国产成人一区二区 | 国产精品毛片久久久久久 | 亚洲乱码国产乱码精品精 | 免费的国产视频 | 欧美精品在线一区二区三区 | 亚洲一区二区三区四区在线 | 久久久久女人精品毛片九一韩国 | 亚洲精品午夜aaa久久久 | 亚洲一区二区免费看 | 免费爱爱视频 | 欧洲视频一区二区 | 免费观看一级特黄欧美大片 | 亚洲一区二区在线 | 国产精品久久久久久 | 亚洲一区二区三区在线免费观看 | 亚洲欧美在线观看 | 欧美日韩在线一 | 亚洲伊人久久综合 | 国产一区二区三区91 | 日本成人黄色网址 | 国产精品久久久久久久粉嫩 | 91在线成人 | 精品国产欧美一区二区三区成人 | 色官网| 国产精品视频专区 | 精品一区二区三区蜜桃 | 91免费观看国产 | 国产精一区二区 | 中文字幕第31页 | 国产成人一区二区 | 一区免费看| 国产精品成人一区二区三区夜夜夜 | 亚洲视频在线观看免费 | 狠狠干美女 | 老熟女毛片 | 91在线免费观看 | 毛片91 | 亚洲国产网站 | 成人免费视频网站在线观看 | 一本大道久久a久久精二百 国产精品片aa在线观看 | 欧美国产日韩一区 | 91激情在线 | 日本中文字幕一区 | 男女羞羞视频免费观看 | 欧美一区二区三区免费 | www.久久久久 | 天天综合永久入口 | 精品一区二区三区三区 | 日韩中文字幕精品 | 精品一区二区三区在线观看 | 欧美在线免费 | 国产一区二区视频免费 | 久草视频在线资源站 | 久久久久久网址 | 欧美日一区二区 | 成人在线观看免费视频 | 北条麻妃一区二区免费播放 | 九色91视频 | 成人国产| 成人影院av | 中文字幕亚洲视频 | 国产成人精品久久二区二区91 | 日韩视频在线观看 | 国产伦精品一区二区三区四区视频 | 亚洲精品二区三区 | 日本精品视频在线播放 | 免费黄色小片 | 国产在线观看欧美 | 免费一区| 超碰最新在线 | 日韩在线免费 | 精品久久亚洲 | 久久大陆| 日韩精品免费在线视频 | 99久久精品国产毛片 | 麻豆精品一区二区 | 中文在线播放 | 激情一区 | 久久久精品一区 | 日韩国产精品视频 | 韩日精品一区 | 免费毛片一区二区三区久久久 | 亚洲国产精品久久久久婷婷老年 | 久久久久国产一区二区三区 | 亚洲一区二区视频在线播放 | 一区二区三区 在线 | 国产一区二区三区免费在线 | 欧美日韩精品一区 | 欧美一级在线观看视频 | 中文字幕视频在线 | 久久人人爽人人爽人人片av高清 | 精品久久久久久亚洲综合网 | 亚洲精品3区 | 午夜寂寞福利视频 | 成人国产精品视频 | 国产精品久久久久影院色老大 | 中文字幕亚洲精品 | 色综合99| 黄毛片视频 | 日日做夜夜爱 | 国产精品一区二区久久久久 | 少妇久久久久 | av伊人网 | 在线观看第一页 | 九九视频在线观看视频6 | 91一区二区 | 中文视频一区 | 日韩精品免费在线观看 | 日本午夜影院 | 亚洲精品一区二区三区在线 | 国产视频福利在线观看 | 成人夜晚看av | 久久久麻豆 | 欧美日韩不卡合集视频 | 日韩三级av在线 | 亚洲国产精品一区二区第一页 | 色一色视频 | 国产精品久久久久久久久久东京 | 亚洲一区二区三区四区五区中文 | 亚洲激情一区 | 国产福利一区二区三区视频 | 四虎影院网 | 中文字幕观看 | 欧美日韩欧美日韩 | 青青草av | 久久九九精品视频 | 国产综合精品一区二区三区 | 亚洲va欧美va天堂v国产综合 | 精品亚洲一区二区三区 | 亚洲电影二区 | 在线免费观看色视频 | 在线日韩成人 | 欧美日韩国产一区二区三区不卡 | 久久综合一区二区三区 | 中文字幕在线精品 | 日韩a级免费视频 | 日韩欧美精品 | 亚州av在线 | 国产成人精品免费视频 | 国产羞羞视频在线观看 | 久久av在线 | 欧美日韩啪啪 | 亚洲人成网站999久久久综合 | 日本三级在线视频 | 91捆绑91紧缚调教91 | 久久这里只有精品23 | 五月婷婷综合网 | 欧美a级成人淫片免费看 | 日韩视频中文字幕在线观看 | 久久这里只有精品免费 | 日本淫片| 午夜精品一区二区三区免费视频 | 日韩亚洲欧美综合 | 热久久这里只有精品 | 国产在线观看一区二区三区 | 精品免费视频一区二区 | 一级免费在线视频 | 亚洲综合99 | 成人国产 | 久久久大 | 少妇一区二区三区 | 欧美日韩在线精品 | 久久精品国产77777蜜臀 | 91福利视频导航 | aaa级片 | 久久精品美女 | 国产精品久久久久久久天堂 | 午夜影院入口 | 久久亚洲国产精品 | 婷婷亚洲五月 | 99亚洲| а天堂中文最新一区二区三区 | 欧美视频网站 | 国产精品一区二区三区四区 | 国产久 | 欧美自拍视频一区 | 一级毛片大全免费播放 | 亚洲综合视频 | 亚洲免费精品 | 夜夜艹| 国产男人的天堂 | 激情.com | 中国黄色毛片 大片 | a成人| 毛片在线网站 | 在线国产欧美 | 高清三区| 国产一区二区三区免费 | 亚洲综合日韩 | 亚洲乱码一区二区三区在线观看 | 午夜免费在线 | 亚洲二区视频 | 国产日韩欧美一二三区 | 天天爱天天草 | 狠狠爱www人成狠狠爱综合网 | 香蕉久久av一区二区三区 | 我和我的祖国电影在线观看免费版高清 | 国产精品久久久久一区二区三区 | 韩日视频在线观看 | 欧美日韩成人在线播放 | 日本一区二区三区四区 | 久久一区| 精产国产伦理一二三区 | 亚洲欧美日韩一区二区 | 亚州中文字幕 | 一区二区三区在线视频播放 | 国产精品无码专区在线观看 | 日韩久久影院 | 欧美国产一区二区三区 | 午夜电影网址 | 日韩欧美中字 | 国产福利视频 | 成年人精品视频 | 日批免费观看视频 | 欧美日韩国产一区二区三区不卡 | 日本久久精品一区 | 91精品一区 | 日韩欧美一区二区三区免费观看 | 国产在线拍揄自揄拍视频 | 成人黄色短视频在线观看 | 国产精品原创av片国产免费 | www久久久久久久 | 亚洲a在线播放 | av中文字幕在线播放 | 999精品嫩草久久久久久99 | 国产999精品久久久久久麻豆 | 国产在线中文字幕 | 在线中文字幕av | 农村末发育av片四区五区 | 亚洲午夜视频在线观看 | 一区二区三区日韩在线 | 亚洲高清在线 | 日韩欧美国产一区二区三区 | 久精品视频 | 欧美与黑人午夜性猛交久久久 | 日日操夜 | 狠狠躁日日躁夜夜躁东南亚 | 国产99页 | 成年人黄色免费视频 | 在线视频中文字幕 | 精品久久久久久一区二区 | 丁香五月网久久综合 | 韩国毛片在线 | www97影院 | 一区二区三区影院 | 日本黄色大片免费 | 国产伦精品一区二区 | 狠狠撸在线视频 | 久久精品国产一区二区电影 | 亚洲一区二区三 | 九九99| 久久久精品网站 | 成人国产精品久久久 | av片免费| 久久只有精品 | 成人欧美一区二区三区在线播放 | 欧美日韩国产精品一区 | 久久伦理电影 | 国产色视频网站 | 蜜桃视频成人m3u8 | 精品久久久久久久久久久久 | 性免费网站 | 日韩欧美大片在线观看 | a在线免费观看 | 伊人影院久久 | 色吊丝2288sds中文字幕 | 欧洲毛片 | 成人av高清 | 一区二区日韩精品 | 国产96在线视频 | 国产玖玖 | 国产免费一区二区三区 | 日韩高清国产一区在线 | 美女91| 欧美高清成人 | 欧美9999| 久色视频在线观看 | 99久久免费精品国产男女性高好 | 国产毛片网站 | 国产综合亚洲精品一区二 | 91一区二区在线 | 国产精品福利视频 | 黄色毛片观看 | 男人的天堂中文字幕 | 国产精品精品视频 | 国产噜噜噜噜噜久久久久久久久 | 国产91看片| 精品三级三级三级三级三级 | 777777777亚洲妇女| 欧美视频免费在线 | 天天爽天天干 | 二区视频 | 91亚洲国产成人久久精品网站 | 成人午夜影院 | 中文字字幕一区二区三区四区五区 | 国产资源视频在线观看 | 久在线| 欧洲一级毛片 | a一级片在线观看 | 91亚洲高清 | 久久综合成人精品亚洲另类欧美 | 日韩一区二区三区在线观看 | 欧美日韩中文字幕在线 | 伊人久久综合 | 国产综合亚洲精品一区二 | 国产精品久久久久国产a级 国产精品欧美一区二区三区不卡 | 草樱av| 精品久 | 国产在线看h | 男人的天堂视频网站 | 久久久久黄色 | 久久国产亚洲精品 | 狠狠的干| 国产免费自拍 | www.操.com| 亚洲精品一区二区网址 | 成人高清视频在线观看 | 久久av在线 | av在线免费网址 | 国产精品无 | 天天色天天射天天操 | 欧美黑人一级爽快片淫片高清 | 黄色av网站在线免费观看 | 国产免费国产 |