久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

Spring是如何利用“三级缓存“巧妙解决Bean的循环依赖问题

發布時間:2024/1/23 javascript 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Spring是如何利用“三级缓存“巧妙解决Bean的循环依赖问题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前言

循環依賴:就是N個類循環(嵌套)引用
通俗的講就是N個Bean互相引用對方,最終形成閉環。用一副經典的圖示可以表示成這樣(A、B、C都代表對象,虛線代表引用關系):

注意:其實可以N=1,也就是極限情況的循環依賴:自己依賴自己

另需注意:這里指的循環引用不是方法之間的循環調用,而是對象的相互依賴關系。(方法之間循環調用若有出口也是能夠正常work的)

可以設想一下這個場景:如果在日常開發中我們用new對象的方式,若構造函數之間發生這種循環依賴的話,程序會在運行時一直循環調用最終導致內存溢出,示例代碼如下:

public class Main {public static void main(String[] args) throws Exception {System.out.println(new A());}}class A {public A() {new B();} }class B {public B() {new A();} }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

運行報錯:

Exception in thread "main" java.lang.StackOverflowError
  • 1

這是一個典型的循環依賴問題。本文說一下Spring是如果巧妙的解決平時我們會遇到的三大循環依賴問題的~

Spring Bean的循環依賴

談到Spring Bean的循環依賴,有的小伙伴可能比較陌生,畢竟開發過程中好像對循環依賴這個概念無感知。其實不然,你有這種錯覺,權是因為你工作在Spring的襁褓中,從而讓你“高枕無憂”~
我十分堅信,小伙伴們在平時業務開發中一定一定寫過如下結構的代碼:

@Service public class AServiceImpl implements AService {@Autowiredprivate BService bService;... } @Service public class BServiceImpl implements BService {@Autowiredprivate AService aService;... }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

這其實就是Spring環境下典型的循環依賴場景。但是很顯然,這種循環依賴場景,Spring已經完美的幫我們解決和規避了問題。所以即使平時我們這樣循環引用,也能夠整成進行我們的coding之旅~

Spring中三大循環依賴場景演示

在Spring環境中,因為我們的Bean的實例化、初始化都是交給了容器,因此它的循環依賴主要表現為下面三種場景。為了方便演示,我準備了如下兩個類:

1、構造器注入循環依賴

@Service public class A {public A(B b) {} } @Service public class B {public B(A a) {} }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

結果:項目啟動失敗拋出異常BeanCurrentlyInCreationException

Caused by: org.springframework.beans.factory.BeanCurrentlyInCreationException: Error creating bean with name 'a': Requested bean is currently in creation: Is there an unresolvable circular reference?at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.beforeSingletonCreation(DefaultSingletonBeanRegistry.java:339)at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:215)at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:318)at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:199)
  • 1
  • 2
  • 3
  • 4
  • 5

構造器注入構成的循環依賴,此種循環依賴方式是無法解決的,只能拋出BeanCurrentlyInCreationException異常表示循環依賴。這也是構造器注入的最大劣勢(它有很多獨特的優勢,請小伙伴自行發掘)

根本原因:Spring解決循環依賴依靠的是Bean的“中間態”這個概念,而這個中間態指的是已經實例化,但還沒初始化的狀態。而構造器是完成實例化的東東,所以構造器的循環依賴無法解決~~~

2、field屬性注入(setter方法注入)循環依賴

這種方式是我們最最最最為常用的依賴注入方式(所以猜都能猜到它肯定不會有問題啦):

@Service public class A {@Autowiredprivate B b; }@Service public class B {@Autowiredprivate A a; }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

結果:項目啟動成功,能夠正常work

備注:setter方法注入方式因為原理和字段注入方式類似,此處不多加演示

2、prototype?field屬性注入循環依賴

prototype在平時使用情況較少,但是也并不是不會使用到,因此此種方式也需要引起重視。

@Scope(ConfigurableBeanFactory.SCOPE_PROTOTYPE) @Service public class A {@Autowiredprivate B b; }@Scope(ConfigurableBeanFactory.SCOPE_PROTOTYPE) @Service public class B {@Autowiredprivate A a; }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

結果:需要注意的是本例中啟動時是不會報錯的(因為非單例Bean默認不會初始化,而是使用時才會初始化),所以很簡單咱們只需要手動getBean()或者在一個單例Bean內@Autowired一下它即可

// 在單例Bean內注入@Autowiredprivate A a;
  • 1
  • 2
  • 3

這樣子啟動就報錯:

org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'mytest.TestSpringBean': Unsatisfied dependency expressed through field 'a'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'a': Unsatisfied dependency expressed through field 'b'; nested exception is org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'b': Unsatisfied dependency expressed through field 'a'; nested exception is org.springframework.beans.factory.BeanCurrentlyInCreationException: Error creating bean with name 'a': Requested bean is currently in creation: Is there an unresolvable circular reference?at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor$AutowiredFieldElement.inject(AutowiredAnnotationBeanPostProcessor.java:596)at org.springframework.beans.factory.annotation.InjectionMetadata.inject(InjectionMetadata.java:90)at org.springframework.beans.factory.annotation.AutowiredAnnotationBeanPostProcessor.postProcessProperties(AutowiredAnnotationBeanPostProcessor.java:374)
  • 1
  • 2
  • 3
  • 4
  • 5

如何解決???
可能有的小伙伴看到網上有說使用@Lazy注解解決:

@Lazy@Autowiredprivate A a;
  • 1
  • 2
  • 3

此處負責任的告訴你這樣是解決不了問題的(可能會掩蓋問題),@Lazy只是延遲初始化而已,當你真正使用到它(初始化)的時候,依舊會報如上異常。

對于Spring循環依賴的情況總結如下:

  • 不能解決的情況:
    1. 構造器注入循環依賴
    2.?prototype?field屬性注入循環依賴
  • 能解決的情況:
    1. field屬性注入(setter方法注入)循環依賴
  • Spring解決循環依賴的原理分析

    在這之前需要明白java中所謂的引用傳遞和值傳遞的區別。

    說明:看到這句話可能有小伙伴就想噴我了。java中明明都是傳遞啊,這是我初學java時背了100遍的面試題,怎么可能有錯???
    這就是我做這個申明的必要性:伙計,你的說法是正確的,java中只有值傳遞。但是本文借用引用傳遞來輔助講解,希望小伙伴明白我想表達的意思~

    Spring的循環依賴的理論依據基于Java的引用傳遞,當獲得對象的引用時,對象的屬性是可以延后設置的。(但是構造器必須是在獲取引用之前,畢竟你的引用是靠構造器給你生成的,兒子能先于爹出生?哈哈)

    Spring創建Bean的流程

    首先需要了解是Spring它創建Bean的流程,我把它的大致調用棧繪圖如下:

    對Bean的創建最為核心三個方法解釋如下:

    • createBeanInstance:例化,其實也就是調用對象的構造方法實例化對象
    • populateBean:填充屬性,這一步主要是對bean的依賴屬性進行注入(@Autowired)
    • initializeBean:回到一些形如initMethod、InitializingBean等方法

    從對單例Bean的初始化可以看出,循環依賴主要發生在第二步(populateBean),也就是field屬性注入的處理。

    Spring容器的'三級緩存'

    在Spring容器的整個聲明周期中,單例Bean有且僅有一個對象。這很容易讓人想到可以用緩存來加速訪問。
    從源碼中也可以看出Spring大量運用了Cache的手段,在循環依賴問題的解決過程中甚至不惜使用了“三級緩存”,這也便是它設計的精妙之處~

    三級緩存其實它更像是Spring容器工廠的內的術語,采用三級緩存模式來解決循環依賴問題,這三級緩存分別指:

    public class DefaultSingletonBeanRegistry extends SimpleAliasRegistry implements SingletonBeanRegistry {...// 從上至下 分表代表這“三級緩存”private final Map<String, Object> singletonObjects = new ConcurrentHashMap<>(256); //一級緩存private final Map<String, Object> earlySingletonObjects = new HashMap<>(16); // 二級緩存private final Map<String, ObjectFactory<?>> singletonFactories = new HashMap<>(16); // 三級緩存.../** Names of beans that are currently in creation. */// 這個緩存也十分重要:它表示bean創建過程中都會在里面呆著~// 它在Bean開始創建時放值,創建完成時會將其移出~private final Set<String> singletonsCurrentlyInCreation = Collections.newSetFromMap(new ConcurrentHashMap<>(16));/** Names of beans that have already been created at least once. */// 當這個Bean被創建完成后,會標記為這個 注意:這里是set集合 不會重復// 至少被創建了一次的 都會放進這里~~~~private final Set<String> alreadyCreated = Collections.newSetFromMap(new ConcurrentHashMap<>(256)); }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    注:AbstractBeanFactory繼承自DefaultSingletonBeanRegistry~

  • singletonObjects:用于存放完全初始化好的 bean,從該緩存中取出的 bean 可以直接使用
  • earlySingletonObjects:提前曝光的單例對象的cache,存放原始的 bean 對象(尚未填充屬性),用于解決循環依賴
  • singletonFactories:單例對象工廠的cache,存放 bean 工廠對象,用于解決循環依賴
  • 獲取單例Bean的源碼如下:

    public class DefaultSingletonBeanRegistry extends SimpleAliasRegistry implements SingletonBeanRegistry {...@Override@Nullablepublic Object getSingleton(String beanName) {return getSingleton(beanName, true);}@Nullableprotected Object getSingleton(String beanName, boolean allowEarlyReference) {Object singletonObject = this.singletonObjects.get(beanName);if (singletonObject == null && isSingletonCurrentlyInCreation(beanName)) {synchronized (this.singletonObjects) {singletonObject = this.earlySingletonObjects.get(beanName);if (singletonObject == null && allowEarlyReference) {ObjectFactory<?> singletonFactory = this.singletonFactories.get(beanName);if (singletonFactory != null) {singletonObject = singletonFactory.getObject();this.earlySingletonObjects.put(beanName, singletonObject);this.singletonFactories.remove(beanName);}}}}return singletonObject;}...public boolean isSingletonCurrentlyInCreation(String beanName) {return this.singletonsCurrentlyInCreation.contains(beanName);}protected boolean isActuallyInCreation(String beanName) {return isSingletonCurrentlyInCreation(beanName);}... }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
  • 先從一級緩存singletonObjects中去獲取。(如果獲取到就直接return)
  • 如果獲取不到或者對象正在創建中(isSingletonCurrentlyInCreation()),那就再從二級緩存earlySingletonObjects中獲取。(如果獲取到就直接return)
  • 如果還是獲取不到,且允許singletonFactories(allowEarlyReference=true)通過getObject()獲取。就從三級緩存singletonFactory.getObject()獲取。(如果獲取到了就從singletonFactories中移除,并且放進earlySingletonObjects。其實也就是從三級緩存移動(是剪切、不是復制哦~)到了二級緩存)
  • 加入singletonFactories三級緩存的前提是執行了構造器,所以構造器的循環依賴沒法解決

    getSingleton()從緩存里獲取單例對象步驟分析可知,Spring解決循環依賴的訣竅:就在于singletonFactories這個三級緩存。這個Cache里面都是ObjectFactory,它是解決問題的關鍵。

    // 它可以將創建對象的步驟封裝到ObjectFactory中 交給自定義的Scope來選擇是否需要創建對象來靈活的實現scope。 具體參見Scope接口 @FunctionalInterface public interface ObjectFactory<T> {T getObject() throws BeansException; }
    • 1
    • 2
    • 3
    • 4
    • 5

    經過ObjectFactory.getObject()后,此時放進了二級緩存earlySingletonObjects內。這個時候對象已經實例化了,雖然還不完美,但是對象的引用已經可以被其它引用了。

    此處說一下二級緩存earlySingletonObjects它里面的數據什么時候添加什么移除???

    添加:向里面添加數據只有一個地方,就是上面說的getSingleton()里從三級緩存里挪過來
    移除:addSingleton、addSingletonFactory、removeSingleton從語義中可以看出添加單例、添加單例工廠ObjectFactory的時候都會刪除二級緩存里面對應的緩存值,是互斥的

    源碼解析

    Spring容器會將每一個正在創建的Bean 標識符放在一個“當前創建Bean池”中,Bean標識符在創建過程中將一直保持在這個池中,而對于創建完畢的Bean將從當前創建Bean池中清除掉。
    這個“當前創建Bean池”指的是上面提到的singletonsCurrentlyInCreation那個集合。

    public abstract class AbstractBeanFactory extends FactoryBeanRegistrySupport implements ConfigurableBeanFactory {...protected <T> T doGetBean(final String name, @Nullable final Class<T> requiredType, @Nullable final Object[] args, boolean typeCheckOnly) throws BeansException {...// Eagerly check singleton cache for manually registered singletons.// 先去獲取一次,如果不為null,此處就會走緩存了~~Object sharedInstance = getSingleton(beanName);...// 如果不是只檢查類型,那就標記這個Bean被創建了~~添加到緩存里 也就是所謂的 當前創建Bean池if (!typeCheckOnly) {markBeanAsCreated(beanName);}...// Create bean instance.if (mbd.isSingleton()) {// 這個getSingleton方法不是SingletonBeanRegistry的接口方法 屬于實現類DefaultSingletonBeanRegistry的一個public重載方法~~~// 它的特點是在執行singletonFactory.getObject();前后會執行beforeSingletonCreation(beanName);和afterSingletonCreation(beanName); // 也就是保證這個Bean在創建過程中,放入正在創建的緩存池里 可以看到它實際創建bean調用的是我們的createBean方法~~~~sharedInstance = getSingleton(beanName, () -> {try {return createBean(beanName, mbd, args);} catch (BeansException ex) {destroySingleton(beanName);throw ex;}});bean = getObjectForBeanInstance(sharedInstance, name, beanName, mbd);}}... }// 抽象方法createBean所在地 這個接口方法是屬于抽象父類AbstractBeanFactory的 實現在這個抽象類里 public abstract class AbstractAutowireCapableBeanFactory extends AbstractBeanFactory implements AutowireCapableBeanFactory {...protected Object doCreateBean(final String beanName, final RootBeanDefinition mbd, final @Nullable Object[] args) throws BeanCreationException {...// 創建Bean對象,并且將對象包裹在BeanWrapper 中instanceWrapper = createBeanInstance(beanName, mbd, args);// 再從Wrapper中把Bean原始對象(非代理~~~) 這個時候這個Bean就有地址值了,就能被引用了~~~// 注意:此處是原始對象,這點非常的重要final Object bean = instanceWrapper.getWrappedInstance();...// earlySingletonExposure 用于表示是否”提前暴露“原始對象的引用,用于解決循環依賴。// 對于單例Bean,該變量一般為 true 但你也可以通過屬性allowCircularReferences = false來關閉循環引用// isSingletonCurrentlyInCreation(beanName) 表示當前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");}// 上面講過調用此方法放進一個ObjectFactory,二級緩存會對應刪除的// getEarlyBeanReference的作用:調用SmartInstantiationAwareBeanPostProcessor.getEarlyBeanReference()這個方法 否則啥都不做// 也就是給調用者個機會,自己去實現暴露這個bean的應用的邏輯~~~// 比如在getEarlyBeanReference()里可以實現AOP的邏輯~~~ 參考自動代理創建器AbstractAutoProxyCreator 實現了這個方法來創建代理對象// 若不需要執行AOP的邏輯,直接返回BeanaddSingletonFactory(beanName, () -> getEarlyBeanReference(beanName, mbd, bean));}Object exposedObject = bean; //exposedObject 是最終返回的對象...// 填充屬于,解決@Autowired依賴~populateBean(beanName, mbd, instanceWrapper);// 執行初始化回調方法們~~~exposedObject = initializeBean(beanName, exposedObject, mbd);// earlySingletonExposure:如果你的bean允許被早期暴露出去 也就是說可以被循環引用 那這里就會進行檢查// 此段代碼非常重要~~~~~但大多數人都忽略了它if (earlySingletonExposure) {// 此時一級緩存肯定還沒數據,但是呢此時候二級緩存earlySingletonObjects也沒數據//注意,注意:第二參數為false 表示不會再去三級緩存里查了~~~// 此處非常巧妙的一點:::因為上面各式各樣的實例化、初始化的后置處理器都執行了,如果你在上面執行了這一句// ((ConfigurableListableBeanFactory)this.beanFactory).registerSingleton(beanName, bean);// 那么此處得到的earlySingletonReference 的引用最終會是你手動放進去的Bean最終返回,完美的實現了"偷天換日" 特別適合中間件的設計// 我們知道,執行完此doCreateBean后執行addSingleton() 其實就是把自己再添加一次 **再一次強調,完美實現偷天換日**Object earlySingletonReference = getSingleton(beanName, false);if (earlySingletonReference != null) {// 這個意思是如果經過了initializeBean()后,exposedObject還是木有變,那就可以大膽放心的返回了// initializeBean會調用后置處理器,這個時候可以生成一個代理對象,那這個時候它哥倆就不會相等了 走else去判斷吧if (exposedObject == bean) {exposedObject = earlySingletonReference;} // allowRawInjectionDespiteWrapping這個值默認是false// hasDependentBean:若它有依賴的bean 那就需要繼續校驗了~~~(若沒有依賴的 就放過它~)else if (!this.allowRawInjectionDespiteWrapping && hasDependentBean(beanName)) {// 拿到它所依賴的Bean們~~~~ 下面會遍歷一個一個的去看~~String[] dependentBeans = getDependentBeans(beanName);Set<String> actualDependentBeans = new LinkedHashSet<>(dependentBeans.length);// 一個個檢查它所以Bean// removeSingletonIfCreatedForTypeCheckOnly這個放見下面 在AbstractBeanFactory里面// 簡單的說,它如果判斷到該dependentBean并沒有在創建中的了的情況下,那就把它從所有緩存中移除~~~ 并且返回true// 否則(比如確實在創建中) 那就返回false 進入我們的if里面~ 表示所謂的真正依賴//(解釋:就是真的需要依賴它先實例化,才能實例化自己的依賴)for (String dependentBean : dependentBeans) {if (!removeSingletonIfCreatedForTypeCheckOnly(dependentBean)) {actualDependentBeans.add(dependentBean);}}// 若存在真正依賴,那就報錯(不要等到內存移除你才報錯,那是非常不友好的) // 這個異常是BeanCurrentlyInCreationException,報錯日志也稍微留意一下,方便定位錯誤~~~~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.");}}}}return exposedObject;}// 雖然是remove方法 但是它的返回值也非常重要// 該方法唯一調用的地方就是循環依賴的最后檢查處~~~~~protected boolean removeSingletonIfCreatedForTypeCheckOnly(String beanName) {// 如果這個bean不在創建中 比如是ForTypeCheckOnly的 那就移除掉if (!this.alreadyCreated.contains(beanName)) {removeSingleton(beanName);return true;}else {return false;}}}
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98
    • 99
    • 100
    • 101
    • 102
    • 103
    • 104
    • 105
    • 106
    • 107
    • 108
    • 109
    • 110
    • 111
    • 112
    • 113
    • 114
    • 115
    • 116
    • 117
    • 118
    • 119
    • 120
    • 121
    • 122
    • 123
    • 124
    • 125
    • 126
    • 127
    • 128
    • 129
    • 130
    • 131
    • 132
    • 133
    • 134
    • 135

    這里舉例:例如是field屬性依賴注入,在populateBean時它就會先去完成它所依賴注入的那個bean的實例化、初始化過程,最終返回到本流程繼續處理,因此Spring這樣處理是不存在任何問題的。

    這里有個小細節:

    if (exposedObject == bean) {exposedObject = earlySingletonReference; }
    • 1
    • 2
    • 3

    這一句如果exposedObject == bean表示最終返回的對象就是原始對象,說明在populateBean和initializeBean沒對他代理過,那就啥話都不說了exposedObject = earlySingletonReference,最終把二級緩存里的引用返回即可~

    流程總結(非常重要)

    此處以如上的A、B類的互相依賴注入為例,在這里表達出關鍵代碼的走勢:

    1、入口處即是實例化、初始化A這個單例Bean。AbstractBeanFactory.doGetBean("a")

    protected <T> T doGetBean(...){... // 標記beanName a是已經創建過至少一次的~~~ 它會一直存留在緩存里不會被移除(除非拋出了異常)// 參見緩存Set<String> alreadyCreated = Collections.newSetFromMap(new ConcurrentHashMap<>(256))if (!typeCheckOnly) {markBeanAsCreated(beanName);}// 此時a不存在任何一級緩存中,且不是在創建中 所以此處返回null// 此處若不為null,然后從緩存里拿就可以了(主要處理FactoryBean和BeanFactory情況吧)Object beanInstance = getSingleton(beanName, false);...// 這個getSingleton方法非常關鍵。//1、標注a正在創建中~//2、調用singletonObject = singletonFactory.getObject();(實際上調用的是createBean()方法) 因此這一步最為關鍵//3、此時實例已經創建完成 會把a移除整整創建的緩存中//4、執行addSingleton()添加進去。(備注:注冊bean的接口方法為registerSingleton,它依賴于addSingleton方法)sharedInstance = getSingleton(beanName, () -> { ... return createBean(beanName, mbd, args); }); }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    2、下面進入到最為復雜的AbstractAutowireCapableBeanFactory.createBean/doCreateBean()環節,創建A的實例

    protected Object doCreateBean(){...// 使用構造器/工廠方法 instanceWrapper是一個BeanWrapperinstanceWrapper = createBeanInstance(beanName, mbd, args);// 此處bean為"原始Bean" 也就是這里的A實例對象:A@1234final Object bean = instanceWrapper.getWrappedInstance();...// 是否要提前暴露(允許循環依賴) 現在此處A是被允許的boolean earlySingletonExposure = (mbd.isSingleton() && this.allowCircularReferences && isSingletonCurrentlyInCreation(beanName));// 允許暴露,就把A綁定在ObjectFactory上,注冊到三級緩存`singletonFactories`里面去保存著// Tips:這里后置處理器的getEarlyBeanReference方法會被促發,自動代理創建器在此處創建代理對象(注意執行時機 為執行三級緩存的時候)if (earlySingletonExposure) {addSingletonFactory(beanName, () -> getEarlyBeanReference(beanName, mbd, bean));}...// exposedObject 為最終返回的對象,此處為原始對象bean也就是A@1234,下面會有用處Object exposedObject = bean; // 給A@1234屬性完成賦值,@Autowired在此處起作用~// 因此此處會調用getBean("b"),so 會重復上面步驟創建B類的實例// 此處我們假設B已經創建好了 為B@5678// 需要注意的是在populateBean("b")的時候依賴有beanA,所以此時候調用getBean("a")最終會調用getSingleton("a"),//此時候上面說到的getEarlyBeanReference方法就會被執行。這也解釋為何我們@Autowired是個代理對象,而不是普通對象的根本原因populateBean(beanName, mbd, instanceWrapper);// 實例化。這里會執行后置處理器BeanPostProcessor的兩個方法// 此處注意:postProcessAfterInitialization()是有可能返回一個代理對象的,這樣exposedObject 就不再是原始對象了 特備注意哦~~~// 比如處理@Aysnc的AsyncAnnotationBeanPostProcessor它就是在這個時間里生成代理對象的(有坑,請小心使用@Aysnc)exposedObject = initializeBean(beanName, exposedObject, mbd);... // 至此,相當于A@1234已經實例化完成、初始化完成(屬性也全部賦值了~)// 這一步我把它理解為校驗:校驗:校驗是否有循環引用問題~~~~~if (earlySingletonExposure) {// 注意此處第二個參數傳的false,表示不去三級緩存里singletonFactories再去調用一次getObject()方法了~~~// 上面建講到了由于B在初始化的時候,會觸發A的ObjectFactory.getObject() 所以a此處已經在二級緩存earlySingletonObjects里了// 因此此處返回A的實例:A@1234Object earlySingletonReference = getSingleton(beanName, false);if (earlySingletonReference != null) {// 這個等式表示,exposedObject若沒有再被代理過,這里就是相等的// 顯然此處我們的a對象的exposedObject它是沒有被代理過的 所以if會進去~// 這種情況至此,就全部結束了~~~if (exposedObject == bean) {exposedObject = earlySingletonReference;}// 繼續以A為例,比如方法標注了@Aysnc注解,exposedObject此時候就是一個代理對象,因此就會進到這里來//hasDependentBean(beanName)是肯定為true,因為getDependentBeans(beanName)得到的是["b"]這個依賴else if (!this.allowRawInjectionDespiteWrapping && hasDependentBean(beanName)) {String[] dependentBeans = getDependentBeans(beanName);Set<String> actualDependentBeans = new LinkedHashSet<>(dependentBeans.length);// A@1234依賴的是["b"],所以此處去檢查b// 如果最終存在實際依賴的bean:actualDependentBeans不為空 那就拋出異常 證明循環引用了~for (String dependentBean : dependentBeans) {// 這個判斷原則是:如果此時候b并還沒有創建好,this.alreadyCreated.contains(beanName)=true表示此bean已經被創建過,就返回false// 若該bean沒有在alreadyCreated緩存里,就是說沒被創建過(其實只有CreatedForTypeCheckOnly才會是此倉庫)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.");}}}} }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76

    由于關鍵代碼部分的步驟不太好拆分,為了更具象表達,那么使用下面一副圖示幫助小伙伴們理解:


    最后的最后,由于我太暖心了_,再來個純文字版的總結。
    依舊以上面A、B類使用屬性field注入循環依賴的例子為例,對整個流程做文字步驟總結如下:

  • 使用context.getBean(A.class),旨在獲取容器內的單例A(若A不存在,就會走A這個Bean的創建流程),顯然初次獲取A是不存在的,因此走A的創建之路~
  • 實例化A(注意此處僅僅是實例化),并將它放進緩存(此時A已經實例化完成,已經可以被引用了)
  • 初始化A:@Autowired依賴注入B(此時需要去容器內獲取B)
  • 為了完成依賴注入B,會通過getBean(B)去容器內找B。但此時B在容器內不存在,就走向B的創建之路~
  • 實例化B,并將其放入緩存。(此時B也能夠被引用了)
  • 初始化B,@Autowired依賴注入A(此時需要去容器內獲取A)
  • 此處重要:初始化B時會調用getBean(A)去容器內找到A,上面我們已經說過了此時候因為A已經實例化完成了并且放進了緩存里,所以這個時候去看緩存里是已經存在A的引用了的,所以getBean(A)能夠正常返回
  • B初始化成功(此時已經注入A成功了,已成功持有A的引用了),return(注意此處return相當于是返回最上面的getBean(B)這句代碼,回到了初始化A的流程中~)。
  • 因為B實例已經成功返回了,因此最終A也初始化成功
  • 到此,B持有的已經是初始化完成的A,A持有的也是初始化完成的B,完美~
  • 站的角度高一點,宏觀上看Spring處理循環依賴的整個流程就是如此。希望這個宏觀層面的總結能更加有助于小伙伴們對Spring解決循環依賴的原理的了解,同時也順便能解釋為何構造器循環依賴就不好使的原因。




    循環依賴對AOP代理對象創建流程和結果的影響

    我們都知道Spring AOP、事務等都是通過代理對象來實現的,而事務的代理對象是由自動代理創建器來自動完成的。也就是說Spring最終給我們放進容器里面的是一個代理對象,而非原始對象

    本文結合循環依賴,回頭再看AOP代理對象的創建過程,和最終放進容器內的動作,非常有意思。

    @Service public class HelloServiceImpl implements HelloService {@Autowiredprivate HelloService helloService;@Transactional@Overridepublic Object hello(Integer id) {return "service hello";} }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    此Service類使用到了事務,所以最終會生成一個JDK動態代理對象Proxy。剛好它又存在自己引用自己的循環依賴??纯催@個Bean的創建概要描述如下:

    protected Object doCreateBean( ... ){...// 這段告訴我們:如果允許循環依賴的話,此處會添加一個ObjectFactory到三級緩存里面,以備創建對象并且提前暴露引用~// 此處Tips:getEarlyBeanReference是后置處理器SmartInstantiationAwareBeanPostProcessor的一個方法,它的功效為:// 保證自己被循環依賴的時候,即使被別的Bean @Autowire進去的也是代理對象~~~~ AOP自動代理創建器此方法里會創建的代理對象~~~// 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) { // 需要提前暴露(支持循環依賴),就注冊一個ObjectFactory到三級緩存addSingletonFactory(beanName, () -> getEarlyBeanReference(beanName, mbd, bean));}// 此處注意:如果此處自己被循環依賴了 那它會走上面的getEarlyBeanReference,從而創建一個代理對象從三級緩存轉移到二級緩存里// 注意此時候對象還在二級緩存里,并沒有在一級緩存。并且此時可以知道exposedObject仍舊是原始對象~~~populateBean(beanName, mbd, instanceWrapper);exposedObject = initializeBean(beanName, exposedObject, mbd);// 經過這兩大步后,exposedObject還是原始對象(注意此處以事務的AOP為例子的,// 因為事務的AOP自動代理創建器在getEarlyBeanReference創建代理后,initializeBean就不會再重復創建了,二選一的,下面會有描述~~~)...// 循環依賴校驗(非常重要)~~~~if (earlySingletonExposure) {// 前面說了因為自己被循環依賴了,所以此時候代理對象還在二級緩存里~~~(備注:本利講解的是自己被循環依賴了的情況)// so,此處getSingleton,就會把里面的對象拿出來,我們知道此時候它已經是個Proxy代理對象~~~// 最后賦值給exposedObject 然后return出去,進而最終被addSingleton()添加進一級緩存里面去 // 這樣就保證了我們容器里**最終實際上是代理對象**,而非原始對象~~~~~Object earlySingletonReference = getSingleton(beanName, false);if (earlySingletonReference != null) {if (exposedObject == bean) { // 這個判斷不可少(因為如果initializeBean改變了exposedObject ,就不能這么玩了,否則就是兩個對象了~~~)exposedObject = earlySingletonReference;}}...}}
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39

    上演示的是代理對象+自己存在循環依賴的case:Spring用三級緩存很巧妙的進行解決了。
    若是這種case:代理對象,但是自己并不存在循環依賴,過程稍微有點不一樣兒了,如下描述:

    protected Object doCreateBean( ... ) {...// 這些語句依舊會執行,三級緩存里是會加入的 表示它支持被循環引用嘛~~~addSingletonFactory(beanName, () -> getEarlyBeanReference(beanName, mbd, bean));...// 此處注意,因為它沒有被其它Bean循環引用(注意是循環引用,而不是直接引用~),所以上面getEarlyBeanReference不會執行~// 也就是說此時二級緩存里并不會存在它~~~ 知曉這點特別的重要populateBean(beanName, mbd, instanceWrapper);// 重點在這:AnnotationAwareAspectJAutoProxyCreator自動代理創建器此處的postProcessAfterInitialization方法里,會給創建一個代理對象返回// 所以此部分執行完成后,exposedObject **已經是個代理對象**而不再是個原始對象了~~~~ 此時二級緩存里依舊無它,更別提一級緩存了exposedObject = initializeBean(beanName, exposedObject, mbd);...// 循環依賴校驗if (earlySingletonExposure) {// 前面說了一級、二級緩存里都木有它,然后這里傳的又是false(表示不看三級緩存~~)// 所以毋庸置疑earlySingletonReference = null so下面的邏輯就不用看了,直接return出去~~// 然后執行addSingleton()方法,由此可知 容器里最終存在的也還是代理對象~~~~~~Object earlySingletonReference = getSingleton(beanName, false);if (earlySingletonReference != null) {if (exposedObject == bean) { // 這個判斷不可少(因為如果initializeBean改變了exposedObject ,就不能這么玩了,否則就是兩個對象了~~~)exposedObject = earlySingletonReference;}}.........} }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30

    分析可知,即使自己只需要代理,并不被循環引用,最終存在Spring容器里的仍舊是代理對象。(so此時別人直接@Autowired進去的也是代理對象呀~~~)

    終極case:如果我關閉Spring容器的循環依賴能力,也就是把allowCircularReferences設值為false,那么會不會造成什么問題呢?

    // 它用于關閉循環引用(關閉后只要有循環引用現象就直接報錯~~) @Component public class MyBeanFactoryPostProcessor implements BeanFactoryPostProcessor {@Overridepublic void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {((AbstractAutowireCapableBeanFactory) beanFactory).setAllowCircularReferences(false);} }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    若關閉了循環依賴后,還存在上面A、B的循環依賴現象,啟動便會報錯如下:

    Caused by: org.springframework.beans.factory.BeanCurrentlyInCreationException: Error creating bean with name 'a': Requested bean is currently in creation: Is there an unresolvable circular reference?at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.beforeSingletonCreation(DefaultSingletonBeanRegistry.java:339)at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:215)
    • 1
    • 2
    • 3

    注意此處異常類型也是BeanCurrentlyInCreationException異常,但是文案內容和上面強調的有所區別~~
    它報錯位置在:DefaultSingletonBeanRegistry.beforeSingletonCreation這個位置~

    報錯淺析:在實例化A后給其屬性賦值時,會去實例化B。B實例化完成后會繼續給B屬性賦值,這時由于此時我們關閉了循環依賴,所以不存在提前暴露引用這么一說來給實用。因此B無法直接拿到A的引用地址,因此只能又去創建A的實例。而此時我們知道A其實已經正在創建中了,不能再創建了。so,就報錯了~

    @Service public class HelloServiceImpl implements HelloService {// 因為管理了循環依賴,所以此處不能再依賴自己的// 但是:我們的此bean還是需要AOP代理的~~~//@Autowired//private HelloService helloService;@Transactional@Overridepublic Object hello(Integer id) {return "service hello";} }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    這樣它的大致運行如下:

    protected Object doCreateBean( ... ) {// 毫無疑問此時候earlySingletonExposure = false 也就是Bean都不會提前暴露引用了 顯然就不能被循環依賴了~boolean earlySingletonExposure = (mbd.isSingleton() && this.allowCircularReferences && isSingletonCurrentlyInCreation(beanName));...populateBean(beanName, mbd, instanceWrapper);// 若是事務的AOP 在這里會為源生Bean創建代理對象(因為上面沒有提前暴露這個代理)exposedObject = initializeBean(beanName, exposedObject, mbd);if (earlySingletonExposure) {... 這里更不用說,因為earlySingletonExposure=false 所以上面的代理對象exposedObject 直接return了~} }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    可以看到即使把這個開關給關了,最終放進容器了的仍舊是代理對象,顯然@Autowired給屬性賦值的也一定是代理對象。

    最后,以AbstractAutoProxyCreator為例看看自動代理創建器是怎么配合實現:循環依賴+創建代理

    AbstractAutoProxyCreator是抽象類,它的三大實現子類InfrastructureAdvisorAutoProxyCreator、AspectJAwareAdvisorAutoProxyCreator、AnnotationAwareAspectJAutoProxyCreator小伙伴們應該會更加的熟悉些

    該抽象類實現了創建代理的動作:

    // @since 13.10.2003 它實現代理創建的方法有如下兩個 // 實現了SmartInstantiationAwareBeanPostProcessor 所以有方法getEarlyBeanReference來只能的解決循環引用問題:提前把代理對象暴露出去~ public abstract class AbstractAutoProxyCreator extends ProxyProcessorSupport implements SmartInstantiationAwareBeanPostProcessor, BeanFactoryAware {...// 下面兩個方法是自動代理創建器創建代理對象的唯二的兩個節點~// 提前暴露代理對象的引用 它肯定在postProcessAfterInitialization之前執行// 所以它并不需要判斷啥的~~~~ 創建好后放進緩存earlyProxyReferences里 注意此處value是原始Bean@Overridepublic Object getEarlyBeanReference(Object bean, String beanName) {Object cacheKey = getCacheKey(bean.getClass(), beanName);this.earlyProxyReferences.put(cacheKey, bean);return wrapIfNecessary(bean, beanName, cacheKey);}// 因為它會在getEarlyBeanReference之后執行,所以此處的重要邏輯是下面的判斷@Overridepublic Object postProcessAfterInitialization(@Nullable Object bean, String beanName) {if (bean != null) {Object cacheKey = getCacheKey(bean.getClass(), beanName);// remove方法返回被移除的value,上面說了它記錄的是原始bean// 若被循環引用了,那就是執行了上面的`getEarlyBeanReference`方法,所以此時remove返回值肯定是==bean的(注意此時方法入參的bean還是原始對象)// 若沒有被循環引用,getEarlyBeanReference()不執行 所以remove方法返回null,所以就進入if執行此處的創建代理對象方法~~~if (this.earlyProxyReferences.remove(cacheKey) != bean) {return wrapIfNecessary(bean, beanName, cacheKey);}}return bean;}... }
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31

    由上可知,自動代理創建器它保證了代理對象只會被創建一次,而且支持循環依賴的自動注入的依舊是代理對象。

    上面分析了三種case,現給出結論如下:
    不管是自己被循環依賴了還是沒有,甚至是把Spring容器的循環依賴給關了,它對AOP代理的創建流程有影響,但對結果是無影響的。
    也就是說Spring很好的對調用者屏蔽了這些實現細節,使得使用者使用起來完全的無感知~




    總結

    解決此類問題的關鍵是要對SpringIOC和DI的整個流程做到心中有數,要理解好本文章,建議有【相關閱讀】里文章的大量知識的鋪墊,同時呢本文又能進一步的幫助小伙伴理解到Spring Bean的實例化、初始化流程。

    本文還是花了我一番心思的,個人覺得對Spring這部分的處理流程描述得還是比較詳細的,希望我的總結能夠給大家帶來幫助。
    另外為了避免循環依賴導致啟動問題而又不會解決,有如下建議:

  • 業務代碼中盡量不要使用構造器注入,即使它有很多優點。
  • 業務代碼中為了簡潔,盡量使用field注入而非setter方法注入
  • 若你注入的同時,立馬需要處理一些邏輯(一般見于框架設計中,業務代碼中不太可能出現),可以使用setter方法注入輔助完成
  • 創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

    總結

    以上是生活随笔為你收集整理的Spring是如何利用“三级缓存“巧妙解决Bean的循环依赖问题的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    精品厕所偷拍各类美女tp嘘嘘 | 女高中生第一次破苞av | 欧洲精品码一区二区三区免费看 | 在教室伦流澡到高潮hnp视频 | 亚洲精品国偷拍自产在线观看蜜桃 | 亚洲日本va中文字幕 | 国产精品a成v人在线播放 | 丝袜足控一区二区三区 | 乌克兰少妇xxxx做受 | 无码精品国产va在线观看dvd | 男女性色大片免费网站 | 欧美性生交活xxxxxdddd | 成人无码视频免费播放 | 天堂久久天堂av色综合 | 亚洲s色大片在线观看 | 国产精品自产拍在线观看 | 久久久av男人的天堂 | 亚洲无人区一区二区三区 | 天堂一区人妻无码 | 狠狠色噜噜狠狠狠狠7777米奇 | 久久zyz资源站无码中文动漫 | 成人无码精品1区2区3区免费看 | 成人毛片一区二区 | 国产成人人人97超碰超爽8 | 亚洲综合在线一区二区三区 | 国产成人无码区免费内射一片色欲 | 无码午夜成人1000部免费视频 | 国产激情艳情在线看视频 | 无码人中文字幕 | 夜夜高潮次次欢爽av女 | 久久精品国产亚洲精品 | 蜜臀av在线观看 在线欧美精品一区二区三区 | www国产亚洲精品久久网站 | 亚洲成a人片在线观看日本 | 中文字幕色婷婷在线视频 | 少妇性荡欲午夜性开放视频剧场 | 噜噜噜亚洲色成人网站 | 东京热一精品无码av | 久久综合香蕉国产蜜臀av | 伊人久久大香线蕉午夜 | 亚洲大尺度无码无码专区 | 久青草影院在线观看国产 | 久久97精品久久久久久久不卡 | 国产人成高清在线视频99最全资源 | 亚洲综合精品香蕉久久网 | 丰满少妇熟乱xxxxx视频 | 亚洲精品一区二区三区在线 | 无码纯肉视频在线观看 | 国产成人无码av片在线观看不卡 | 久久精品人人做人人综合试看 | 欧美精品一区二区精品久久 | 四十如虎的丰满熟妇啪啪 | 欧美性猛交xxxx富婆 | 亚洲成a人片在线观看日本 | 又色又爽又黄的美女裸体网站 | 中文久久乱码一区二区 | 99在线 | 亚洲 | 四虎影视成人永久免费观看视频 | 鲁大师影院在线观看 | 伦伦影院午夜理论片 | 国产免费久久精品国产传媒 | 中文字幕av无码一区二区三区电影 | 精品国精品国产自在久国产87 | 人妻尝试又大又粗久久 | 亚洲色偷偷偷综合网 | 少妇人妻大乳在线视频 | 国产午夜福利亚洲第一 | 亚洲毛片av日韩av无码 | 免费看男女做好爽好硬视频 | 四虎国产精品一区二区 | 日产精品高潮呻吟av久久 | 九月婷婷人人澡人人添人人爽 | 国产乱码精品一品二品 | 国产精品igao视频网 | 国产亚av手机在线观看 | 欧美日韩一区二区免费视频 | 久久久精品成人免费观看 | 亚洲成a人片在线观看无码 | 国产 浪潮av性色四虎 | 国产精品办公室沙发 | 日本精品少妇一区二区三区 | 蜜桃视频插满18在线观看 | 亚洲精品成人av在线 | 亚洲国产精品久久久久久 | 国产精品久久国产精品99 | 国产猛烈高潮尖叫视频免费 | 免费看男女做好爽好硬视频 | 精品偷拍一区二区三区在线看 | 亚洲国产精华液网站w | 成人亚洲精品久久久久 | 亚洲男人av天堂午夜在 | 国产乱人偷精品人妻a片 | 国产无套粉嫩白浆在线 | 色一情一乱一伦一视频免费看 | 欧美第一黄网免费网站 | 亚洲精品国偷拍自产在线观看蜜桃 | 人妻互换免费中文字幕 | 午夜精品久久久内射近拍高清 | 亚洲精品久久久久avwww潮水 | a在线亚洲男人的天堂 | 国产午夜视频在线观看 | a在线亚洲男人的天堂 | 亚洲国产精品久久人人爱 | 久久亚洲中文字幕精品一区 | 黄网在线观看免费网站 | 亚洲一区二区三区播放 | 国产精品久久久久9999小说 | 性色欲网站人妻丰满中文久久不卡 | 人妻互换免费中文字幕 | 日韩av激情在线观看 | 无码人妻丰满熟妇区五十路百度 | av香港经典三级级 在线 | 亚洲一区二区三区含羞草 | 国产无遮挡又黄又爽免费视频 | 97久久超碰中文字幕 | 亚洲精品一区国产 | 中文字幕亚洲情99在线 | 欧美人与善在线com | 天天拍夜夜添久久精品 | 精品少妇爆乳无码av无码专区 | 国产午夜亚洲精品不卡下载 | 国产情侣作爱视频免费观看 | 久久99精品国产.久久久久 | 久久午夜夜伦鲁鲁片无码免费 | 国产精品国产自线拍免费软件 | 日韩精品乱码av一区二区 | 亚洲精品一区二区三区婷婷月 | 无套内谢的新婚少妇国语播放 | 欧美性生交活xxxxxdddd | 综合人妻久久一区二区精品 | 国产精品高潮呻吟av久久 | 亚洲爆乳精品无码一区二区三区 | 色一情一乱一伦 | 国产在线aaa片一区二区99 | 日日橹狠狠爱欧美视频 | 国产sm调教视频在线观看 | av无码久久久久不卡免费网站 | 又大又硬又爽免费视频 | 国产亚洲精品久久久久久久 | 大地资源网第二页免费观看 | 强伦人妻一区二区三区视频18 | 亚洲色大成网站www | 欧美人与禽猛交狂配 | 亚洲爆乳精品无码一区二区三区 | 久久综合狠狠综合久久综合88 | 2020久久香蕉国产线看观看 | 免费无码的av片在线观看 | 免费看男女做好爽好硬视频 | 色婷婷久久一区二区三区麻豆 | 偷窥日本少妇撒尿chinese | 久久午夜无码鲁丝片 | 无遮挡啪啪摇乳动态图 | 好屌草这里只有精品 | 欧美人与物videos另类 | 亚洲人成人无码网www国产 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 熟妇女人妻丰满少妇中文字幕 | 亚洲一区av无码专区在线观看 | 夜夜夜高潮夜夜爽夜夜爰爰 | √天堂中文官网8在线 | 性色欲情网站iwww九文堂 | 强辱丰满人妻hd中文字幕 | 中文字幕精品av一区二区五区 | 久久zyz资源站无码中文动漫 | 精品人妻av区 | 久久精品一区二区三区四区 | 亚洲国产精品美女久久久久 | 一区二区三区乱码在线 | 欧洲 | 在线a亚洲视频播放在线观看 | 精品一区二区三区无码免费视频 | 自拍偷自拍亚洲精品10p | 亚洲色偷偷男人的天堂 | 熟女少妇在线视频播放 | 天干天干啦夜天干天2017 | 人人妻人人澡人人爽精品欧美 | 亚洲日韩精品欧美一区二区 | 亚洲成av人在线观看网址 | 欧洲熟妇色 欧美 | 亚洲人亚洲人成电影网站色 | 18禁黄网站男男禁片免费观看 | 日韩精品无码免费一区二区三区 | 久久综合激激的五月天 | 亚洲国产精华液网站w | 四十如虎的丰满熟妇啪啪 | 亚洲a无码综合a国产av中文 | 99er热精品视频 | 欧美性色19p | 日韩av无码中文无码电影 | 国产人妻人伦精品1国产丝袜 | 精品人妻av区 | 国产两女互慰高潮视频在线观看 | 精品亚洲韩国一区二区三区 | 牲欲强的熟妇农村老妇女视频 | 亚洲精品无码国产 | 国产综合久久久久鬼色 | 日日鲁鲁鲁夜夜爽爽狠狠 | 亚洲日本一区二区三区在线 | 国产午夜视频在线观看 | 麻豆精产国品 | 国产凸凹视频一区二区 | 九月婷婷人人澡人人添人人爽 | 伦伦影院午夜理论片 | 永久免费观看美女裸体的网站 | 成人综合网亚洲伊人 | 亚洲国产av精品一区二区蜜芽 | 久久精品99久久香蕉国产色戒 | 国产午夜精品一区二区三区嫩草 | 亚洲日本va午夜在线电影 | 亚洲色www成人永久网址 | 天天躁日日躁狠狠躁免费麻豆 | 精品乱码久久久久久久 | 国产亚洲精品久久久久久大师 | 日本熟妇乱子伦xxxx | 国产精品毛多多水多 | 日韩亚洲欧美精品综合 | 麻豆人妻少妇精品无码专区 | 18无码粉嫩小泬无套在线观看 | 国产成人无码a区在线观看视频app | 久久综合狠狠综合久久综合88 | 中文字幕av日韩精品一区二区 | 荫蒂被男人添的好舒服爽免费视频 | 在线a亚洲视频播放在线观看 | 国产无遮挡吃胸膜奶免费看 | 少妇一晚三次一区二区三区 | 国产偷抇久久精品a片69 | 亚洲精品www久久久 | 国产av无码专区亚洲a∨毛片 | 亚洲国产成人a精品不卡在线 | 色五月丁香五月综合五月 | 欧美放荡的少妇 | 亚洲成色www久久网站 | 无码人妻精品一区二区三区下载 | 午夜性刺激在线视频免费 | 色一情一乱一伦一视频免费看 | 国产舌乚八伦偷品w中 | 高潮毛片无遮挡高清免费 | 中文字幕无码日韩专区 | 中文字幕日韩精品一区二区三区 | 久久国产精品萌白酱免费 | 内射爽无广熟女亚洲 | 欧美成人免费全部网站 | 亚洲国产高清在线观看视频 | 欧美老人巨大xxxx做受 | 久久99国产综合精品 | 中文毛片无遮挡高清免费 | 5858s亚洲色大成网站www | 国产精品毛多多水多 | 夜夜高潮次次欢爽av女 | 又大又黄又粗又爽的免费视频 | 精品日本一区二区三区在线观看 | 俄罗斯老熟妇色xxxx | 波多野结衣一区二区三区av免费 | 欧美午夜特黄aaaaaa片 | 东京热无码av男人的天堂 | 精品少妇爆乳无码av无码专区 | 成人精品一区二区三区中文字幕 | 久久午夜夜伦鲁鲁片无码免费 | 少妇人妻大乳在线视频 | 成人性做爰aaa片免费看 | 99精品无人区乱码1区2区3区 | 日韩视频 中文字幕 视频一区 | 18黄暴禁片在线观看 | 图片区 小说区 区 亚洲五月 | 亚洲中文无码av永久不收费 | 成人影院yy111111在线观看 | 激情内射日本一区二区三区 | 日韩人妻系列无码专区 | 国产高清av在线播放 | 麻豆人妻少妇精品无码专区 | 午夜福利电影 | 大色综合色综合网站 | 又大又硬又黄的免费视频 | 久久国产劲爆∧v内射 | 中文字幕无码免费久久99 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 天堂无码人妻精品一区二区三区 | 大地资源网第二页免费观看 | 97人妻精品一区二区三区 | 2019午夜福利不卡片在线 | 人人妻在人人 | 日本xxxx色视频在线观看免费 | 成人aaa片一区国产精品 | 国产手机在线αⅴ片无码观看 | 久久人人爽人人爽人人片ⅴ | 无码国产乱人伦偷精品视频 | 荫蒂被男人添的好舒服爽免费视频 | 国产人成高清在线视频99最全资源 | 亚洲欧美色中文字幕在线 | 欧美乱妇无乱码大黄a片 | 一本久道久久综合狠狠爱 | 动漫av一区二区在线观看 | 色综合久久久久综合一本到桃花网 | 粉嫩少妇内射浓精videos | 日韩精品乱码av一区二区 | 亚洲成av人片在线观看无码不卡 | aⅴ亚洲 日韩 色 图网站 播放 | 精品国产国产综合精品 | 久久久久久久久蜜桃 | 免费人成网站视频在线观看 | 麻豆国产人妻欲求不满 | 999久久久国产精品消防器材 | 捆绑白丝粉色jk震动捧喷白浆 | 国产精品无码一区二区三区不卡 | 动漫av一区二区在线观看 | 男女性色大片免费网站 | 国产精品无码一区二区三区不卡 | 午夜肉伦伦影院 | 亚洲欧美中文字幕5发布 | 人妻无码久久精品人妻 | 国产高清av在线播放 | 国产精品第一国产精品 | 日韩av无码一区二区三区不卡 | 久久久国产精品无码免费专区 | 中文字幕乱码亚洲无线三区 | 丰满人妻被黑人猛烈进入 | 精品无码一区二区三区的天堂 | 黑人玩弄人妻中文在线 | 国产精品无码永久免费888 | 国产熟妇高潮叫床视频播放 | 中文无码成人免费视频在线观看 | 在线精品亚洲一区二区 | 天下第一社区视频www日本 | 2020最新国产自产精品 | 又大又黄又粗又爽的免费视频 | 大地资源网第二页免费观看 | 日韩欧美群交p片內射中文 | 国产亚洲人成a在线v网站 | 内射老妇bbwx0c0ck | 国产亚洲tv在线观看 | 俺去俺来也在线www色官网 | 亚洲一区二区三区无码久久 | 国产成人一区二区三区别 | 午夜理论片yy44880影院 | 色五月五月丁香亚洲综合网 | 中文字幕无码日韩专区 | 成人亚洲精品久久久久 | 性生交大片免费看女人按摩摩 | 国产一区二区不卡老阿姨 | 亚洲精品鲁一鲁一区二区三区 | 天天拍夜夜添久久精品大 | 97久久国产亚洲精品超碰热 | 国产精品怡红院永久免费 | 蜜桃无码一区二区三区 | 中文字幕人妻无码一夲道 | 亚拍精品一区二区三区探花 | 在教室伦流澡到高潮hnp视频 | 国产激情综合五月久久 | 亚洲经典千人经典日产 | 亚洲综合无码久久精品综合 | 日本丰满护士爆乳xxxx | 久久久久久国产精品无码下载 | 亚洲中文字幕在线观看 | 国产偷国产偷精品高清尤物 | 无码国内精品人妻少妇 | 国产成人精品一区二区在线小狼 | 水蜜桃亚洲一二三四在线 | 中文字幕av无码一区二区三区电影 | 少妇性荡欲午夜性开放视频剧场 | 无码人妻av免费一区二区三区 | 国色天香社区在线视频 | 高潮毛片无遮挡高清免费 | 曰韩少妇内射免费播放 | 国产精品香蕉在线观看 | 久久午夜夜伦鲁鲁片无码免费 | 窝窝午夜理论片影院 | 久久久www成人免费毛片 | 久久国产精品二国产精品 | 狠狠噜狠狠狠狠丁香五月 | 无码人妻少妇伦在线电影 | 亚洲精品国产a久久久久久 | 国语精品一区二区三区 | 久久99精品久久久久久 | 亚洲欧美日韩国产精品一区二区 | 俺去俺来也在线www色官网 | 精品成在人线av无码免费看 | 丰满人妻一区二区三区免费视频 | 久久综合久久自在自线精品自 | 亚洲欧美日韩综合久久久 | 精品乱码久久久久久久 | 亚洲国产精品久久久天堂 | 中文字幕精品av一区二区五区 | 精品成人av一区二区三区 | 国产激情一区二区三区 | 国产农村乱对白刺激视频 | 久久久精品人妻久久影视 | 无套内谢老熟女 | 纯爱无遮挡h肉动漫在线播放 | 人妻无码αv中文字幕久久琪琪布 | 无套内谢的新婚少妇国语播放 | 日本高清一区免费中文视频 | 国产黑色丝袜在线播放 | 中文字幕无码免费久久99 | 无码一区二区三区在线观看 | 日本大乳高潮视频在线观看 | 亚洲gv猛男gv无码男同 | 午夜嘿嘿嘿影院 | 亚洲精品鲁一鲁一区二区三区 | 日本高清一区免费中文视频 | 日韩人妻无码中文字幕视频 | 99久久人妻精品免费二区 | 欧美熟妇另类久久久久久不卡 | 欧美性色19p | 亚洲欧美中文字幕5发布 | 亚洲欧美国产精品久久 | 在线观看国产一区二区三区 | 无码乱肉视频免费大全合集 | 无码av岛国片在线播放 | 99re在线播放 | 野外少妇愉情中文字幕 | 国产欧美精品一区二区三区 | 日韩视频 中文字幕 视频一区 | 精品熟女少妇av免费观看 | 激情内射亚州一区二区三区爱妻 | 无套内谢的新婚少妇国语播放 | 国产麻豆精品一区二区三区v视界 | 99精品国产综合久久久久五月天 | 日韩亚洲欧美精品综合 | 亚洲成av人在线观看网址 | 久在线观看福利视频 | 国产极品视觉盛宴 | 欧美阿v高清资源不卡在线播放 | 未满成年国产在线观看 | 欧美日本免费一区二区三区 | 国产精品无码mv在线观看 | 国产va免费精品观看 | 野外少妇愉情中文字幕 | 久久人妻内射无码一区三区 | 国产人妖乱国产精品人妖 | 精品久久综合1区2区3区激情 | 成人三级无码视频在线观看 | 国产一区二区不卡老阿姨 | 日本爽爽爽爽爽爽在线观看免 | 无码人中文字幕 | 妺妺窝人体色www在线小说 | 欧洲vodafone精品性 | 午夜男女很黄的视频 | 欧美日韩人成综合在线播放 | 欧美放荡的少妇 | 日韩欧美中文字幕在线三区 | 人妻体内射精一区二区三四 | 日本精品少妇一区二区三区 | 水蜜桃色314在线观看 | 日本熟妇人妻xxxxx人hd | 无码一区二区三区在线观看 | 无码国产色欲xxxxx视频 | 一本色道久久综合亚洲精品不卡 | 三上悠亚人妻中文字幕在线 | 欧美乱妇无乱码大黄a片 | 无码成人精品区在线观看 | 国产suv精品一区二区五 | 99国产欧美久久久精品 | 亚洲人成网站色7799 | 少妇高潮喷潮久久久影院 | 国产无遮挡又黄又爽又色 | 国产av无码专区亚洲a∨毛片 | 一本久道高清无码视频 | 老子影院午夜精品无码 | 免费男性肉肉影院 | 国产又爽又猛又粗的视频a片 | 亚洲欧洲日本综合aⅴ在线 | 午夜免费福利小电影 | 未满成年国产在线观看 | 性欧美videos高清精品 | 麻豆国产人妻欲求不满 | 国产成人人人97超碰超爽8 | 一本久道久久综合婷婷五月 | 小泽玛莉亚一区二区视频在线 | 亚洲无人区午夜福利码高清完整版 | 国产免费观看黄av片 | 性做久久久久久久久 | 欧美xxxxx精品 | 国产精品亚洲五月天高清 | 天天综合网天天综合色 | 亚洲精品综合一区二区三区在线 | 99麻豆久久久国产精品免费 | 成人亚洲精品久久久久 | 天天躁日日躁狠狠躁免费麻豆 | 国产无遮挡又黄又爽免费视频 | 精品国产精品久久一区免费式 | 欧美日本精品一区二区三区 | 国产艳妇av在线观看果冻传媒 | 丰腴饱满的极品熟妇 | 人人爽人人爽人人片av亚洲 | 蜜桃视频插满18在线观看 | 精品无人国产偷自产在线 | 成人精品视频一区二区 | 亚洲欧美中文字幕5发布 | 国产xxx69麻豆国语对白 | 久久久精品成人免费观看 | 无码人妻精品一区二区三区下载 | 97久久精品无码一区二区 | 牲欲强的熟妇农村老妇女视频 | 疯狂三人交性欧美 | 国产精品无码成人午夜电影 | 精品久久8x国产免费观看 | 久久精品国产亚洲精品 | 男女猛烈xx00免费视频试看 | 亚洲爆乳精品无码一区二区三区 | 亚洲欧洲中文日韩av乱码 | 无码毛片视频一区二区本码 | 亚洲精品国偷拍自产在线观看蜜桃 | a片免费视频在线观看 | 无码人妻久久一区二区三区不卡 | 97久久精品无码一区二区 | 国产av一区二区精品久久凹凸 | 色婷婷综合中文久久一本 | 国产精品.xx视频.xxtv | 亚洲国产欧美日韩精品一区二区三区 | 国产精品高潮呻吟av久久 | 国色天香社区在线视频 | 噜噜噜亚洲色成人网站 | 内射后入在线观看一区 | 亚洲日韩av一区二区三区四区 | 国产麻豆精品精东影业av网站 | 精品国产精品久久一区免费式 | 成人精品一区二区三区中文字幕 | 欧洲极品少妇 | 亚洲成熟女人毛毛耸耸多 | 国产深夜福利视频在线 | 真人与拘做受免费视频一 | 日日天日日夜日日摸 | 青青青手机频在线观看 | 久久天天躁狠狠躁夜夜免费观看 | a国产一区二区免费入口 | 久久视频在线观看精品 | 玩弄中年熟妇正在播放 | 国内精品久久毛片一区二区 | 国产精品毛多多水多 | 亚洲精品一区二区三区婷婷月 | 久久国产精品二国产精品 | 久久亚洲日韩精品一区二区三区 | 国产乱人偷精品人妻a片 | 久久精品人妻少妇一区二区三区 | 日韩精品久久久肉伦网站 | 成人片黄网站色大片免费观看 | 人妻有码中文字幕在线 | 日本一区二区三区免费高清 | 亚洲欧美色中文字幕在线 | 色老头在线一区二区三区 | 国产午夜福利100集发布 | 国产在热线精品视频 | 暴力强奷在线播放无码 | 精品国产一区二区三区av 性色 | 亚洲午夜无码久久 | 国产综合在线观看 | 亚洲精品一区二区三区四区五区 | 国产午夜无码精品免费看 | 国产精品成人av在线观看 | 黑森林福利视频导航 | 99久久久无码国产精品免费 | 97无码免费人妻超级碰碰夜夜 | 免费国产黄网站在线观看 | 性色av无码免费一区二区三区 | 永久免费观看美女裸体的网站 | 成人免费视频在线观看 | 久久亚洲中文字幕无码 | 亚洲熟妇色xxxxx亚洲 | 正在播放老肥熟妇露脸 | 麻豆人妻少妇精品无码专区 | 97精品人妻一区二区三区香蕉 | 1000部夫妻午夜免费 | 精品久久久无码人妻字幂 | 少妇被黑人到高潮喷出白浆 | 日韩欧美中文字幕公布 | 在线看片无码永久免费视频 | 76少妇精品导航 | 久久人人爽人人人人片 | 波多野结衣一区二区三区av免费 | 老司机亚洲精品影院 | 国产美女精品一区二区三区 | 久热国产vs视频在线观看 | 秋霞成人午夜鲁丝一区二区三区 | 青草视频在线播放 | 亚洲色在线无码国产精品不卡 | 又湿又紧又大又爽a视频国产 | 内射欧美老妇wbb | www国产精品内射老师 | 日欧一片内射va在线影院 | 欧美人与物videos另类 | 丰满少妇熟乱xxxxx视频 | 一个人看的视频www在线 | 色妞www精品免费视频 | 日韩欧美中文字幕在线三区 | 成人亚洲精品久久久久 | 欧美日韩亚洲国产精品 | 午夜精品一区二区三区在线观看 | 又粗又大又硬毛片免费看 | 熟妇人妻无乱码中文字幕 | 东北女人啪啪对白 | 国产精品亚洲专区无码不卡 | 97久久精品无码一区二区 | 人妻少妇被猛烈进入中文字幕 | 久久久久人妻一区精品色欧美 | 成人免费视频视频在线观看 免费 | 呦交小u女精品视频 | 55夜色66夜色国产精品视频 | 婷婷综合久久中文字幕蜜桃三电影 | 一个人免费观看的www视频 | 亚洲人成网站在线播放942 | 中文字幕乱妇无码av在线 | 欧美黑人巨大xxxxx | 亚洲日本一区二区三区在线 | 丰满少妇熟乱xxxxx视频 | 中文字幕乱码人妻二区三区 | 中文毛片无遮挡高清免费 | 99久久婷婷国产综合精品青草免费 | 亚洲欧美精品aaaaaa片 | 在线成人www免费观看视频 | 国产欧美亚洲精品a | 亚洲中文字幕av在天堂 | 影音先锋中文字幕无码 | 国内揄拍国内精品少妇国语 | 性生交片免费无码看人 | 色综合天天综合狠狠爱 | 狠狠躁日日躁夜夜躁2020 | av香港经典三级级 在线 | 人人妻在人人 | 亚洲色大成网站www国产 | 一个人看的www免费视频在线观看 | 亚洲精品午夜国产va久久成人 | 国产成人无码av在线影院 | 亚洲日韩乱码中文无码蜜桃臀网站 | 88国产精品欧美一区二区三区 | 扒开双腿吃奶呻吟做受视频 | 狠狠综合久久久久综合网 | 在线观看欧美一区二区三区 | 亚洲天堂2017无码中文 | 久久久久亚洲精品男人的天堂 | 成人欧美一区二区三区黑人免费 | 成熟人妻av无码专区 | 亚洲欧洲日本无在线码 | 色五月五月丁香亚洲综合网 | 狠狠噜狠狠狠狠丁香五月 | 成人综合网亚洲伊人 | 国产精华av午夜在线观看 | 日本高清一区免费中文视频 | 亚洲无人区午夜福利码高清完整版 | 丰满诱人的人妻3 | 无遮挡国产高潮视频免费观看 | 黑人巨大精品欧美一区二区 | 在教室伦流澡到高潮hnp视频 | 亚洲色成人中文字幕网站 | 2019nv天堂香蕉在线观看 | 狠狠色色综合网站 | 日产精品99久久久久久 | 日本一区二区三区免费播放 | 亚洲s码欧洲m码国产av | 成人综合网亚洲伊人 | 纯爱无遮挡h肉动漫在线播放 | 日韩欧美成人免费观看 | 久久国产自偷自偷免费一区调 | 欧美日韩综合一区二区三区 | 97人妻精品一区二区三区 | 大屁股大乳丰满人妻 | 亚洲精品一区国产 | 丰满人妻翻云覆雨呻吟视频 | 激情亚洲一区国产精品 | 好屌草这里只有精品 | 亚洲精品无码国产 | а√资源新版在线天堂 | 97精品人妻一区二区三区香蕉 | 国产午夜亚洲精品不卡下载 | 色婷婷综合中文久久一本 | 欧美丰满少妇xxxx性 | 国产色xx群视频射精 | 亚洲精品中文字幕 | 国语自产偷拍精品视频偷 | 成人一在线视频日韩国产 | 成人免费无码大片a毛片 | 亚洲成a人片在线观看无码 | 狠狠亚洲超碰狼人久久 | 又色又爽又黄的美女裸体网站 | 精品久久久无码中文字幕 | 3d动漫精品啪啪一区二区中 | 国产va免费精品观看 | 免费无码肉片在线观看 | 丁香啪啪综合成人亚洲 | 亚洲精品一区国产 | 丰满人妻翻云覆雨呻吟视频 | 国产黄在线观看免费观看不卡 | 免费观看黄网站 | 色综合久久久久综合一本到桃花网 | 精品人妻中文字幕有码在线 | 精品 日韩 国产 欧美 视频 | 俺去俺来也在线www色官网 | 图片小说视频一区二区 | 欧美精品一区二区精品久久 | 久久99久久99精品中文字幕 | 无套内谢的新婚少妇国语播放 | 131美女爱做视频 | 最近中文2019字幕第二页 | 免费看男女做好爽好硬视频 | 精品成人av一区二区三区 | 免费乱码人妻系列无码专区 | 一二三四在线观看免费视频 | av无码不卡在线观看免费 | 亚洲熟熟妇xxxx | 国产无遮挡又黄又爽又色 | 国产激情无码一区二区app | 无人区乱码一区二区三区 | 国产在线无码精品电影网 | 帮老师解开蕾丝奶罩吸乳网站 | 国产精品美女久久久久av爽李琼 | 四虎国产精品免费久久 | 夜精品a片一区二区三区无码白浆 | 青草青草久热国产精品 | 乱人伦中文视频在线观看 | 中文字幕无码热在线视频 | 无码国产乱人伦偷精品视频 | 伊人久久大香线蕉亚洲 | 一本久久伊人热热精品中文字幕 | 亚洲一区二区三区含羞草 | 永久免费观看美女裸体的网站 | 国产精品鲁鲁鲁 | 天堂亚洲2017在线观看 | 三上悠亚人妻中文字幕在线 | 色综合久久久无码网中文 | 亚拍精品一区二区三区探花 | 98国产精品综合一区二区三区 | 伊人久久大香线焦av综合影院 | 国产农村乱对白刺激视频 | 天海翼激烈高潮到腰振不止 | 99久久精品国产一区二区蜜芽 | 少妇被粗大的猛进出69影院 | 正在播放老肥熟妇露脸 | 亚洲国产欧美国产综合一区 | 77777熟女视频在线观看 а天堂中文在线官网 | 大肉大捧一进一出好爽视频 | 东京无码熟妇人妻av在线网址 | 中国大陆精品视频xxxx | 中文精品无码中文字幕无码专区 | 熟女俱乐部五十路六十路av | 丝袜美腿亚洲一区二区 | 秋霞成人午夜鲁丝一区二区三区 | 55夜色66夜色国产精品视频 | 在线播放免费人成毛片乱码 | 国产精品久久久久久无码 | 亚洲精品午夜国产va久久成人 | 亚洲自偷精品视频自拍 | 国产乱人伦av在线无码 | 高潮毛片无遮挡高清免费 | 熟妇人妻激情偷爽文 | 牲欲强的熟妇农村老妇女视频 | 18禁止看的免费污网站 | 国产精品无码永久免费888 | 丰满少妇熟乱xxxxx视频 | 精品偷拍一区二区三区在线看 | 日本护士xxxxhd少妇 | 国产av一区二区三区最新精品 | 精品国产青草久久久久福利 | 人妻夜夜爽天天爽三区 | 中文精品久久久久人妻不卡 | 永久黄网站色视频免费直播 | 欧美兽交xxxx×视频 | 成人片黄网站色大片免费观看 | 久久这里只有精品视频9 | 99riav国产精品视频 | 午夜福利一区二区三区在线观看 | 亚洲熟熟妇xxxx | 精品夜夜澡人妻无码av蜜桃 | 一本久久a久久精品亚洲 | 久久国产精品精品国产色婷婷 | 成人一在线视频日韩国产 | 久久久久久久女国产乱让韩 | 色综合久久久无码中文字幕 | 双乳奶水饱满少妇呻吟 | 成年美女黄网站色大免费全看 | 窝窝午夜理论片影院 | 亚洲日韩乱码中文无码蜜桃臀网站 | 99在线 | 亚洲 | 国内精品人妻无码久久久影院蜜桃 | 亚洲自偷自偷在线制服 | 性欧美牲交xxxxx视频 | 欧美亚洲日韩国产人成在线播放 | 国产成人精品必看 | √天堂中文官网8在线 | 日本饥渴人妻欲求不满 | 人妻夜夜爽天天爽三区 | 成人亚洲精品久久久久软件 | 一区二区三区乱码在线 | 欧洲 | 国产亚洲精品久久久闺蜜 | 精品乱码久久久久久久 | 宝宝好涨水快流出来免费视频 | 国产绳艺sm调教室论坛 | 久久国产精品_国产精品 | 高潮毛片无遮挡高清免费 | 精品国偷自产在线 | 荫蒂被男人添的好舒服爽免费视频 | а天堂中文在线官网 | 少妇无套内谢久久久久 | 欧美成人午夜精品久久久 | 日本xxxx色视频在线观看免费 | 美女黄网站人色视频免费国产 | 4hu四虎永久在线观看 | 色情久久久av熟女人妻网站 | 三上悠亚人妻中文字幕在线 | 亚无码乱人伦一区二区 | 中文字幕人妻无码一夲道 | 老子影院午夜精品无码 | 中文字幕 人妻熟女 | 国产激情无码一区二区 | 国产真实夫妇视频 | 精品无码av一区二区三区 | 俺去俺来也www色官网 | 色综合久久网 | 色一情一乱一伦一视频免费看 | 又大又硬又爽免费视频 | 国产精品久久久久9999小说 | 亚洲精品国产a久久久久久 | 日本成熟视频免费视频 | 国产成人人人97超碰超爽8 | 激情国产av做激情国产爱 | 欧美精品无码一区二区三区 | 欧美一区二区三区 | 久久国产精品偷任你爽任你 | 精品国偷自产在线视频 | 国产真实乱对白精彩久久 | 色综合久久88色综合天天 | 久久久久久a亚洲欧洲av冫 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 成人性做爰aaa片免费看不忠 | 中文字幕无码免费久久9一区9 | 中文字幕无线码 | 大色综合色综合网站 | av人摸人人人澡人人超碰下载 | 中文精品久久久久人妻不卡 | 在线观看免费人成视频 | 欧美国产日产一区二区 | 亚洲欧洲日本综合aⅴ在线 | 国产精品第一区揄拍无码 | 无码播放一区二区三区 | 国产sm调教视频在线观看 | 日本高清一区免费中文视频 | 色婷婷欧美在线播放内射 | 少妇愉情理伦片bd | 永久黄网站色视频免费直播 | 国产一区二区三区精品视频 | 国产成人精品无码播放 | 国产免费无码一区二区视频 | 精品国产一区av天美传媒 | 全球成人中文在线 | 九九综合va免费看 | 无套内谢老熟女 | 国产综合久久久久鬼色 | 久久久久99精品成人片 | 国产在线一区二区三区四区五区 | 亚洲日韩乱码中文无码蜜桃臀网站 | 97久久精品无码一区二区 | 欧美兽交xxxx×视频 | 麻豆果冻传媒2021精品传媒一区下载 | 久久熟妇人妻午夜寂寞影院 | 成熟女人特级毛片www免费 | 亚洲 日韩 欧美 成人 在线观看 | 久久午夜无码鲁丝片午夜精品 | 欧美色就是色 | 老太婆性杂交欧美肥老太 | 国产熟女一区二区三区四区五区 | 久久无码中文字幕免费影院蜜桃 | 少妇人妻大乳在线视频 | aa片在线观看视频在线播放 | 爽爽影院免费观看 | 亚洲欧美日韩国产精品一区二区 | 无码精品国产va在线观看dvd | 成人精品一区二区三区中文字幕 | 人妻中文无码久热丝袜 | 丝袜足控一区二区三区 | 狠狠躁日日躁夜夜躁2020 | 午夜熟女插插xx免费视频 | 亚洲色偷偷偷综合网 | 亚洲а∨天堂久久精品2021 | 少女韩国电视剧在线观看完整 | 久久久久亚洲精品男人的天堂 | 人妻少妇精品久久 | 无码av最新清无码专区吞精 | 色婷婷av一区二区三区之红樱桃 | 无码乱肉视频免费大全合集 | 免费视频欧美无人区码 | 久久伊人色av天堂九九小黄鸭 | 日本欧美一区二区三区乱码 | 国内精品久久久久久中文字幕 | 亚洲爆乳无码专区 | 久久久久成人片免费观看蜜芽 | 青青久在线视频免费观看 | 国产精品亚洲专区无码不卡 | 亚洲综合无码久久精品综合 | 中文字幕人妻无码一区二区三区 | 色欲人妻aaaaaaa无码 | 国产九九九九九九九a片 | 亚洲无人区一区二区三区 | 成人免费无码大片a毛片 | 色一情一乱一伦一区二区三欧美 | 国产特级毛片aaaaaa高潮流水 | 国产在线无码精品电影网 | 精品无码一区二区三区爱欲 | 无遮无挡爽爽免费视频 | 水蜜桃色314在线观看 | 久久熟妇人妻午夜寂寞影院 | 色妞www精品免费视频 | 国产艳妇av在线观看果冻传媒 | 又黄又爽又色的视频 | 午夜无码区在线观看 | 久久精品国产99精品亚洲 | 精品 日韩 国产 欧美 视频 | 日本成熟视频免费视频 | 色窝窝无码一区二区三区色欲 | 久久午夜夜伦鲁鲁片无码免费 | 未满成年国产在线观看 | 成人无码影片精品久久久 | 中文字幕亚洲情99在线 | 国产精品久久国产三级国 | 最新版天堂资源中文官网 | 麻豆人妻少妇精品无码专区 | 国产精品人妻一区二区三区四 | 久久亚洲精品中文字幕无男同 | 亚洲 激情 小说 另类 欧美 | 熟妇女人妻丰满少妇中文字幕 | 久久人妻内射无码一区三区 | 少妇被粗大的猛进出69影院 | 噜噜噜亚洲色成人网站 | 久久综合九色综合97网 | 色综合久久久无码中文字幕 | 成人女人看片免费视频放人 | 网友自拍区视频精品 | 丰腴饱满的极品熟妇 | 3d动漫精品啪啪一区二区中 | 国产成人无码专区 | 少妇愉情理伦片bd | 全黄性性激高免费视频 | 国产成人无码av一区二区 | 亚洲精品欧美二区三区中文字幕 | 性史性农村dvd毛片 | 亚洲成a人一区二区三区 | 日本高清一区免费中文视频 | 又色又爽又黄的美女裸体网站 | 国内丰满熟女出轨videos | 麻豆md0077饥渴少妇 | 扒开双腿吃奶呻吟做受视频 | а天堂中文在线官网 | 日韩av激情在线观看 | 亚洲色欲色欲欲www在线 | 伊人久久婷婷五月综合97色 | 成年美女黄网站色大免费全看 | 高清国产亚洲精品自在久久 | 精品一区二区三区无码免费视频 | 久久99热只有频精品8 | 内射欧美老妇wbb | 亚洲一区二区观看播放 | 丝袜足控一区二区三区 | 无码福利日韩神码福利片 | 午夜福利一区二区三区在线观看 | 97精品人妻一区二区三区香蕉 | 欧美熟妇另类久久久久久多毛 | 亚洲成av人综合在线观看 | 99精品视频在线观看免费 | 亚洲国产av美女网站 | 中文字幕乱码人妻二区三区 | 亚洲 欧美 激情 小说 另类 | 久久久精品456亚洲影院 | 久久精品无码一区二区三区 | 国产午夜亚洲精品不卡下载 | 亚洲人成网站免费播放 | 日本一本二本三区免费 | 欧美大屁股xxxxhd黑色 | 又粗又大又硬毛片免费看 | 精品久久久无码中文字幕 | 免费国产成人高清在线观看网站 | 麻豆国产97在线 | 欧洲 | 久久久久久久女国产乱让韩 | 波多野结衣一区二区三区av免费 | 激情五月综合色婷婷一区二区 | 98国产精品综合一区二区三区 | 日日躁夜夜躁狠狠躁 | 18精品久久久无码午夜福利 | 大色综合色综合网站 | 少妇愉情理伦片bd | 久久人妻内射无码一区三区 | 免费人成在线视频无码 | 东京无码熟妇人妻av在线网址 | 国产精品va在线观看无码 | 日产精品99久久久久久 | 亚洲а∨天堂久久精品2021 | 色狠狠av一区二区三区 | 亚洲理论电影在线观看 | 亚洲国产欧美国产综合一区 | 亚洲小说图区综合在线 | 在线精品国产一区二区三区 | 色一情一乱一伦一区二区三欧美 | 久久综合久久自在自线精品自 | 免费视频欧美无人区码 | 97精品人妻一区二区三区香蕉 | 国产成人综合在线女婷五月99播放 | 对白脏话肉麻粗话av | 永久免费观看国产裸体美女 | 东京热男人av天堂 | 久久人人爽人人人人片 | 少妇的肉体aa片免费 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 美女黄网站人色视频免费国产 | 中文字幕无码视频专区 | 自拍偷自拍亚洲精品10p | 久久久精品人妻久久影视 | а√资源新版在线天堂 | 久久综合九色综合97网 | 爽爽影院免费观看 | 亚洲s色大片在线观看 | 国产精品沙发午睡系列 | 老子影院午夜精品无码 | 成熟妇人a片免费看网站 | 日韩欧美中文字幕在线三区 | 天堂亚洲免费视频 | 国产办公室秘书无码精品99 | 97色伦图片97综合影院 | 一二三四在线观看免费视频 | 国产无套内射久久久国产 | 亚洲 日韩 欧美 成人 在线观看 | 国产精品第一区揄拍无码 | 婷婷丁香五月天综合东京热 | 亚洲区小说区激情区图片区 | 亚洲日韩av一区二区三区中文 | 真人与拘做受免费视频一 | 精品久久久无码人妻字幂 | 国产人妻精品一区二区三区 | 少妇无套内谢久久久久 | 国产色视频一区二区三区 | 天海翼激烈高潮到腰振不止 | 夜先锋av资源网站 | 真人与拘做受免费视频 | 丰满妇女强制高潮18xxxx | 国产无遮挡吃胸膜奶免费看 | aⅴ在线视频男人的天堂 | 亚洲国产精品一区二区美利坚 | 国产精品二区一区二区aⅴ污介绍 | 成人精品视频一区二区三区尤物 | 亚洲熟熟妇xxxx | 性生交大片免费看女人按摩摩 | 激情内射亚州一区二区三区爱妻 | 正在播放东北夫妻内射 | 装睡被陌生人摸出水好爽 | 亚洲中文字幕在线无码一区二区 | 国产精品亚洲专区无码不卡 | 少妇性荡欲午夜性开放视频剧场 | 国产色视频一区二区三区 | 欧美xxxx黑人又粗又长 | 日本www一道久久久免费榴莲 | 国产97人人超碰caoprom | 国产成人无码av片在线观看不卡 | 在线观看国产午夜福利片 | 色欲久久久天天天综合网精品 | 亚洲国产成人a精品不卡在线 | 亚洲午夜无码久久 | 国产一精品一av一免费 | 欧美精品在线观看 | 国产免费观看黄av片 | 亚洲国产精品久久人人爱 | 久久午夜无码鲁丝片午夜精品 | 亚洲国产精品毛片av不卡在线 | 婷婷六月久久综合丁香 | 国产 精品 自在自线 | 国内精品一区二区三区不卡 | 日产精品高潮呻吟av久久 | 无码中文字幕色专区 | 伊人久久大香线蕉午夜 | 亚洲色成人中文字幕网站 | 国产乡下妇女做爰 | 国产亚洲欧美日韩亚洲中文色 | 欧美日韩亚洲国产精品 | 国产乡下妇女做爰 | 野外少妇愉情中文字幕 | 国产成人精品必看 | 波多野结衣aⅴ在线 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 久久午夜无码鲁丝片午夜精品 | 日韩精品无码免费一区二区三区 | 亚洲日本va中文字幕 | 欧美老妇交乱视频在线观看 | 国产人成高清在线视频99最全资源 | 中文字幕 亚洲精品 第1页 | 日日摸夜夜摸狠狠摸婷婷 | 久久久中文久久久无码 | 乱人伦人妻中文字幕无码 | 久久精品女人天堂av免费观看 | 男女猛烈xx00免费视频试看 | 97夜夜澡人人双人人人喊 | 老太婆性杂交欧美肥老太 | 好男人社区资源 | 国产乱码精品一品二品 | 久久久亚洲欧洲日产国码αv | 久久午夜无码鲁丝片秋霞 | 久久精品国产精品国产精品污 | 无人区乱码一区二区三区 | 久久精品国产一区二区三区肥胖 | 国产香蕉尹人综合在线观看 | 国产精品18久久久久久麻辣 | 无码毛片视频一区二区本码 | 欧美人与禽猛交狂配 | 亚洲欧洲无卡二区视頻 | 中文字幕精品av一区二区五区 | 在线观看免费人成视频 | 久久国产精品二国产精品 | 欧美性生交活xxxxxdddd | 国产一区二区三区影院 | 成人一在线视频日韩国产 | a在线亚洲男人的天堂 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 女人被男人爽到呻吟的视频 | 日韩av激情在线观看 | 国产精品久免费的黄网站 | 天堂亚洲2017在线观看 | 国产成人精品久久亚洲高清不卡 | 国产亚洲精品久久久久久大师 | 日本xxxx色视频在线观看免费 | 一区二区传媒有限公司 | 久久精品国产亚洲精品 | 日韩av无码中文无码电影 | 人妻熟女一区 | 美女毛片一区二区三区四区 | 婷婷五月综合缴情在线视频 | 狂野欧美性猛交免费视频 | 中文字幕精品av一区二区五区 | 国产av一区二区三区最新精品 | 最近的中文字幕在线看视频 | 亚洲成av人在线观看网址 | 日韩 欧美 动漫 国产 制服 | 亲嘴扒胸摸屁股激烈网站 | 日本熟妇人妻xxxxx人hd | 国产成人人人97超碰超爽8 | 久久久精品人妻久久影视 | 久久久久久亚洲精品a片成人 | 人妻与老人中文字幕 | 97夜夜澡人人双人人人喊 | 激情亚洲一区国产精品 | 国产偷自视频区视频 | 日日摸天天摸爽爽狠狠97 | 亚洲成av人在线观看网址 | 亚洲日韩精品欧美一区二区 | 国产精品办公室沙发 | 国产农村乱对白刺激视频 | 国内精品久久久久久中文字幕 | 久久久久久久人妻无码中文字幕爆 | 久久国产劲爆∧v内射 | 日本高清一区免费中文视频 | 中文精品久久久久人妻不卡 | 免费无码一区二区三区蜜桃大 | 老司机亚洲精品影院 | 黑人巨大精品欧美一区二区 | 亚洲欧美色中文字幕在线 | 亚洲男人av天堂午夜在 | 久久人人爽人人爽人人片ⅴ | 天天躁夜夜躁狠狠是什么心态 | 美女极度色诱视频国产 | 无码av中文字幕免费放 | 国内揄拍国内精品人妻 | 国产在热线精品视频 | 性做久久久久久久久 | 免费男性肉肉影院 | 日韩av无码一区二区三区不卡 | 中文字幕无码免费久久9一区9 | 亚洲理论电影在线观看 | 激情内射日本一区二区三区 | 国产综合色产在线精品 | 奇米影视888欧美在线观看 | 国产精品视频免费播放 | 奇米影视888欧美在线观看 | 一本久久a久久精品亚洲 | 97久久国产亚洲精品超碰热 | 亚洲乱码日产精品bd | 性开放的女人aaa片 | 国产精品第一区揄拍无码 | 300部国产真实乱 | 无码帝国www无码专区色综合 | 国产无套内射久久久国产 | 精品久久综合1区2区3区激情 | 国产精品久久久久7777 | 亚洲精品一区二区三区在线 | 又湿又紧又大又爽a视频国产 | 性欧美videos高清精品 | 国产一区二区三区日韩精品 | 精品无人国产偷自产在线 | 性开放的女人aaa片 | 欧美性生交活xxxxxdddd | 国产午夜福利100集发布 | 亚洲欧美色中文字幕在线 | 成人性做爰aaa片免费看 | 成人三级无码视频在线观看 | 亚洲爆乳大丰满无码专区 | 国产精品第一区揄拍无码 | 国产精品久久久久无码av色戒 | 国产婷婷色一区二区三区在线 | 中文字幕乱码人妻无码久久 | 嫩b人妻精品一区二区三区 | 中文毛片无遮挡高清免费 | 久久99精品久久久久久 | 国产精品高潮呻吟av久久4虎 | 亚洲精品久久久久中文第一幕 | 免费乱码人妻系列无码专区 | 久久午夜无码鲁丝片午夜精品 | 欧美变态另类xxxx | 欧美亚洲日韩国产人成在线播放 | 一二三四社区在线中文视频 | 18精品久久久无码午夜福利 | 亚洲va欧美va天堂v国产综合 | 午夜熟女插插xx免费视频 | 日韩在线不卡免费视频一区 | 日本va欧美va欧美va精品 | 久久午夜夜伦鲁鲁片无码免费 | 女人和拘做爰正片视频 | 国模大胆一区二区三区 | 日日碰狠狠丁香久燥 | 国产乱人无码伦av在线a | 97精品国产97久久久久久免费 | 国产另类ts人妖一区二区 | 大色综合色综合网站 | 国产精品久久久久影院嫩草 | 内射后入在线观看一区 | 国产无遮挡吃胸膜奶免费看 | 99在线 | 亚洲 | 三级4级全黄60分钟 | 欧美精品国产综合久久 | 国产成人无码a区在线观看视频app | 亚洲狠狠婷婷综合久久 | 18精品久久久无码午夜福利 | www国产亚洲精品久久久日本 | 熟妇人妻无乱码中文字幕 | 日本精品少妇一区二区三区 | 欧美高清在线精品一区 | 欧美国产日韩久久mv | 国产精品人人妻人人爽 | 久久99精品国产麻豆蜜芽 | 少妇的肉体aa片免费 | 精品国产一区二区三区av 性色 | 欧美丰满熟妇xxxx性ppx人交 | 国产亚洲日韩欧美另类第八页 | 十八禁真人啪啪免费网站 | 激情内射亚州一区二区三区爱妻 | 网友自拍区视频精品 | 一本色道久久综合亚洲精品不卡 | 在线欧美精品一区二区三区 | 久久成人a毛片免费观看网站 | 台湾无码一区二区 | 欧美 亚洲 国产 另类 | 国产在线aaa片一区二区99 | 亚洲日韩av片在线观看 | 少妇高潮喷潮久久久影院 | 在教室伦流澡到高潮hnp视频 | 久久久精品人妻久久影视 | 蜜桃视频韩日免费播放 | 久久久亚洲欧洲日产国码αv | 国内精品人妻无码久久久影院蜜桃 | 成人免费视频视频在线观看 免费 | 成 人 免费观看网站 | 国产麻豆精品精东影业av网站 | 亚洲中文无码av永久不收费 | 欧美日韩一区二区综合 | 色综合久久88色综合天天 | 国产一精品一av一免费 | 天下第一社区视频www日本 | 蜜桃臀无码内射一区二区三区 | 撕开奶罩揉吮奶头视频 | 永久黄网站色视频免费直播 | 兔费看少妇性l交大片免费 | 久久99精品久久久久婷婷 | 99久久精品国产一区二区蜜芽 | 成人欧美一区二区三区黑人免费 | 亚洲自偷精品视频自拍 | 最近免费中文字幕中文高清百度 | 亚洲国产精华液网站w | 久久综合给合久久狠狠狠97色 | 国产免费无码一区二区视频 | 成年美女黄网站色大免费全看 | 国产人成高清在线视频99最全资源 | 人妻少妇被猛烈进入中文字幕 | 国产午夜视频在线观看 | 无码毛片视频一区二区本码 | 麻豆国产人妻欲求不满谁演的 | 丝袜人妻一区二区三区 | 成人aaa片一区国产精品 | 波多野结衣av在线观看 | 性色av无码免费一区二区三区 | 青青草原综合久久大伊人精品 | 国色天香社区在线视频 | 美女极度色诱视频国产 | 婷婷综合久久中文字幕蜜桃三电影 | 亚洲精品国产a久久久久久 | 亚洲色欲色欲欲www在线 | 丰满少妇人妻久久久久久 | 无套内谢的新婚少妇国语播放 | 欧美日韩视频无码一区二区三 | 又大又硬又爽免费视频 | 少妇无码一区二区二三区 | 久久精品丝袜高跟鞋 | 99久久无码一区人妻 | 亚洲国产精品毛片av不卡在线 | 东京热男人av天堂 | 亚洲男女内射在线播放 | 又黄又爽又色的视频 | 国产真实乱对白精彩久久 | 粉嫩少妇内射浓精videos | 男女爱爱好爽视频免费看 | 综合激情五月综合激情五月激情1 | 在线精品国产一区二区三区 | 日本精品人妻无码免费大全 | 色欲人妻aaaaaaa无码 | 日韩少妇白浆无码系列 | 国产精品永久免费视频 | 毛片内射-百度 | 午夜精品久久久内射近拍高清 | a片免费视频在线观看 | 人人澡人人透人人爽 | 色综合久久88色综合天天 | 国产一精品一av一免费 | 在线天堂新版最新版在线8 | 亚洲精品中文字幕久久久久 | 精品无码一区二区三区的天堂 | 无码人妻精品一区二区三区不卡 | 国产精品理论片在线观看 | 伊人久久大香线蕉av一区二区 | 伊人色综合久久天天小片 | 亚洲精品成a人在线观看 | 51国偷自产一区二区三区 | 99视频精品全部免费免费观看 | 免费播放一区二区三区 | 老熟妇乱子伦牲交视频 | 国产两女互慰高潮视频在线观看 | 亚洲无人区午夜福利码高清完整版 | 国产熟妇高潮叫床视频播放 | av无码电影一区二区三区 | 欧美人与动性行为视频 | 日本va欧美va欧美va精品 | 国产女主播喷水视频在线观看 | 丰满人妻一区二区三区免费视频 | 97久久国产亚洲精品超碰热 | av无码久久久久不卡免费网站 | 亚洲中文字幕av在天堂 | 男人扒开女人内裤强吻桶进去 | 亚洲s色大片在线观看 | 久久成人a毛片免费观看网站 | 丰满少妇高潮惨叫视频 | 成人片黄网站色大片免费观看 | 一本无码人妻在中文字幕免费 | 国产婷婷色一区二区三区在线 | 爽爽影院免费观看 | 国产肉丝袜在线观看 | 一个人看的www免费视频在线观看 | 丰满少妇高潮惨叫视频 | 男人扒开女人内裤强吻桶进去 | 欧美 日韩 人妻 高清 中文 | 亚洲色欲色欲天天天www | 国产 浪潮av性色四虎 | 国产亚洲精品久久久久久 | 国产精品人人爽人人做我的可爱 | 久久国产36精品色熟妇 | 人人妻人人澡人人爽人人精品 | 亚洲区小说区激情区图片区 | 国产莉萝无码av在线播放 | 一本色道久久综合狠狠躁 | 亚洲国产欧美国产综合一区 | 高清不卡一区二区三区 | 熟女少妇在线视频播放 | 婷婷色婷婷开心五月四房播播 | 在线欧美精品一区二区三区 | 免费无码的av片在线观看 | 人妻aⅴ无码一区二区三区 | 最近的中文字幕在线看视频 | 午夜精品一区二区三区在线观看 | 欧美人与禽zoz0性伦交 | 亚洲欧美综合区丁香五月小说 | 国产精品国产三级国产专播 | 成 人 免费观看网站 | 精品国产成人一区二区三区 | 伊人久久大香线蕉av一区二区 | 波多野结衣av在线观看 | 国内精品久久久久久中文字幕 | 欧美日韩综合一区二区三区 | 在线成人www免费观看视频 | 国产色视频一区二区三区 | 国产精品毛片一区二区 | 一区二区三区高清视频一 | 日本精品久久久久中文字幕 | 久久婷婷五月综合色国产香蕉 | 日韩欧美成人免费观看 | 男人扒开女人内裤强吻桶进去 | 伊人色综合久久天天小片 | 小sao货水好多真紧h无码视频 | 无套内谢的新婚少妇国语播放 | 欧美日韩色另类综合 | 青青草原综合久久大伊人精品 | 中文字幕+乱码+中文字幕一区 | 亚洲日韩av一区二区三区四区 | 亚洲の无码国产の无码步美 | 国产偷国产偷精品高清尤物 | 成人影院yy111111在线观看 | 日韩欧美中文字幕在线三区 | 中文字幕乱妇无码av在线 | 久久无码人妻影院 | 国内精品久久毛片一区二区 | 国产色在线 | 国产 | 精品日本一区二区三区在线观看 | 国产在线一区二区三区四区五区 | 青青青手机频在线观看 | 精品少妇爆乳无码av无码专区 | 国产熟妇高潮叫床视频播放 | 久久综合给久久狠狠97色 | 欧美日本免费一区二区三区 | 国内精品九九久久久精品 | 久久视频在线观看精品 | 性生交大片免费看女人按摩摩 | 久久精品中文闷骚内射 | 成人综合网亚洲伊人 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产精品无码mv在线观看 | 日韩精品无码一本二本三本色 | 国产色xx群视频射精 | 国产亚洲精品久久久闺蜜 | 国产亚洲日韩欧美另类第八页 | 少妇性俱乐部纵欲狂欢电影 | 欧美人与物videos另类 | 丰满人妻精品国产99aⅴ | 国产精品久久国产精品99 | 精品久久久久香蕉网 | 99精品久久毛片a片 | 久久精品丝袜高跟鞋 | 少妇被粗大的猛进出69影院 | 国产真实夫妇视频 | 国产绳艺sm调教室论坛 | 国产精品久久久久9999小说 | 激情亚洲一区国产精品 | 国产精品美女久久久 | 国产午夜无码精品免费看 | 人人妻在人人 | 久久久久久久女国产乱让韩 | 国产精品久久久久7777 | 影音先锋中文字幕无码 | 国产亚洲视频中文字幕97精品 | 又粗又大又硬又长又爽 | 国产无套粉嫩白浆在线 | 久久精品国产一区二区三区 | 日韩无码专区 | 国产在线一区二区三区四区五区 | 大地资源中文第3页 | 久久天天躁夜夜躁狠狠 | 国产精品视频免费播放 | 日本熟妇大屁股人妻 | 一二三四社区在线中文视频 | 久久久精品456亚洲影院 | 亚洲精品久久久久avwww潮水 | 国产真人无遮挡作爱免费视频 | 四虎国产精品免费久久 | 国产av无码专区亚洲awww | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 动漫av一区二区在线观看 | 成人精品天堂一区二区三区 | 日本xxxx色视频在线观看免费 | 动漫av一区二区在线观看 | 欧洲欧美人成视频在线 | av无码不卡在线观看免费 | 国产精品无码mv在线观看 | 性开放的女人aaa片 | 亚洲成熟女人毛毛耸耸多 | 久久亚洲a片com人成 | 女人和拘做爰正片视频 | 国产在线一区二区三区四区五区 | 兔费看少妇性l交大片免费 | 无码人妻精品一区二区三区不卡 | 中文字幕+乱码+中文字幕一区 | 国产猛烈高潮尖叫视频免费 | 女人被男人躁得好爽免费视频 | 国产精品自产拍在线观看 | 1000部啪啪未满十八勿入下载 | 午夜成人1000部免费视频 | 久久午夜无码鲁丝片 | 亚洲成a人片在线观看无码3d | 日本乱人伦片中文三区 | 国产精品.xx视频.xxtv | 亚洲精品美女久久久久久久 | 欧美老人巨大xxxx做受 | 男人的天堂av网站 | 亚洲人成无码网www | а天堂中文在线官网 | 野外少妇愉情中文字幕 | 熟女少妇在线视频播放 | 天天躁夜夜躁狠狠是什么心态 | 日本爽爽爽爽爽爽在线观看免 | 亚洲精品国产品国语在线观看 | 国产黑色丝袜在线播放 | 色妞www精品免费视频 | 成人精品一区二区三区中文字幕 | 国产乱人偷精品人妻a片 | 久久精品国产99久久6动漫 | 国产亚洲精品精品国产亚洲综合 | 日韩欧美中文字幕在线三区 | 国产成人精品久久亚洲高清不卡 | 成人欧美一区二区三区 | 成 人 免费观看网站 | 一区二区三区高清视频一 | 亚洲国产精品久久久久久 | 欧美日本日韩 | 久久久久久九九精品久 | 日韩亚洲欧美中文高清在线 | 欧美丰满少妇xxxx性 | 人人爽人人澡人人高潮 | 一个人看的www免费视频在线观看 | 欧美性黑人极品hd | 亚洲区欧美区综合区自拍区 | 国产区女主播在线观看 | 中文字幕无码视频专区 | 色婷婷欧美在线播放内射 | 亚洲国产欧美国产综合一区 | 亚洲 日韩 欧美 成人 在线观看 | 国内少妇偷人精品视频 | 人妻与老人中文字幕 | 久久国产自偷自偷免费一区调 | 真人与拘做受免费视频 | 欧美真人作爱免费视频 | 久久久久久久女国产乱让韩 | 国产sm调教视频在线观看 | 国产福利视频一区二区 | 日本熟妇人妻xxxxx人hd | 国产免费久久精品国产传媒 | 成人性做爰aaa片免费看 | 人妻aⅴ无码一区二区三区 | 蜜桃无码一区二区三区 | 国产激情艳情在线看视频 | 亚洲国产欧美日韩精品一区二区三区 | 97久久精品无码一区二区 | 亚洲精品一区二区三区四区五区 | 疯狂三人交性欧美 | 国产亚洲欧美日韩亚洲中文色 | 一二三四在线观看免费视频 | 伊人久久大香线蕉亚洲 | 久久久久免费精品国产 | 樱花草在线社区www | 又色又爽又黄的美女裸体网站 | 亚洲精品中文字幕久久久久 | 麻豆md0077饥渴少妇 | 中文字幕av日韩精品一区二区 | 亚洲中文字幕久久无码 | 久久人人爽人人人人片 | 国内揄拍国内精品少妇国语 | 国产免费观看黄av片 | 熟妇人妻中文av无码 | 无码精品国产va在线观看dvd | 蜜臀aⅴ国产精品久久久国产老师 | 精品国产一区二区三区四区在线看 | 综合人妻久久一区二区精品 | 牲欲强的熟妇农村老妇女 | 中文字幕乱妇无码av在线 | 又粗又大又硬毛片免费看 | 中文字幕av日韩精品一区二区 | 亚洲阿v天堂在线 | 欧美性色19p | 日本va欧美va欧美va精品 | 麻豆md0077饥渴少妇 | 少妇高潮一区二区三区99 | 人妻尝试又大又粗久久 | 极品尤物被啪到呻吟喷水 | 久热国产vs视频在线观看 | 天堂а√在线地址中文在线 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 久久天天躁狠狠躁夜夜免费观看 | 97夜夜澡人人双人人人喊 | 88国产精品欧美一区二区三区 | 黄网在线观看免费网站 | 成人精品天堂一区二区三区 | 亚洲午夜福利在线观看 | 动漫av网站免费观看 | 久久久久久久人妻无码中文字幕爆 | 乱码av麻豆丝袜熟女系列 | 亚洲国产成人a精品不卡在线 | 亚洲国产欧美国产综合一区 | 亚洲性无码av中文字幕 | 中文字幕乱码人妻无码久久 | 少妇被粗大的猛进出69影院 | 久久亚洲国产成人精品性色 | 亚洲色欲色欲天天天www | 在线播放免费人成毛片乱码 | 亚洲精品中文字幕久久久久 | 国产特级毛片aaaaaaa高清 | 极品嫩模高潮叫床 | 亚洲国产午夜精品理论片 | 少妇人妻大乳在线视频 | 一本无码人妻在中文字幕免费 | 伊人久久大香线蕉亚洲 | 国产黑色丝袜在线播放 | 无码一区二区三区在线观看 | 超碰97人人做人人爱少妇 | 一区二区三区高清视频一 | 国产无套内射久久久国产 | 人人妻人人澡人人爽欧美精品 | 正在播放东北夫妻内射 | 老司机亚洲精品影院 | 中文字幕无码免费久久99 | 少妇高潮一区二区三区99 | 九月婷婷人人澡人人添人人爽 | 漂亮人妻洗澡被公强 日日躁 | 久久精品国产亚洲精品 | 国产特级毛片aaaaaa高潮流水 | 国产精品久久久久9999小说 | 成 人影片 免费观看 | 人妻少妇精品无码专区动漫 | 日韩欧美中文字幕公布 | 欧美日韩一区二区三区自拍 | 精品一区二区三区波多野结衣 | 久久zyz资源站无码中文动漫 | 国产在线无码精品电影网 | 免费播放一区二区三区 | 思思久久99热只有频精品66 | 国产成人精品一区二区在线小狼 | 色综合视频一区二区三区 | 97精品人妻一区二区三区香蕉 | 中国大陆精品视频xxxx | 国产亚洲tv在线观看 | 国产成人无码区免费内射一片色欲 | 久久综合狠狠综合久久综合88 | 国产免费久久久久久无码 | 亚洲精品欧美二区三区中文字幕 | 久久午夜无码鲁丝片午夜精品 | 国产av无码专区亚洲awww | 狠狠色噜噜狠狠狠狠7777米奇 | 少妇高潮喷潮久久久影院 | 欧美丰满少妇xxxx性 | 国产偷自视频区视频 | 国产在线一区二区三区四区五区 | 精品久久8x国产免费观看 | 东京一本一道一二三区 | 久久久久人妻一区精品色欧美 | 国产精品久久久久影院嫩草 | 一本久道久久综合婷婷五月 | 亚洲熟熟妇xxxx | 中文字幕无码乱人伦 | 精品人妻av区 | 亚洲成av人片天堂网无码】 | 久久精品国产99久久6动漫 | 99久久精品日本一区二区免费 | 色一情一乱一伦一视频免费看 | 帮老师解开蕾丝奶罩吸乳网站 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 欧美真人作爱免费视频 | 亚洲精品午夜无码电影网 | 一本久道久久综合婷婷五月 | 欧洲熟妇精品视频 | 久久 国产 尿 小便 嘘嘘 | 久久久久久久女国产乱让韩 | 亚洲乱码中文字幕在线 | 日本www一道久久久免费榴莲 | 日本乱人伦片中文三区 | 精品无人区无码乱码毛片国产 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 久久国产劲爆∧v内射 | 日本一区二区三区免费播放 | 欧美成人免费全部网站 | 麻豆果冻传媒2021精品传媒一区下载 | 国产手机在线αⅴ片无码观看 | 国产成人无码专区 | 日韩人妻无码一区二区三区久久99 | 日韩精品a片一区二区三区妖精 | 日本精品高清一区二区 | 日日摸夜夜摸狠狠摸婷婷 | 三级4级全黄60分钟 | 国产熟妇另类久久久久 | 丝袜美腿亚洲一区二区 | 97无码免费人妻超级碰碰夜夜 | 99久久久无码国产精品免费 | 色婷婷综合激情综在线播放 | 国产手机在线αⅴ片无码观看 | 少妇性俱乐部纵欲狂欢电影 | 成人动漫在线观看 | 久久久久久a亚洲欧洲av冫 | 亚洲精品成a人在线观看 | 亚洲日韩中文字幕在线播放 | 色一情一乱一伦 | 亚洲精品美女久久久久久久 | 亚洲一区二区三区在线观看网站 | 亚洲伊人久久精品影院 | 国内综合精品午夜久久资源 | 一本久道久久综合狠狠爱 | 四虎4hu永久免费 |