3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

6、Qt Meta Object system 学习

發布時間:2024/4/17 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 6、Qt Meta Object system 学习 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原文地址:http://blog.csdn.net/ilvu999/article/details/8049908

?

使用 meta object system

  • 繼承自 QOject
  • 類定義中添加 Q_OBJECT 宏
  • 使用 moc 程序對包含該宏的文件進行處理

采用 qmake 進行處理時,如果頭文件xxx.h內包含 Q_OBJECT 宏,將生成 moc_xxx.cpp 文件。如果xxx.cpp文件內包含宏,將生成 xxx.moc 文件(這時,我們需要在xxx.cpp文件內添加?#include"xxx.moc")

Q_OBJECT宏

包括兩個方面,

  • 該宏在C++中的展開,有編譯預處理器完成
  • moc 程序對該宏的處理

宏定義

1 #define Q_OBJECT \2 public: \3 Q_OBJECT_CHECK \4 static const QMetaObject staticMetaObject; \5 Q_OBJECT_GETSTATICMETAOBJECT \6 virtual const QMetaObject *metaObject() const; \7 virtual void *qt_metacast(const char *); \8 QT_TR_FUNCTIONS \9 virtual int qt_metacall(QMetaObject::Call, int, void **); \ 10 private: \ 11 Q_DECL_HIDDEN static const QMetaObjectExtraData staticMetaObjectExtraData; \ 12 Q_DECL_HIDDEN static void qt_static_metacall(QObject *, QMetaObject::Call, int, void **);

?

而宏 QT_TR_FUNCTIONS 將展開為我們使程序國際化經常使用的 tr 與 trUtf8函數

1 # define QT_TR_FUNCTIONS \ 2 static inline QString tr(const char *s, const char *c = 0) \ 3 { return staticMetaObject.tr(s, c); } \ 4 static inline QString trUtf8(const char *s, const char *c = 0) \ 5 { return staticMetaObject.trUtf8(s, c); } \ 6 static inline QString tr(const char *s, const char *c, int n) \ 7 { return staticMetaObject.tr(s, c, n); } \ 8 static inline QString trUtf8(const char *s, const char *c, int n) \ 9 { return staticMetaObject.trUtf8(s, c, n); }

?

moc 處理

Q_OBJECT 為我們添加了這么多成員函數,而這些函數我們有沒有自己去實現,那么其定義在哪兒呢? 這就是 moc 為我們做的,自動生成這些成員函數的定義,放于生成的 xxx.moc 或 moc_xxx.cpp 文件內

注意:兩個文件的區別(如果你用cmake或其他工具的話,這點可能很重要)

  • 生成的 moc_xxx.cpp 中會自動包含 xxx.h 頭文件,所以它可以被獨立編譯成目標文件(.o 或 .obj)
  • 生成的 xxx.moc 是不會包含 xxx.cpp 的(要是包含就出問題了,能發現吧?),因此 xxx.moc 中沒有類定義,它無法被獨立編譯,只能被 include 到 xxx.cpp 中。

QMetaObject

既然 Q_OBJECT 展開成與 QMetaObject 有關的成員函數,看一下QMetaObject 都提供哪些常用功能

  • className() 返回類的名字
  • superClass() 返回父類的 QMetaObject 對象
  • method()與methodCount() 提供meta函數信息(包括signals, slots 與 invokable函數)
  • enumerator()與 enumeratorCount() 提供enum類型信息
  • propertyCount()與 property() 提供屬性信息
  • constructor()與 constructorCount() 提供 meta-constructors 信息

既然meta object能為我們的類提供這么多信息,那么這些信息存放哪兒了(大家肯定都能猜到秘密在moc生成的文件內,但為清楚起見,我們看一下QMetaObject的定義)。

這是用 struct 定義的一個類,我們略過其它,只看其數據成員

1 struct Q_CORE_EXPORT QMetaObject2 {3 const char *className() const;4 const QMetaObject *superClass() const;5 6 QObject *cast(QObject *obj) const;7 const QObject *cast(const QObject *obj) const;8 9 #ifndef QT_NO_TRANSLATION10 // ### Qt 4: Merge overloads11 QString tr(const char *s, const char *c) const;12 QString trUtf8(const char *s, const char *c) const;13 QString tr(const char *s, const char *c, int n) const;14 QString trUtf8(const char *s, const char *c, int n) const;15 #endif // QT_NO_TRANSLATION16 17 int methodOffset() const;18 int enumeratorOffset() const;19 int propertyOffset() const;20 int classInfoOffset() const;21 22 int constructorCount() const;23 int methodCount() const;24 int enumeratorCount() const;25 int propertyCount() const;26 int classInfoCount() const;27 28 int indexOfConstructor(const char *constructor) const;29 int indexOfMethod(const char *method) const;30 int indexOfSignal(const char *signal) const;31 int indexOfSlot(const char *slot) const;32 int indexOfEnumerator(const char *name) const;33 int indexOfProperty(const char *name) const;34 int indexOfClassInfo(const char *name) const;35 36 QMetaMethod constructor(int index) const;37 QMetaMethod method(int index) const;38 QMetaEnum enumerator(int index) const;39 QMetaProperty property(int index) const;40 QMetaClassInfo classInfo(int index) const;41 QMetaProperty userProperty() const;42 43 static bool checkConnectArgs(const char *signal, const char *method);44 static QByteArray normalizedSignature(const char *method);45 static QByteArray normalizedType(const char *type);46 47 // internal index-based connect48 static bool connect(const QObject *sender, int signal_index,49 const QObject *receiver, int method_index,50 int type = 0, int *types = 0);51 // internal index-based disconnect52 static bool disconnect(const QObject *sender, int signal_index,53 const QObject *receiver, int method_index);54 static bool disconnectOne(const QObject *sender, int signal_index,55 const QObject *receiver, int method_index);56 // internal slot-name based connect57 static void connectSlotsByName(QObject *o);58 59 // internal index-based signal activation60 static void activate(QObject *sender, int signal_index, void **argv); //obsolete61 static void activate(QObject *sender, int from_signal_index, int to_signal_index, void **argv); //obsolete62 static void activate(QObject *sender, const QMetaObject *, int local_signal_index, void **argv);63 static void activate(QObject *sender, const QMetaObject *, int from_local_signal_index, int to_local_signal_index, void **argv); //obsolete64 65 // internal guarded pointers66 static void addGuard(QObject **ptr);67 static void removeGuard(QObject **ptr);68 static void changeGuard(QObject **ptr, QObject *o);69 70 static bool invokeMethod(QObject *obj, const char *member,71 Qt::ConnectionType,72 QGenericReturnArgument ret,73 QGenericArgument val0 = QGenericArgument(0),74 QGenericArgument val1 = QGenericArgument(),75 QGenericArgument val2 = QGenericArgument(),76 QGenericArgument val3 = QGenericArgument(),77 QGenericArgument val4 = QGenericArgument(),78 QGenericArgument val5 = QGenericArgument(),79 QGenericArgument val6 = QGenericArgument(),80 QGenericArgument val7 = QGenericArgument(),81 QGenericArgument val8 = QGenericArgument(),82 QGenericArgument val9 = QGenericArgument());83 84 static inline bool invokeMethod(QObject *obj, const char *member,85 QGenericReturnArgument ret,86 QGenericArgument val0 = QGenericArgument(0),87 QGenericArgument val1 = QGenericArgument(),88 QGenericArgument val2 = QGenericArgument(),89 QGenericArgument val3 = QGenericArgument(),90 QGenericArgument val4 = QGenericArgument(),91 QGenericArgument val5 = QGenericArgument(),92 QGenericArgument val6 = QGenericArgument(),93 QGenericArgument val7 = QGenericArgument(),94 QGenericArgument val8 = QGenericArgument(),95 QGenericArgument val9 = QGenericArgument())96 {97 return invokeMethod(obj, member, Qt::AutoConnection, ret, val0, val1, val2, val3,98 val4, val5, val6, val7, val8, val9);99 } 100 101 static inline bool invokeMethod(QObject *obj, const char *member, 102 Qt::ConnectionType type, 103 QGenericArgument val0 = QGenericArgument(0), 104 QGenericArgument val1 = QGenericArgument(), 105 QGenericArgument val2 = QGenericArgument(), 106 QGenericArgument val3 = QGenericArgument(), 107 QGenericArgument val4 = QGenericArgument(), 108 QGenericArgument val5 = QGenericArgument(), 109 QGenericArgument val6 = QGenericArgument(), 110 QGenericArgument val7 = QGenericArgument(), 111 QGenericArgument val8 = QGenericArgument(), 112 QGenericArgument val9 = QGenericArgument()) 113 { 114 return invokeMethod(obj, member, type, QGenericReturnArgument(), val0, val1, val2, 115 val3, val4, val5, val6, val7, val8, val9); 116 } 117 118 static inline bool invokeMethod(QObject *obj, const char *member, 119 QGenericArgument val0 = QGenericArgument(0), 120 QGenericArgument val1 = QGenericArgument(), 121 QGenericArgument val2 = QGenericArgument(), 122 QGenericArgument val3 = QGenericArgument(), 123 QGenericArgument val4 = QGenericArgument(), 124 QGenericArgument val5 = QGenericArgument(), 125 QGenericArgument val6 = QGenericArgument(), 126 QGenericArgument val7 = QGenericArgument(), 127 QGenericArgument val8 = QGenericArgument(), 128 QGenericArgument val9 = QGenericArgument()) 129 { 130 return invokeMethod(obj, member, Qt::AutoConnection, QGenericReturnArgument(), val0, 131 val1, val2, val3, val4, val5, val6, val7, val8, val9); 132 } 133 134 QObject *newInstance(QGenericArgument val0 = QGenericArgument(0), 135 QGenericArgument val1 = QGenericArgument(), 136 QGenericArgument val2 = QGenericArgument(), 137 QGenericArgument val3 = QGenericArgument(), 138 QGenericArgument val4 = QGenericArgument(), 139 QGenericArgument val5 = QGenericArgument(), 140 QGenericArgument val6 = QGenericArgument(), 141 QGenericArgument val7 = QGenericArgument(), 142 QGenericArgument val8 = QGenericArgument(), 143 QGenericArgument val9 = QGenericArgument()) const; 144 145 enum Call { 146 InvokeMetaMethod, 147 ReadProperty, 148 WriteProperty, 149 ResetProperty, 150 QueryPropertyDesignable, 151 QueryPropertyScriptable, 152 QueryPropertyStored, 153 QueryPropertyEditable, 154 QueryPropertyUser, 155 CreateInstance 156 }; 157 158 int static_metacall(Call, int, void **) const; 159 static int metacall(QObject *, Call, int, void **); 160 161 #ifdef QT3_SUPPORT 162 QT3_SUPPORT const char *superClassName() const; 163 #endif 164 165 struct { // private data 166 const QMetaObject *superdata; 167 const char *stringdata; 168 const uint *data; 169 const void *extradata; 170 } d; 171 };

其中呢,

  • uperdata,指向父類的MetaObject,容易理解

  • extradata 似乎目前未啟用,不用理解
  • 剩下兩個是什么呢? 如你所想,就在 moc 生成的文件內

moc生成的文件

隨便找個 moc 文件出來看看

1 static const uint qt_meta_data_HPixmapScene[] = {...}; 2 static const char qt_meta_stringdata_HPixmapScene[] = {...}; 3 const QMetaObject HPixmapScene::staticMetaObject = { 4 { &QGraphicsScene::staticMetaObject, qt_meta_stringdata_HPixmapScene, 5 qt_meta_data_HPixmapScene, 0 } 6 };

這是一個QGraphicsScene的子類。對比前面QMetaObject的數據成員看看,是不是很簡單:

  • 先分別定義1個 uint 和 char 的數組,
  • 用這兩個數組首地址和父類的MetaObject的指針初始化 staticMetaObject

  • 這個 staticMetaObject 是我們自己的類的靜態成員變量

uint數組
接下來我們可以看看 uint 數組,這個數組中存放的是一些索引值,來指導我們從char字符串中提取信息

1 static const uint qt_meta_data_HPixmapScene[] = {2 3 // content:4 4, // revision5 0, // classname6 0, 0, // classinfo7 2, 14, // methods8 0, 0, // properties9 0, 0, // enums/sets 10 0, 0, // constructors 11 0, // flags 12 0, // signalCount 13 14 // slots: signature, parameters, type, tag, flags 15 18, 14, 13, 13, 0x0a, 16 41, 37, 13, 13, 0x0a, 17 18 0 // eod 19 };

對比QMetaObject用到的數據結構 QMetaObjectPrivate,看看,是不是豁然開朗了:uint 數組中的第一段 就對應這個結構體

1 struct QMetaObjectPrivate2 {3 int revision;4 int className;5 int classInfoCount, classInfoData;6 int methodCount, methodData;7 int propertyCount, propertyData;8 int enumeratorCount, enumeratorData;9 int constructorCount, constructorData; //since revision 2 10 int flags; //since revision 3 11 int signalCount; //since revision 4 12 // revision 5 introduces changes in normalized signatures, no new members 13 // revision 6 added qt_static_metacall as a member of each Q_OBJECT and inside QMetaObject itself 14 15 static inline const QMetaObjectPrivate *get(const QMetaObject *metaobject) 16 { return reinterpret_cast<const QMetaObjectPrivate*>(metaobject->d.data); } 17 18 static int indexOfSignalRelative(const QMetaObject **baseObject, 19 const char* name, 20 bool normalizeStringData); 21 static int indexOfSlotRelative(const QMetaObject **m, 22 const char *slot, 23 bool normalizeStringData); 24 static int originalClone(const QMetaObject *obj, int local_method_index); 25 26 #ifndef QT_NO_QOBJECT 27 //defined in qobject.cpp 28 enum DisconnectType { DisconnectAll, DisconnectOne }; 29 static void memberIndexes(const QObject *obj, const QMetaMethod &member, 30 int *signalIndex, int *methodIndex); 31 static bool connect(const QObject *sender, int signal_index, 32 const QObject *receiver, int method_index_relative, 33 const QMetaObject *rmeta = 0, 34 int type = 0, int *types = 0); 35 static bool disconnect(const QObject *sender, int signal_index, 36 const QObject *receiver, int method_index, 37 DisconnectType = DisconnectAll); 38 static inline bool disconnectHelper(QObjectPrivate::Connection *c, 39 const QObject *receiver, int method_index, 40 QMutex *senderMutex, DisconnectType); 41 #endif 42 };

?

char 數組

配合上面的索引數組,繼續看一下:

1 static const char qt_meta_stringdata_HPixmapScene[] = { 2 "HPixmapScene\0\0pix\0setPixmap(QPixmap)\0" 3 "img\0setImage(QImage)\0" 4 };

?

索引數組中 className 為0,我們看字符數組中從0開始是什么?恩,就是我們類的名字。

我們類的類中還定義的兩個slot函數

public slots:
void setPixmap(const QPixmap& pix);
void setImage(const QImage& img);

我們看看是怎么對應的,

  • 首先看索引數組 methodCount=2, methodData=14,告訴我們有兩個method,數據從索引數組的14開始
  • 然后,我們從索引數組的14開始看,{18,???14,???13,???13,?0x0a

  • 這兒,18和14對應到我們的char數組了,看一下,分別是setPixmap(QPixmap) 和 pix。怎么樣,和我們定義的函數對應上了吧。
有什么不對
  • 其實上面有一處不太對,從開始就不太對。什么不對呢?

Qt manual 對此只提了一句,在QObject的manual中,除此之外,似乎再沒出現過:要用 meta object system,我們不一定要繼承QObject,普通的C++的類也可以部分使用,與此對應,我們不用Q_OBJECT宏,而用Q_GADGET宏,當然,這個只提供部分meta object system 的功能,比如Qt 元對象系統之 "enum自省"?

另外:ActiveQt模塊中,QAxObject和QAxWidget 定義了信號槽,卻沒有使用Q_OBJECT,具體可以看?ActiveQt模塊學習(三)

另外 moc 生成的文件內有一個 Q_NO_DATA_RELOCATION 宏,無論用 Q_OBJECT 還是 Q_GADGET,我不清楚該宏起什么作用的。

整理思路太累了,寫完這個,還不清楚什么時候再寫(二)

參考
  • http://doc.qt.nokia.com/latest/object.html

  • http://doc.qt.nokia.com/latest/metaobjects.html

  • Qt MetaObject System詳解之一:簡介

  • Inside Qt Series (五):元對象系統(Meta-Object System)

?

Qt屬性系統(Qt's Property System)

使用

  • 使用 Q_PROPERTY 宏來聲明屬性(即 將屬性注冊到meta-object系統中)。
  • 通過QObject的metaObject即可獲得用Q_PROPERTY注冊的所有屬性
    • QMetaObject::property 返回QMetaProperty對象指針
    • QMetaObject::propertyCount 屬性個數(包含父類定義的屬性)
    • QMetaObject::propertyOffset 屬性的開始索引
    • QMetaObject::indexOfProperty 根據屬性名得到屬性索引
    • QMetaObject::userProperty 帶USER的屬性,無參數(只能有一個?)
  • 通過QMetaProperty可以獲得屬性的的各種信息
  • 使用QObjecty可以讀取或設置屬性
    • property
    • setProperty

Q_PROPERTY

Qt屬性是靠 Q_PROPERTY 宏進行聲明的

1 Q_PROPERTY(type name READ getFunction2 [WRITE setFunction]3 [RESET resetFunction]4 [NOTIFY notifySignal]5 [DESIGNABLE bool]6 [SCRIPTABLE bool]7 [STORED bool]8 [USER bool]9 [CONSTANT] 10 [FINAL])

例子:

1 Q_PROPERTY(bool focus READ hasFocus) 2 Q_PROPERTY(bool enabled READ isEnabled WRITE setEnabled) 3 Q_PROPERTY(QCursor cursor READ cursor WRITE setCursor RESET unsetCursor) 4 Q_PROPERTY(bool checked READ isChecked WRITE setChecked DESIGNABLE isCheckable NOTIFY toggled USER true)
  • READ 該項必須!后接無參的const函數
  • WRITE 后接無返回值的但參數函數
  • RESET 后接無參無返回值的函數
  • NOTIFT 后接單參的信號,屬性變化時發射
  • DESIGNABLE 布爾量(默認True),是否在designer中出現
  • SCRIPTABLE 布爾量(默認True),是否用于腳本
  • STORED 布爾量(默認True),是否“不依賴”其他值。比如mimimumWidth 依賴 mimimumSize,故為False
  • USER 布爾量(默認False),是否是直接面向用戶的。比如QPushButton的 checked 屬性,則為 True
  • CONSTANT 出現則代表常量。不可有 WRITE 及 NOTIFY
  • FINAL 出現則代表不能被派生類重載?

從源代碼文件 qobjectdefs.h 中可以看到該宏定義為空

1 #define Q_PROPERTY(TEXT)

也就是是說該宏僅對 moc 有意義,moc處理后生成的代碼在 xxx.moc 或 moc_xxx.cpp 中。

moc

看一個例子:

1 Q_PROPERTY(bool colorDialog READ colorDialogEnabled WRITE setColorDialogEnabled)

查看對應的moc文件:

  • 索引數據在?static?const?uint?qt_meta_data_QtColorPicker[]

  • 字符串數據在?static?const?char?qt_meta_stringdata_QtColorPicker[]

  • 并在 qt_metacall 函數中生成有相關的代碼

?

自測如下-->

源碼:

結果:

?

動態屬性
通過QObject的setProperty 設置屬性時,如果該屬性不存在,則為設置為動態屬性。動態屬性存儲在QObject中,而不是其QMetaObject對象中。

類型

  • 對于 enum 類型,需要用 Q_ENUMS 或Q_FLAGS 將其注冊到 meta-object系統中
  • 對自定義類型,如果要用作屬性,需要用 Q_DECLARE_METATYPE()將其注冊到meta-object系統中。

對 PySide 及 PyQt4

1 QtCore.pyqtProperty(type, fget=None, fset=None, freset=None, fdel=None, doc=None, designable=True, scriptable=True, stored=True, user=False, constant=False, final=False)2 3 type4 5 type of the property6 7 fget8 9 getter function 10 11 fset 12 13 None 14 15 setter function 16 17 freset 18 19 None 20 21 function used to reset the value of the property to its default value (only in C++) 22 23 fdel 24 25 None 26 27 function for del'ing the property (only in Python) 28 29 doc 30 31 None 32 33 docstring of the property 34 35 designable 36 37 True 38 39 value of Qt DESIGNABLE flag 40 41 scriptable 42 43 True 44 45 value of Qt SCRIPTABLE flag 46 47 stored 48 49 True 50 51 value of Qt STORED flag 52 53 user 54 55 False 56 57 value of Qt USER flag 58 59 constant 60 61 False 62 63 value of Qt CONSTANT flag 64 65 final 66 67 False 68 69 value of Qt FINAL flag

使用舉例:

1 class MyObject(QObject):2 def __init__(self,startval=42):3 self.ppval = startval4 def readPP(self):5 return self.ppval6 def setPP(self,val):7 self.ppval = val8 pp = pyqtProperty(int, readPP, setPP)9 10 obj = MyObject() 11 obj.pp = 47 12 print obj.pp

?

  • PySide用Property來取代pyqtProPerty

  • PySide一開始出現一個失誤,用的是QProperty而不是Property

  • PyQt4 為 fget 提供了默認的None,由于Qt要求READ函數必須有,故PySide不為其提供默認值

?

?看 ActiveQt 模塊的源碼,看到信號槽部分,實在看不懂了,只好回來繼續學習 元對象系統 了。

在前面的學習中中簡單整理了Q_OBJECT宏 與 moc 生成的文件,并且從中學習了屬性系統的宏 Q_PROPERTY。現在該看看源碼中信號槽相關的內容了(Qt4.7的源碼,其他版本與此可能不同)

1 QObject::connect

非常重要的函數,不是么?

函數一開始是這么一段:

1 bool QObject::connect(const QObject *sender, const char *signal,2 const QObject *receiver, const char *method,3 Qt::ConnectionType type)4 {5 {6 const void *cbdata[] = { sender, signal, receiver, method, &type };7 if (QInternal::activateCallbacks(QInternal::ConnectCallback, (void **) cbdata))8 return true;9 } 10 11 。。。。。。 12 }

?

這個復合語句的作用看不太懂,QInternal類的定義在 src/corelib/global/qnamespace.h 中,類成員的實現在 src/corelib/global/qglobal.cpp 中。

1 bool QInternal::activateCallbacks(Callback cb, void **parameters)2 {3 Q_ASSERT_X(cb >= 0, "QInternal::activateCallback()", "Callback id must be a valid id");4 5 QInternal_CallBackTable *cbt = global_callback_table();6 if (cbt && cb < cbt->callbacks.size()) {7 QList<qInternalCallback> callbacks = cbt->callbacks[cb];8 bool ret = false;9 for (int i=0; i<callbacks.size(); ++i) 10 ret |= (callbacks.at(i))(parameters); 11 return ret; 12 } 13 return false; 14 }

然后檢測4個參數是否都非空

1 if (sender == 0 || receiver == 0 || signal == 0 || method == 0) { 2 qWarning("QObject::connect: Cannot connect %s::%s to %s::%s", 3 sender ? sender->metaObject()->className() : "(null)", 4 (signal && *signal) ? signal+1 : "(null)", 5 receiver ? receiver->metaObject()->className() : "(null)", 6 (method && *method) ? method+1 : "(null)"); 7 return false; 8 }

?

然后

1 QByteArray tmp_signal_name; 2 3 if (!check_signal_macro(sender, signal, "connect", "bind")) 4 return false; 5 const QMetaObject *smeta = sender->metaObject();
  • 檢測與信號連接的“信號或槽”是否符合格式,然后從元對象系統中獲得相應的索引

檢測信號與槽的參數是否匹配,對與Queued連接,檢測參數是否注冊到元對象系統

1 ++signal; //skip code2 int signal_index = QMetaObjectPrivate::indexOfSignalRelative(&smeta, signal, false);3 if (signal_index < 0) {4 // check for normalized signatures5 tmp_signal_name = QMetaObject::normalizedSignature(signal - 1);6 signal = tmp_signal_name.constData() + 1;7 8 smeta = sender->metaObject();9 signal_index = QMetaObjectPrivate::indexOfSignalRelative(&smeta, signal, false); 10 } 11 if (signal_index < 0) { 12 // re-use tmp_signal_name and signal from above 13 14 smeta = sender->metaObject(); 15 signal_index = QMetaObjectPrivate::indexOfSignalRelative(&smeta, signal, true); 16 } 17 if (signal_index < 0) { 18 err_method_notfound(sender, signal_arg, "connect"); 19 err_info_about_objects("connect", sender, receiver); 20 return false; 21 } 22 signal_index = QMetaObjectPrivate::originalClone(smeta, signal_index); 23 int signalOffset, methodOffset; 24 computeOffsets(smeta, &signalOffset, &methodOffset); 25 int signal_absolute_index = signal_index + methodOffset; 26 signal_index += signalOffset; 27 28 QByteArray tmp_method_name; 29 int membcode = extract_code(method); 30 31 if (!check_method_code(membcode, receiver, method, "connect")) 32 return false; 33 const char *method_arg = method; 34 ++method; // skip code 35 36 const QMetaObject *rmeta = receiver->metaObject(); 37 int method_index_relative = -1; 38 switch (membcode) { 39 case QSLOT_CODE: 40 method_index_relative = QMetaObjectPrivate::indexOfSlotRelative(&rmeta, method, false); 41 break; 42 case QSIGNAL_CODE: 43 method_index_relative = QMetaObjectPrivate::indexOfSignalRelative(&rmeta, method, false); 44 break; 45 } 46 47 if (method_index_relative < 0) { 48 // check for normalized methods 49 tmp_method_name = QMetaObject::normalizedSignature(method); 50 method = tmp_method_name.constData(); 51 52 // rmeta may have been modified above 53 rmeta = receiver->metaObject(); 54 switch (membcode) { 55 case QSLOT_CODE: 56 method_index_relative = QMetaObjectPrivate::indexOfSlotRelative(&rmeta, method, false); 57 if (method_index_relative < 0) 58 method_index_relative = QMetaObjectPrivate::indexOfSlotRelative(&rmeta, method, true); 59 break; 60 case QSIGNAL_CODE: 61 method_index_relative = QMetaObjectPrivate::indexOfSignalRelative(&rmeta, method, false); 62 if (method_index_relative < 0) 63 method_index_relative = QMetaObjectPrivate::indexOfSignalRelative(&rmeta, method, true); 64 break; 65 } 66 } 67 68 if (method_index_relative < 0) { 69 err_method_notfound(receiver, method_arg, "connect"); 70 err_info_about_objects("connect", sender, receiver); 71 return false; 72 } 73 74 if (!QMetaObject::checkConnectArgs(signal, method)) { 75 qWarning("QObject::connect: Incompatible sender/receiver arguments" 76 "\n %s::%s --> %s::%s", 77 sender->metaObject()->className(), signal, 78 receiver->metaObject()->className(), method); 79 return false; 80 } 81 82 int *types = 0; 83 if ((type == Qt::QueuedConnection) 84 && !(types = queuedConnectionTypes(smeta->method(signal_absolute_index).parameterTypes()))) 85 return false; 86 87 #ifndef QT_NO_DEBUG 88 if (warnCompat) { 89 QMetaMethod smethod = smeta->method(signal_absolute_index); 90 QMetaMethod rmethod = rmeta->method(method_index_relative + rmeta->methodOffset()); 91 check_and_warn_compat(smeta, smethod, rmeta, rmethod); 92 } 93 #endif

?

若這一切都通過了,調用 QMetaObjectPrivate 的connect成員。調用成功,則調用 sender 對象的 connectNofify 函數(ActiveQt模塊使用了該函數)

1 if (!QMetaObjectPrivate::connect(sender, signal_index, receiver, method_index_relative, rmeta ,type, types)) 2 return false; 3 const_cast<QObject*>(sender)->connectNotify(signal - 1); 4 return true; 5 }

?

QMetaObjectPrivate::connect首先,檢測是否是 uniqueconnection ,如果是,則先搜索已有的連接,找到則函數返回

1 bool QMetaObjectPrivate::connect(const QObject *sender, int signal_index,2 const QObject *receiver, int method_index,3 const QMetaObject *rmeta, int type, int *types)4 {5 QObject *s = const_cast<QObject *>(sender);6 QObject *r = const_cast<QObject *>(receiver);7 8 int method_offset = rmeta ? rmeta->methodOffset() : 0;9 QObjectPrivate::StaticMetaCallFunction callFunction = 10 (rmeta && QMetaObjectPrivate::get(rmeta)->revision >= 6 && rmeta->d.extradata) 11 ? reinterpret_cast<const QMetaObjectExtraData *>(rmeta->d.extradata)->static_metacall : 0; 12 13 QOrderedMutexLocker locker(signalSlotLock(sender), 14 signalSlotLock(receiver)); 15 16 if (type & Qt::UniqueConnection) { 17 QObjectConnectionListVector *connectionLists = QObjectPrivate::get(s)->connectionLists; 18 if (connectionLists && connectionLists->count() > signal_index) { 19 const QObjectPrivate::Connection *c2 = 20 (*connectionLists)[signal_index].first; 21 22 int method_index_absolute = method_index + method_offset; 23 24 while (c2) { 25 if (c2->receiver == receiver && c2->method() == method_index_absolute) 26 return false; 27 c2 = c2->nextConnectionList; 28 } 29 } 30 type &= Qt::UniqueConnection - 1; 31 }

?

創建連接

1 QObjectPrivate::Connection *c = new QObjectPrivate::Connection;2 c->sender = s;3 c->receiver = r;4 c->method_relative = method_index;5 c->method_offset = method_offset;6 c->connectionType = type;7 c->argumentTypes = types;8 c->nextConnectionList = 0;9 c->callFunction = callFunction; 10 11 QT_TRY { 12 QObjectPrivate::get(s)->addConnection(signal_index, c); 13 } QT_CATCH(...) { 14 delete c; 15 QT_RETHROW; 16 } 17 18 c->prev = &(QObjectPrivate::get(r)->senders); 19 c->next = *c->prev; 20 *c->prev = c; 21 if (c->next) 22 c->next->prev = &c->next; 23 24 QObjectPrivate *const sender_d = QObjectPrivate::get(s); 25 if (signal_index < 0) { 26 sender_d->connectedSignals[0] = sender_d->connectedSignals[1] = ~0; 27 } else if (signal_index < (int)sizeof(sender_d->connectedSignals) * 8) { 28 sender_d->connectedSignals[signal_index >> 5] |= (1 << (signal_index & 0x1f)); 29 } 30 31 return true; 32 }

?

其他還有部分代碼,看不太懂,暫略(應該不影響理解)

?

QMetaObject::activate

信號的定義體在 moc 生成的文件內,在定義體中會調用 QMetaObject::activate 函數來實現信號的功能。

首先判斷該信號有無被鏈接,是否是block設置(具體含義?)

1 void QMetaObject::activate(QObject *sender, const QMetaObject *m, int local_signal_index,2 void **argv)3 {4 int signalOffset;5 int methodOffset;6 computeOffsets(m, &signalOffset, &methodOffset);7 8 int signal_index = signalOffset + local_signal_index;9 10 if (!sender->d_func()->isSignalConnected(signal_index)) 11 return; // nothing connected to these signals, and no spy 12 13 if (sender->d_func()->blockSig) 14 return;

?

和signal spy有關的一些代碼

1 int signal_absolute_index = methodOffset + local_signal_index;2 3 void *empty_argv[] = { 0 };4 if (qt_signal_spy_callback_set.signal_begin_callback != 0) {5 qt_signal_spy_callback_set.signal_begin_callback(sender, signal_absolute_index,6 argv ? argv : empty_argv);7 }8 9 Qt::HANDLE currentThreadId = QThread::currentThreadId(); 10 11 QMutexLocker locker(signalSlotLock(sender)); 12 QObjectConnectionListVector *connectionLists = sender->d_func()->connectionLists; 13 if (!connectionLists) { 14 locker.unlock(); 15 if (qt_signal_spy_callback_set.signal_end_callback != 0) 16 qt_signal_spy_callback_set.signal_end_callback(sender, signal_absolute_index); 17 return; 18 } 19 ++connectionLists->inUse;

?

用雙重循環依次處理每一個信號的每一個連接

1 const QObjectPrivate::ConnectionList *list;2 if (signal_index < connectionLists->count())3 list = &connectionLists->at(signal_index);4 else5 list = &connectionLists->allsignals;6 7 do {8 QObjectPrivate::Connection *c = list->first;9 if (!c) continue;10 // We need to check against last here to ensure that signals added11 // during the signal emission are not emitted in this emission.12 QObjectPrivate::Connection *last = list->last;13 14 do {15 if (!c->receiver)16 continue;17 18 QObject * const receiver = c->receiver;19 const bool receiverInSameThread = currentThreadId == receiver->d_func()->threadData->threadId;20 21 // determine if this connection should be sent immediately or22 // put into the event queue23 if ((c->connectionType == Qt::AutoConnection && !receiverInSameThread)24 || (c->connectionType == Qt::QueuedConnection)) { //對queued的連接單獨處理25 queued_activate(sender, signal_absolute_index, c, argv ? argv : empty_argv);26 continue;27 #ifndef QT_NO_THREAD28 } else if (c->connectionType == Qt::BlockingQueuedConnection) {29 locker.unlock();30 if (receiverInSameThread) {31 qWarning("Qt: Dead lock detected while activating a BlockingQueuedConnection: "32 "Sender is %s(%p), receiver is %s(%p)",33 sender->metaObject()->className(), sender,34 receiver->metaObject()->className(), receiver);35 }36 QSemaphore semaphore;37 QCoreApplication::postEvent(receiver, new QMetaCallEvent(c->method_offset, c->method_relative,38 c->callFunction,39 sender, signal_absolute_index,40 0, 0,41 argv ? argv : empty_argv,42 &semaphore));43 semaphore.acquire();44 locker.relock();45 continue;46 #endif47 }48 //對其他連接,繼續(發送與接收者在同一線程,則設置當前發送者,QObject::sender() 需要該功能)49 QObjectPrivate::Sender currentSender;50 QObjectPrivate::Sender *previousSender = 0;51 if (receiverInSameThread) {52 currentSender.sender = sender;53 currentSender.signal = signal_absolute_index;54 currentSender.ref = 1;55 previousSender = QObjectPrivate::setCurrentSender(receiver, &currentSender);56 }57 const QObjectPrivate::StaticMetaCallFunction callFunction = c->callFunction;58 const int method_relative = c->method_relative;59 if (callFunction && c->method_offset <= receiver->metaObject()->methodOffset()) {60 //we compare the vtable to make sure we are not in the destructor of the object.61 locker.unlock();62 if (qt_signal_spy_callback_set.slot_begin_callback != 0)63 qt_signal_spy_callback_set.slot_begin_callback(receiver, c->method(), argv ? argv : empty_argv);64 65 #if defined(QT_NO_EXCEPTIONS)66 callFunction(receiver, QMetaObject::InvokeMetaMethod, method_relative, argv ? argv : empty_argv);67 #else68 QT_TRY {69 callFunction(receiver, QMetaObject::InvokeMetaMethod, method_relative, argv ? argv : empty_argv);70 } QT_CATCH(...) {71 locker.relock();72 if (receiverInSameThread)73 QObjectPrivate::resetCurrentSender(receiver, &currentSender, previousSender);74 75 --connectionLists->inUse;76 Q_ASSERT(connectionLists->inUse >= 0);77 if (connectionLists->orphaned && !connectionLists->inUse)78 delete connectionLists;79 QT_RETHROW;80 }81 #endif82 if (qt_signal_spy_callback_set.slot_end_callback != 0)83 qt_signal_spy_callback_set.slot_end_callback(receiver, c->method());84 locker.relock();85 } else {86 const int method = method_relative + c->method_offset;87 locker.unlock();88 89 if (qt_signal_spy_callback_set.slot_begin_callback != 0) {90 qt_signal_spy_callback_set.slot_begin_callback(receiver,91 method,92 argv ? argv : empty_argv);93 }94 //調用metacall95 #if defined(QT_NO_EXCEPTIONS)96 metacall(receiver, QMetaObject::InvokeMetaMethod, method, argv ? argv : empty_argv);97 #else98 QT_TRY {99 metacall(receiver, QMetaObject::InvokeMetaMethod, method, argv ? argv : empty_argv); 100 } QT_CATCH(...) { 101 locker.relock(); 102 if (receiverInSameThread) 103 QObjectPrivate::resetCurrentSender(receiver, &currentSender, previousSender); 104 105 --connectionLists->inUse; 106 Q_ASSERT(connectionLists->inUse >= 0); 107 if (connectionLists->orphaned && !connectionLists->inUse) 108 delete connectionLists; 109 QT_RETHROW; 110 } 111 #endif 112 113 if (qt_signal_spy_callback_set.slot_end_callback != 0) 114 qt_signal_spy_callback_set.slot_end_callback(receiver, method); 115 116 locker.relock(); 117 } 118 119 if (receiverInSameThread) 120 QObjectPrivate::resetCurrentSender(receiver, &currentSender, previousSender); 121 122 if (connectionLists->orphaned) 123 break; 124 } while (c != last && (c = c->nextConnectionList) != 0); 125 126 if (connectionLists->orphaned) 127 break; 128 } while (list != &connectionLists->allsignals && 129 //start over for all signals; 130 ((list = &connectionLists->allsignals), true)); 131 132 --connectionLists->inUse; 133 Q_ASSERT(connectionLists->inUse >= 0); 134 if (connectionLists->orphaned) { 135 if (!connectionLists->inUse) 136 delete connectionLists; 137 } else if (connectionLists->dirty) { 138 sender->d_func()->cleanConnectionLists(); 139 } 140 141 locker.unlock(); 142 143 if (qt_signal_spy_callback_set.signal_end_callback != 0) 144 qt_signal_spy_callback_set.signal_end_callback(sender, signal_absolute_index); 145 146 }


接下來看metacall代碼

1 int QMetaObject::metacall(QObject *object, Call cl, int idx, void **argv) 2 { 3 if (QMetaObject *mo = object->d_ptr->metaObject) 4 return static_cast<QAbstractDynamicMetaObject*>(mo)->metaCall(cl, idx, argv); 5 else 6 return object->qt_metacall(cl, idx, argv); 7 }

前面的 QAbstractDynamicMetaObject 部分不清楚作用,后面的 qt_metacall 比較好理解了(代碼在moc生成的文件中)

queued_activate

首先是參數檢測,然后是構建 QMetaCallEvent 事件,并post該事件

1 static void queued_activate(QObject *sender, int signal, QObjectPrivate::Connection *c, void **argv)2 {3 if (!c->argumentTypes && c->argumentTypes != &DIRECT_CONNECTION_ONLY) {4 QMetaMethod m = sender->metaObject()->method(signal);5 int *tmp = queuedConnectionTypes(m.parameterTypes());6 if (!tmp) // cannot queue arguments7 tmp = &DIRECT_CONNECTION_ONLY;8 if (!c->argumentTypes.testAndSetOrdered(0, tmp)) {9 if (tmp != &DIRECT_CONNECTION_ONLY) 10 delete [] tmp; 11 } 12 } 13 if (c->argumentTypes == &DIRECT_CONNECTION_ONLY) // cannot activate 14 return; 15 int nargs = 1; // include return type 16 while (c->argumentTypes[nargs-1]) 17 ++nargs; 18 int *types = (int *) qMalloc(nargs*sizeof(int)); 19 Q_CHECK_PTR(types); 20 void **args = (void **) qMalloc(nargs*sizeof(void *)); 21 Q_CHECK_PTR(args); 22 types[0] = 0; // return type 23 args[0] = 0; // return value 24 for (int n = 1; n < nargs; ++n) 25 args[n] = QMetaType::construct((types[n] = c->argumentTypes[n-1]), argv[n]); 26 QCoreApplication::postEvent(c->receiver, new QMetaCallEvent(c->method_offset, 27 c->method_relative, 28 c->callFunction, 29 sender, signal, nargs, 30 types, args)); 31 }

?

blocking_activate

首先,檢測是否是同一線程,然后發送事件 QMetaCallEvent

既然和事件有關系,就看看事件是怎么回事

1 case QEvent::MetaCall:2 {3 #ifdef QT_JAMBI_BUILD4 d_func()->inEventHandler = false;5 #endif6 QMetaCallEvent *mce = static_cast<QMetaCallEvent*>(e);7 QObjectPrivate::Sender currentSender;8 currentSender.sender = const_cast<QObject*>(mce->sender());9 currentSender.signal = mce->signalId(); 10 currentSender.ref = 1; 11 QObjectPrivate::Sender * const previousSender = 12 QObjectPrivate::setCurrentSender(this, &currentSender); 13 #if defined(QT_NO_EXCEPTIONS) 14 mce->placeMetaCall(this); 15 #else 16 QT_TRY { 17 mce->placeMetaCall(this); 18 } QT_CATCH(...) { 19 QObjectPrivate::resetCurrentSender(this, &currentSender, previousSender); 20 QT_RETHROW; 21 } 22 #endif 23 QObjectPrivate::resetCurrentSender(this, &currentSender, previousSender); 24 break; 25 }

?

可以看到,這兒調用了 placeMetaCall

1 void QMetaCallEvent::placeMetaCall(QObject *object) 2 { 3 if (callFunction_) { 4 callFunction_(object, QMetaObject::InvokeMetaMethod, method_relative_, args_); 5 } else { 6 QMetaObject::metacall(object, QMetaObject::InvokeMetaMethod, method_offset_ + method_relative_, args_); 7 } 8 }

?

參考

  • http://blog.csdn.net/tingsking18/archive/2009/11/12/4800828.aspx

  • http://blog.csdn.net/tingsking18/archive/2009/12/12/4991563.aspx

?

基本理解

  • Q_DECLARE_METATYPE
    • 如果要使自定義類型或其他非QMetaType內置類型在QVaiant中使用,必須使用該宏。
    • 該類型必須有公有的 構造、析構、復制構造 函數
  • qRegisterMetaType 必須使用該函數的兩種情況
    • 如果非QMetaType內置類型要在 Qt 的屬性系統中使用
    • 如果非QMetaType內置類型要在 queued 信號與槽 中使用

二者關系

?

二者的代碼:

  • Q_DECLARE_METATYPE 展開后是一個特化后的類 QMetaTypeId<TYPE>

  • qRegisterMetaType 將某類型注冊中 MetaType 系統中

二者的聯系:

  • QMetaTypeId<TYPE>的類中的成員包含對qRegisterMetaType的調用

  • 我們知道類中的成員函數并不一定會被調用(即,該宏并不確保類型被注冊到MetaType)。

  • 通過qRegisterMetaType可以確保類型被注冊

兩個qRegisterMetaType 的聯系

  • 無參的qRegisterMetaType函數會通過該成員調用帶參數的qRegisterMetaType()

這兩個東西真難理清,不妨看看源碼吧。

1 Q_DECLARE_METATYPE

代碼來源:src/corelib/kernel/qmetatype.h

1 #define Q_DECLARE_METATYPE(TYPE) \2 QT_BEGIN_NAMESPACE \3 template <> \4 struct QMetaTypeId< TYPE > \5 { \6 enum { Defined = 1 }; \7 static int qt_metatype_id() \8 { \9 static QBasicAtomicInt metatype_id = Q_BASIC_ATOMIC_INITIALIZER(0); \ 10 if (!metatype_id) \ 11 metatype_id = qRegisterMetaType< TYPE >(#TYPE, \ 12 reinterpret_cast< TYPE *>(quintptr(-1))); \ 13 return metatype_id; \ 14 } \ 15 }; \ 16 QT_END_NAMESPACE

?

  • 宏展開是一個在Qt的命名空間中的一個類模板的特化 QMetaTypeId<TYPE>

  • 該類含一個enum和一個返回!QMetaType的id的成員函數

?

qRegisterMetaType(const char *typeName)

代碼來源:src/corelib/kernel/qmetatype.h

1 template <typename T>2 int qRegisterMetaType(const char *typeName3 #ifndef qdoc4 , T * dummy = 05 #endif6 )7 {8 const int typedefOf = dummy ? -1 : QtPrivate::QMetaTypeIdHelper<T>::qt_metatype_id();9 if (typedefOf != -1) 10 return QMetaType::registerTypedef(typeName, typedefOf); 11 12 typedef void*(*ConstructPtr)(const T*); 13 ConstructPtr cptr = qMetaTypeConstructHelper<T>; 14 typedef void(*DeletePtr)(T*); 15 DeletePtr dptr = qMetaTypeDeleteHelper<T>; 16 17 return QMetaType::registerType(typeName, reinterpret_cast<QMetaType::Destructor>(dptr), 18 reinterpret_cast<QMetaType::Constructor>(cptr)); 19 }

?

  • 該函數的核心就是調用了registerType 函數
  • 兩個Helper模板函數分別對構造和析構函數進行封裝

registerType

代碼來源:src/corelib/kernel/qmetatype.cpp

1 int QMetaType::registerType(const char *typeName, Destructor destructor,2 Constructor constructor)3 {4 QVector<QCustomTypeInfo> *ct = customTypes();5 if (!ct || !typeName || !destructor || !constructor)6 return -1;7 8 #ifdef QT_NO_QOBJECT9 NS(QByteArray) normalizedTypeName = typeName; 10 #else 11 NS(QByteArray) normalizedTypeName = QMetaObject::normalizedType(typeName); 12 #endif 13 14 int idx = qMetaTypeStaticType(normalizedTypeName.constData(), 15 normalizedTypeName.size()); 16 17 if (!idx) { 18 QWriteLocker locker(customTypesLock()); 19 idx = qMetaTypeCustomType_unlocked(normalizedTypeName.constData(), 20 normalizedTypeName.size()); 21 if (!idx) { 22 QCustomTypeInfo inf; 23 inf.typeName = normalizedTypeName; 24 inf.constr = constructor; 25 inf.destr = destructor; 26 inf.alias = -1; 27 idx = ct->size() + User; 28 ct->append(inf); 29 } 30 } 31 return idx; 32 }

函數功能:

  • 根據類型名查找其MetaType類型,如果已存在,則直接返回;否則創建后返回。

  • 創建一個 !QCustomTypeInfo 對象
  • 該對象包含要類型的構造、析構信息,已經規范化后的類型名
  • 該對象存入一個全局的!QVector中

qRegisterMetaType()

看manual,可以知道,qRegisterMetaType 還有一個無參的重載函數。

1 template <typename T> 2 inline int qRegisterMetaType() 3 { 4 return qMetaTypeId(static_cast<T *>(0)); 5 }

?

  • 函數看起來和帶參數的那個似乎區別很大(難道不是么?)。
  • 手冊中告訴我們,執行這個的時候,模板參數T必須用 Q_DECLARE_METATYPE() 聲明過
  • 能猜到原因嗎?注意看前面 Q_DECLARE_METATYPE() 代碼,
  • 對了。類中的成員函數qt_metatype_id中包含對qRegisterMetaType(typeName)的調用
  • 這兒就是輾轉調用了這個帶參數的qRegisterMetaType函數?

unregisterType(const char *typeName)

函數的作用是取消自己先前注冊的某個metatype類型。

前面提到注冊信息在一個全局的?QVector<QCustomTypeInfo>中,當取消注冊的時候是怎么樣的呢?直接刪除Vector中相應的項么?源碼告訴我們,不是的。

實際是查找到相應的項,清空該項的內容

1 void QMetaType::unregisterType(const char *typeName)2 {3 QVector<QCustomTypeInfo> *ct = customTypes();4 if (!ct || !typeName)5 return;6 7 #ifdef QT_NO_QOBJECT8 NS(QByteArray) normalizedTypeName = typeName;9 #else 10 NS(QByteArray) normalizedTypeName = QMetaObject::normalizedType(typeName); 11 #endif 12 QWriteLocker locker(customTypesLock()); 13 for (int v = 0; v < ct->count(); ++v) { 14 if (ct->at(v).typeName == typeName) { 15 QCustomTypeInfo &inf = (*ct)[v]; 16 inf.typeName.clear(); 17 inf.constr = 0; 18 inf.destr = 0; 19 inf.alias = -1; 20 } 21 } 22 }

?

?

Q_DECLARE_PRIVATE與Q_DECLARE_PUBLIC

這兩個宏在Qt的源碼中隨處可見,重要性不言而喻。在 部落格的 Inside Qt Series 系列文章中,他用了3篇文章來講這個問題。

因為 QObject 本身比較復雜,這兩個宏和一個復雜的東西攪和到一塊,還真是不好理解。不過幸好,這個兩個宏和QObject 沒有必然的聯系。故接下來,忘記 QObject,看一個普通的C++的類

例子

類 QtServiceController 定義:

1 class QtServiceController 2 { 3 Q_DECLARE_PRIVATE(QtServiceController) 4 public: 5 QtServiceController(const QString &name); 6 //省略其他 7 private: 8 QtServiceControllerPrivate *d_ptr; 9 };

類 QtServiceControllerPrivate 定義:

1 class QtServiceControllerPrivate 2 { 3 Q_DECLARE_PUBLIC(QtServiceController) 4 public: 5 QString serviceName; 6 QtServiceController *q_ptr; 7 };

將所有的private數據成員,獨立出來放于一個獨立的私有的數據對象中。這一點是比較好理解的,那么這兩個宏在這起什么作用呢?

注意:上面定義的兩個指針 d_ptr, q_ptr。

宏定義

宏定義在 QtGlobal(即qglobal.h)頭文件中:

1 #define Q_DECLARE_PRIVATE(Class) \2 inline Class##Private* d_func() { return reinterpret_cast<Class##Private *>(qGetPtrHelper(d_ptr)); } \3 inline const Class##Private* d_func() const { return reinterpret_cast<const Class##Private *>(qGetPtrHelper(d_ptr)); } \4 friend class Class##Private;5 6 #define Q_DECLARE_PRIVATE_D(Dptr, Class) \7 inline Class##Private* d_func() { return reinterpret_cast<Class##Private *>(Dptr); } \8 inline const Class##Private* d_func() const { return reinterpret_cast<const Class##Private *>(Dptr); } \9 friend class Class##Private; 10 11 #define Q_DECLARE_PUBLIC(Class) \ 12 inline Class* q_func() { return static_cast<Class *>(q_ptr); } \ 13 inline const Class* q_func() const { return static_cast<const Class *>(q_ptr); } \ 14 friend class Class;

這兩個宏在這看起來真蠻繞的,因為這個例子太簡單了,兩個宏的威力發揮不出來。反正核心就是:

  • 在 QtServiceController 中通過 d_func() 可以獲得 QtServiceControllerPrivate 的指針 d_ptr

  • 在 QtServiceControllerPrivate 中通過 q_func() 可以獲得 QtServiceController 的指針 q_ptr

Q_D 與 Q_Q

這是另兩個Qt源碼中隨處可見的宏,那么它們有什么用呢?

1 #define Q_D(Class) Class##Private * const d = d_func() 2 #define Q_Q(Class) Class * const q = q_func()

兩個宏展開后分別是對 d_func 和 q_func 兩個函數的調用,返回值分別賦值給 d 和 q 兩個指針變量。

于是:

  • 在 QtServiceController 中的成員函數中,我們只需要添加 Q_D(QtServiceController) 宏,在該函數內就可以直接用 d 來指代 d_ptr

  • 在 QtServiceControllerPrivate 中的成員函數中,我們只需要添加 Q_Q(QtServiceController)宏,在該函數內就可以直接用 q 來指代 q_ptr

d_ptr與q_ptr

繞這么大圈,為什么不直接用 d_ptr 與 q_ptr 呢。在,在我們的例子中,確實可以直接用,而且會更直接更簡單。官方這么用了,或許是為了和其他類保持一致吧。

但在其他情況下,這么做顯然是有意義的,因為 d_ptr 與 d,q_ptr 與 q 的類型并不一致(比如QObject系列)。這也是為何宏展開后有cast的原因。

參考

  • http://www.qkevin.com/archives/31

  • http://doc.qt.nokia.com/solutions/4/qtservice/qtservicebase.html

?

C++ GUI Qt4 編程?一書多線程部分提到invokeMethod的用法

QMetaObject::invokeMethod(label, SLOT(setText(const QString&)), Q_ARG(QString, "Hello"));

而 Qt Manual 中介紹卻是

  • You only need to pass the name of the signal or slot to this function, not the entire signature. For example, to asynchronously invoke the animateClick() slot on a QPushButton, use the following code:

?

QMetaObject::invokeMethod(pushButton, "animateClick");

這可怎么辦?一個是官方的圖書,一個是官方的Manual。是否意味著兩種方式都可以呢,還是說Qt的早期版本用的是前者?

查 Qt4.7/Qt4.6/Qt4.5/Qt4.4/Qt4.3/Qt4.2/Qt4.1/Qt4.0 ,結果發現都沒有提到前面的用法。是不是書的出錯呢?網上搜一下:確實有人抱怨它不工作

測試

本著事實就是的精神,還是先寫個程序測試一下:

1 #include <QtCore/QObject>2 #include <QtCore/QDebug>3 #include <QtCore/QCoreApplication>4 class Test : public QObject5 {6 Q_OBJECT7 public:8 Test(QObject * parent):QObject(parent)9 { 10 connect(this, SIGNAL(sig1(QString)), SLOT(slot1(QString))); 11 QMetaObject::invokeMethod(this, "sig1", Q_ARG(QString, "constructor")); 12 } 13 Q_INVOKABLE void method1(const QString& t) 14 { 15 qDebug()<<"from method:"<<t; 16 } 17 18 signals: 19 void sig1(const QString& t); 20 21 public slots: 22 void slot1(const QString& t) 23 { 24 qDebug()<<"from slot:"<<t; 25 } 26 }; 27 #include "main.moc" 28 int main(int argc, char *argv[]) 29 { 30 QCoreApplication a(argc, argv); 31 Test obj(0); 32 QMetaObject::invokeMethod(&obj, "slot1", Q_ARG(QString, "Hello")); 33 QMetaObject::invokeMethod(&obj, "method1", Q_ARG(QString, "Hello")); 34 QMetaObject::invokeMethod(&obj, SLOT(slot1(QString)), Q_ARG(QString, "Hello with SLOT")); 35 QMetaObject::invokeMethod(&obj, METHOD(method1(QString)), Q_ARG(QString, "Hello with METHOD")); 36 return a.exec(); 37 }

確實如他人所說,SLOT這種用法不工作

1 from slot: "constructor" 2 from slot: "Hello" 3 from method: "Hello" 4 QMetaObject::invokeMethod: No such method Test::1slot1(QString)(QString) 5 QMetaObject::invokeMethod: No such method Test::0method1(QString)(QString)

順便看看源碼吧

1 bool QMetaObject::invokeMethod(QObject *obj,2 const char *member,3 Qt::ConnectionType type,4 QGenericReturnArgument ret,5 QGenericArgument val0,6 QGenericArgument val1,7 QGenericArgument val2,8 QGenericArgument val3,9 QGenericArgument val4, 10 QGenericArgument val5, 11 QGenericArgument val6, 12 QGenericArgument val7, 13 QGenericArgument val8, 14 QGenericArgument val9) 15 { 16 if (!obj) 17 return false; 18 19 QVarLengthArray<char, 512> sig; 20 int len = qstrlen(member); 21 if (len <= 0) 22 return false;
//生成函數原型字符串(從這兒可以看到書中方法不工作的原因) 23 sig.append(member, len); 24 sig.append('('); 25 26 const char *typeNames[] = {ret.name(), val0.name(), val1.name(), val2.name(), val3.name(), 27 val4.name(), val5.name(), val6.name(), val7.name(), val8.name(), 28 val9.name()}; 29 30 int paramCount; 31 for (paramCount = 1; paramCount < MaximumParamCount; ++paramCount) { 32 len = qstrlen(typeNames[paramCount]); 33 if (len <= 0) 34 break; 35 sig.append(typeNames[paramCount], len); 36 sig.append(','); 37 } 38 if (paramCount == 1) 39 sig.append(')'); // no parameters 40 else 41 sig[sig.size() - 1] = ')'; 42 sig.append('\0'); 43 //在元對象系統中看該函數信息是否存在 44 int idx = obj->metaObject()->indexOfMethod(sig.constData()); 45 if (idx < 0) { 46 QByteArray norm = QMetaObject::normalizedSignature(sig.constData()); 47 idx = obj->metaObject()->indexOfMethod(norm.constData()); 48 } 49 50 if (idx < 0 || idx >= obj->metaObject()->methodCount()) { 51 qWarning("QMetaObject::invokeMethod: No such method %s::%s", 52 obj->metaObject()->className(), sig.constData()); 53 return false; 54 }
//獲得相應的 QMetaMethod,調用其 invoke 方法 55 QMetaMethod method = obj->metaObject()->method(idx); 56 return method.invoke(obj, type, ret, 57 val0, val1, val2, val3, val4, val5, val6, val7, val8, val9); 58 }

?

接著看看它的源碼,首先:

* 如果指定了返回值,檢查返回值的類型是否和QMetaMethod 的中的一致

1 bool QMetaMethod::invoke(QObject *object,2 Qt::ConnectionType connectionType,3 QGenericReturnArgument returnValue,4 QGenericArgument val0,5 QGenericArgument val1,6 QGenericArgument val2,7 QGenericArgument val3,8 QGenericArgument val4,9 QGenericArgument val5,10 QGenericArgument val6,11 QGenericArgument val7,12 QGenericArgument val8,13 QGenericArgument val9) const14 {15 if (!object || !mobj)16 return false;17 18 Q_ASSERT(mobj->cast(object));19 20 // check return type21 if (returnValue.data()) {22 const char *retType = typeName();23 if (qstrcmp(returnValue.name(), retType) != 0) {24 // normalize the return value as well25 // the trick here is to make a function signature out of the return type26 // so that we can call normalizedSignature() and avoid duplicating code27 QByteArray unnormalized;28 int len = qstrlen(returnValue.name());29 30 unnormalized.reserve(len + 3);31 unnormalized = "_("; // the function is called "_"32 unnormalized.append(returnValue.name());33 unnormalized.append(')');34 35 QByteArray normalized = QMetaObject::normalizedSignature(unnormalized.constData());36 normalized.truncate(normalized.length() - 1); // drop the ending ')'37 38 if (qstrcmp(normalized.constData() + 2, retType) != 0)39 return false;40 }41 }42 43 // check argument count (we don't allow invoking a method if given too few arguments)44 const char *typeNames[] = {45 returnValue.name(),46 val0.name(),47 val1.name(),48 val2.name(),49 val3.name(),50 val4.name(),51 val5.name(),52 val6.name(),53 val7.name(),54 val8.name(),55 val9.name()56 };57 int paramCount;58 for (paramCount = 1; paramCount < MaximumParamCount; ++paramCount) {59 if (qstrlen(typeNames[paramCount]) <= 0)60 break;61 }62 int metaMethodArgumentCount = 0;63 {64 // based on QMetaObject::parameterNames()65 const char *names = mobj->d.stringdata + mobj->d.data[handle + 1];66 if (*names == 0) {67 // do we have one or zero arguments?68 const char *signature = mobj->d.stringdata + mobj->d.data[handle];69 while (*signature && *signature != '(')70 ++signature;71 if (*++signature != ')')72 ++metaMethodArgumentCount;73 } else {74 --names;75 do {76 ++names;77 while (*names && *names != ',')78 ++names;79 ++metaMethodArgumentCount;80 } while (*names);81 }82 }83 if (paramCount <= metaMethodArgumentCount)84 return false;85
//為了利用現有的代碼來規范化這兒返回值的類型,這兒構造了一個函數_(typeOfReturn)。

????????? //檢查參數個數,傳遞的參數是否不少于需要的參數

????????? //檢查Connection的類型,處理AutoConnection

86 // check connection type87 QThread *currentThread = QThread::currentThread();88 QThread *objectThread = object->thread();89 if (connectionType == Qt::AutoConnection) {90 connectionType = currentThread == objectThread91 ? Qt::DirectConnection92 : Qt::QueuedConnection;93 }94 95 #ifdef QT_NO_THREAD96 if (connectionType == Qt::BlockingQueuedConnection) {97 connectionType = Qt::DirectConnection;98 }99 #endif 100 101 // invoke! 102 void *param[] = { 103 returnValue.data(), 104 val0.data(), 105 val1.data(), 106 val2.data(), 107 val3.data(), 108 val4.data(), 109 val5.data(), 110 val6.data(), 111 val7.data(), 112 val8.data(), 113 val9.data() 114 }; 115 // recompute the methodIndex by reversing the arithmetic in QMetaObject::property() 116 int idx_relative = ((handle - priv(mobj->d.data)->methodData) / 5); 117 int idx_offset = mobj->methodOffset(); 118 QObjectPrivate::StaticMetaCallFunction callFunction = 119 (QMetaObjectPrivate::get(mobj)->revision >= 6 && mobj->d.extradata) 120 ? reinterpret_cast<const QMetaObjectExtraData *>(mobj->d.extradata)->static_metacall : 0; 121 //對于 直連的,直接調 metacall,它進而去調用對象的 qt_metacall 122 if (connectionType == Qt::DirectConnection) { 123 if (callFunction) { 124 callFunction(object, QMetaObject::InvokeMetaMethod, idx_relative, param); 125 return true; 126 } else { 127 return QMetaObject::metacall(object, QMetaObject::InvokeMetaMethod, idx_relative + idx_offset, param) < 0; 128 } 129 } else if (connectionType == Qt::QueuedConnection) { //對于 Queued 的連接,post 相應的事件,進而轉到對象的event()函數中 130 if (returnValue.data()) { 131 qWarning("QMetaMethod::invoke: Unable to invoke methods with return values in " 132 "queued connections"); 133 return false; 134 } 135 136 int nargs = 1; // include return type 137 void **args = (void **) qMalloc(paramCount * sizeof(void *)); 138 Q_CHECK_PTR(args); 139 int *types = (int *) qMalloc(paramCount * sizeof(int)); 140 Q_CHECK_PTR(types); 141 types[0] = 0; // return type 142 args[0] = 0; 143 144 for (int i = 1; i < paramCount; ++i) { 145 types[i] = QMetaType::type(typeNames[i]); 146 if (types[i]) { 147 args[i] = QMetaType::construct(types[i], param[i]); 148 ++nargs; 149 } else if (param[i]) { 150 qWarning("QMetaMethod::invoke: Unable to handle unregistered datatype '%s'", 151 typeNames[i]); 152 for (int x = 1; x < i; ++x) { 153 if (types[x] && args[x]) 154 QMetaType::destroy(types[x], args[x]); 155 } 156 qFree(types); 157 qFree(args); 158 return false; 159 } 160 } 161 162 QCoreApplication::postEvent(object, new QMetaCallEvent(idx_offset, idx_relative, callFunction, 163 0, -1, nargs, types, args)); 164 } else { // blocking queued connection 165 #ifndef QT_NO_THREAD 166 if (currentThread == objectThread) { 167 qWarning("QMetaMethod::invoke: Dead lock detected in " 168 "BlockingQueuedConnection: Receiver is %s(%p)", 169 mobj->className(), object); 170 } 171 //對于 bolckedqueued 的連接,使用了信號量 172 QSemaphore semaphore; 173 QCoreApplication::postEvent(object, new QMetaCallEvent(idx_offset, idx_relative, callFunction, 174 0, -1, 0, 0, param, &semaphore)); 175 semaphore.acquire(); 176 #endif // QT_NO_THREAD 177 } 178 return true; 179 }

?

轉自:http://www.cnblogs.com/lfsblack/p/5284602.html

轉載于:https://www.cnblogs.com/liushui-sky/p/6474085.html

總結

以上是生活随笔為你收集整理的6、Qt Meta Object system 学习的全部內容,希望文章能夠幫你解決所遇到的問題。

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

精品一区二区三区无码免费视频 | 免费无码肉片在线观看 | 中文字幕无码av激情不卡 | 久久精品国产一区二区三区 | 中文字幕精品av一区二区五区 | 男人扒开女人内裤强吻桶进去 | 少女韩国电视剧在线观看完整 | 国产无遮挡吃胸膜奶免费看 | 在线播放无码字幕亚洲 | 欧洲熟妇色 欧美 | 2020久久香蕉国产线看观看 | 欧美激情内射喷水高潮 | 国产精品久久久久久久9999 | 妺妺窝人体色www在线小说 | 亚洲日韩精品欧美一区二区 | 日本又色又爽又黄的a片18禁 | 欧美国产亚洲日韩在线二区 | 欧美丰满熟妇xxxx性ppx人交 | 欧美老妇与禽交 | 国内精品久久久久久中文字幕 | 久久天天躁狠狠躁夜夜免费观看 | 精品水蜜桃久久久久久久 | 色欲av亚洲一区无码少妇 | 西西人体www44rt大胆高清 | 大肉大捧一进一出视频出来呀 | 欧美丰满少妇xxxx性 | 啦啦啦www在线观看免费视频 | 亚洲の无码国产の无码影院 | 一二三四在线观看免费视频 | 国产成人久久精品流白浆 | 精品久久久久久亚洲精品 | 少妇愉情理伦片bd | 久久亚洲日韩精品一区二区三区 | 亚洲精品中文字幕乱码 | 午夜精品一区二区三区在线观看 | 国产va免费精品观看 | 日韩人妻无码一区二区三区久久99 | 欧美刺激性大交 | 亚洲精品一区二区三区在线 | 2020久久超碰国产精品最新 | 国产精品亚洲lv粉色 | 成人一在线视频日韩国产 | 玩弄人妻少妇500系列视频 | 内射巨臀欧美在线视频 | 无码人妻av免费一区二区三区 | 国产一区二区三区精品视频 | 在线观看免费人成视频 | 久久久亚洲欧洲日产国码αv | 国产区女主播在线观看 | 丁香啪啪综合成人亚洲 | 亚洲s色大片在线观看 | 国产三级精品三级男人的天堂 | 欧美喷潮久久久xxxxx | 中文字幕精品av一区二区五区 | 蜜桃无码一区二区三区 | 亚洲 另类 在线 欧美 制服 | 日本www一道久久久免费榴莲 | 性欧美疯狂xxxxbbbb | 国产 精品 自在自线 | 在线播放亚洲第一字幕 | 兔费看少妇性l交大片免费 | 人妻中文无码久热丝袜 | a国产一区二区免费入口 | 亚洲精品国产a久久久久久 | 欧美熟妇另类久久久久久不卡 | 午夜无码人妻av大片色欲 | 亚洲 激情 小说 另类 欧美 | 国产熟女一区二区三区四区五区 | 无码人妻精品一区二区三区下载 | 国产精品久久久久久亚洲影视内衣 | 丁香花在线影院观看在线播放 | 亚洲精品中文字幕久久久久 | 免费无码的av片在线观看 | a片免费视频在线观看 | 久久成人a毛片免费观看网站 | 国内揄拍国内精品少妇国语 | 国产真人无遮挡作爱免费视频 | 亚洲日本在线电影 | 小鲜肉自慰网站xnxx | 影音先锋中文字幕无码 | 日韩av无码一区二区三区不卡 | 久久亚洲精品中文字幕无男同 | 美女黄网站人色视频免费国产 | 欧美日韩一区二区综合 | 精品国产青草久久久久福利 | 国产区女主播在线观看 | 久久天天躁夜夜躁狠狠 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 亚洲码国产精品高潮在线 | 55夜色66夜色国产精品视频 | 熟妇人妻无乱码中文字幕 | 国产成人人人97超碰超爽8 | 狠狠综合久久久久综合网 | 国产办公室秘书无码精品99 | 中文亚洲成a人片在线观看 | 蜜桃av抽搐高潮一区二区 | 免费看男女做好爽好硬视频 | 欧美精品免费观看二区 | 人妻少妇精品无码专区动漫 | 极品尤物被啪到呻吟喷水 | 99国产精品白浆在线观看免费 | 福利一区二区三区视频在线观看 | 亚洲人亚洲人成电影网站色 | 亚洲精品一区二区三区婷婷月 | 国产香蕉97碰碰久久人人 | 精品久久久无码中文字幕 | 亚洲小说春色综合另类 | 少妇无码av无码专区在线观看 | 97精品国产97久久久久久免费 | 少妇性l交大片欧洲热妇乱xxx | 国产精品人人妻人人爽 | 18精品久久久无码午夜福利 | 少妇无套内谢久久久久 | 国内老熟妇对白xxxxhd | 国色天香社区在线视频 | 国产亚洲精品久久久久久国模美 | 激情国产av做激情国产爱 | 国产激情综合五月久久 | 7777奇米四色成人眼影 | 亚洲呦女专区 | 亚洲日韩中文字幕在线播放 | 久久亚洲国产成人精品性色 | 女人和拘做爰正片视频 | 亚洲狠狠色丁香婷婷综合 | 久久伊人色av天堂九九小黄鸭 | 白嫩日本少妇做爰 | 亚洲欧美日韩综合久久久 | 奇米影视7777久久精品人人爽 | 精品久久久无码中文字幕 | 亚洲自偷自拍另类第1页 | 六十路熟妇乱子伦 | 无遮挡国产高潮视频免费观看 | 精品人人妻人人澡人人爽人人 | 蜜桃视频韩日免费播放 | 一本大道久久东京热无码av | 亚洲乱码中文字幕在线 | 久久久久久久女国产乱让韩 | 色情久久久av熟女人妻网站 | 久久国产自偷自偷免费一区调 | 国产无遮挡吃胸膜奶免费看 | 国产亲子乱弄免费视频 | 蜜桃视频韩日免费播放 | 国产成人av免费观看 | 久久综合久久自在自线精品自 | 国产成人无码av一区二区 | 国产农村妇女高潮大叫 | 日本熟妇浓毛 | 99在线 | 亚洲 | 国产成人精品视频ⅴa片软件竹菊 | 东京无码熟妇人妻av在线网址 | 久久精品国产大片免费观看 | 无码国内精品人妻少妇 | 性生交大片免费看女人按摩摩 | 欧美日韩人成综合在线播放 | 国产精品永久免费视频 | 久久精品人人做人人综合试看 | 人人爽人人爽人人片av亚洲 | 亚洲国产午夜精品理论片 | 曰韩无码二三区中文字幕 | 亚洲а∨天堂久久精品2021 | 国内丰满熟女出轨videos | 欧美亚洲国产一区二区三区 | 国产成人精品优优av | www国产亚洲精品久久网站 | 亚洲自偷自偷在线制服 | 国产精品久久久久9999小说 | 国产综合在线观看 | 久久久久人妻一区精品色欧美 | 久久亚洲日韩精品一区二区三区 | 中文字幕乱码人妻二区三区 | 中文字幕av无码一区二区三区电影 | 久久精品女人的天堂av | 国产高潮视频在线观看 | 高清国产亚洲精品自在久久 | 久久综合九色综合97网 | 国产精品99久久精品爆乳 | 中文无码精品a∨在线观看不卡 | 一区二区三区乱码在线 | 欧洲 | 天天爽夜夜爽夜夜爽 | 无码午夜成人1000部免费视频 | 丰满少妇人妻久久久久久 | 久久国产36精品色熟妇 | 无码国产激情在线观看 | 成人一在线视频日韩国产 | 嫩b人妻精品一区二区三区 | 老子影院午夜精品无码 | 欧美熟妇另类久久久久久不卡 | 东京热无码av男人的天堂 | www国产亚洲精品久久网站 | 久久精品中文闷骚内射 | 久久精品视频在线看15 | 日韩精品久久久肉伦网站 | 欧美三级不卡在线观看 | 成人无码精品一区二区三区 | 人妻尝试又大又粗久久 | 牲欲强的熟妇农村老妇女 | 成在人线av无码免观看麻豆 | 中国大陆精品视频xxxx | 中文字幕久久久久人妻 | 亚洲综合无码一区二区三区 | 久久精品中文闷骚内射 | 国产人妻大战黑人第1集 | 免费观看的无遮挡av | 久久久国产精品无码免费专区 | 人人妻人人藻人人爽欧美一区 | 国产高清不卡无码视频 | 欧美激情综合亚洲一二区 | 久久久精品人妻久久影视 | 玩弄少妇高潮ⅹxxxyw | 少妇太爽了在线观看 | 免费观看黄网站 | 亚洲国产精品无码久久久久高潮 | 欧美激情综合亚洲一二区 | 99久久亚洲精品无码毛片 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲人成影院在线观看 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 亚洲国产精品一区二区美利坚 | 精品无人区无码乱码毛片国产 | 亚洲爆乳精品无码一区二区三区 | 久久精品丝袜高跟鞋 | 欧美性猛交xxxx富婆 | av无码电影一区二区三区 | 国产精品国产自线拍免费软件 | 老熟妇乱子伦牲交视频 | 99riav国产精品视频 | 亚洲欧美精品伊人久久 | 欧洲熟妇色 欧美 | 国产女主播喷水视频在线观看 | 99久久久无码国产精品免费 | 狠狠色欧美亚洲狠狠色www | 强奷人妻日本中文字幕 | 成人免费视频视频在线观看 免费 | 中文无码精品a∨在线观看不卡 | 亚洲色欲色欲天天天www | 亚洲小说图区综合在线 | 天堂亚洲2017在线观看 | 亚洲精品一区国产 | 国产综合色产在线精品 | 亚洲人成影院在线无码按摩店 | 日韩亚洲欧美精品综合 | 国产成人亚洲综合无码 | 日本丰满熟妇videos | 亚洲一区二区三区国产精华液 | 性生交大片免费看女人按摩摩 | 久久人人爽人人人人片 | 四虎国产精品免费久久 | 天海翼激烈高潮到腰振不止 | 大胆欧美熟妇xx | 国产特级毛片aaaaaa高潮流水 | 麻豆果冻传媒2021精品传媒一区下载 | 高潮毛片无遮挡高清免费视频 | 免费观看的无遮挡av | 天天做天天爱天天爽综合网 | 俄罗斯老熟妇色xxxx | 久久综合色之久久综合 | 日本乱人伦片中文三区 | 少妇性l交大片欧洲热妇乱xxx | 一本久久a久久精品亚洲 | 国产在热线精品视频 | 国产 精品 自在自线 | 性做久久久久久久免费看 | 国产一区二区不卡老阿姨 | 亚洲另类伦春色综合小说 | 亚洲精品一区二区三区在线 | 超碰97人人射妻 | 伊人久久大香线焦av综合影院 | 欧美人与牲动交xxxx | 一本无码人妻在中文字幕免费 | 男女下面进入的视频免费午夜 | 精品无码国产自产拍在线观看蜜 | 国产乱子伦视频在线播放 | 综合人妻久久一区二区精品 | 亚洲七七久久桃花影院 | 色欲综合久久中文字幕网 | 性生交大片免费看女人按摩摩 | 精品久久久久久亚洲精品 | 久久99精品久久久久婷婷 | 成人亚洲精品久久久久软件 | 亚洲色在线无码国产精品不卡 | 人妻有码中文字幕在线 | 色五月五月丁香亚洲综合网 | 国内精品九九久久久精品 | 国产真实夫妇视频 | 99精品视频在线观看免费 | 久久伊人色av天堂九九小黄鸭 | 国产色视频一区二区三区 | 麻豆精产国品 | 人人妻人人澡人人爽人人精品浪潮 | 国产乱人无码伦av在线a | 人妻天天爽夜夜爽一区二区 | 欧美性猛交xxxx富婆 | 青春草在线视频免费观看 | 少妇太爽了在线观看 | 88国产精品欧美一区二区三区 | 国产乱人伦偷精品视频 | 亚洲va欧美va天堂v国产综合 | 国产精品.xx视频.xxtv | 亚洲国产精品成人久久蜜臀 | 亚洲人亚洲人成电影网站色 | 99精品国产综合久久久久五月天 | 国产成人精品一区二区在线小狼 | 欧美三级a做爰在线观看 | 日日麻批免费40分钟无码 | 一本久久a久久精品vr综合 | 亚洲精品综合一区二区三区在线 | 蜜桃臀无码内射一区二区三区 | 国产偷抇久久精品a片69 | 天堂亚洲2017在线观看 | 色一情一乱一伦一视频免费看 | 性色欲网站人妻丰满中文久久不卡 | 人人妻人人澡人人爽人人精品浪潮 | 日本精品少妇一区二区三区 | 无码人妻出轨黑人中文字幕 | 亚洲成a人片在线观看日本 | 免费人成在线观看网站 | 麻花豆传媒剧国产免费mv在线 | 国产精品a成v人在线播放 | 亚洲精品国产精品乱码视色 | 偷窥日本少妇撒尿chinese | 黄网在线观看免费网站 | 成人性做爰aaa片免费看 | 三上悠亚人妻中文字幕在线 | 对白脏话肉麻粗话av | 暴力强奷在线播放无码 | 亚洲精品成a人在线观看 | 东京无码熟妇人妻av在线网址 | 综合网日日天干夜夜久久 | 噜噜噜亚洲色成人网站 | 精品国产成人一区二区三区 | 国产亚洲视频中文字幕97精品 | 亚洲国精产品一二二线 | 国产色在线 | 国产 | 伊人久久大香线焦av综合影院 | 少妇久久久久久人妻无码 | 久久综合香蕉国产蜜臀av | 欧美怡红院免费全部视频 | 人人妻人人藻人人爽欧美一区 | 国产另类ts人妖一区二区 | 久久人人97超碰a片精品 | 国产精品久久国产三级国 | 亚洲精品一区二区三区婷婷月 | 色婷婷欧美在线播放内射 | 亚洲综合在线一区二区三区 | 国产99久久精品一区二区 | 国产激情无码一区二区app | 亚洲 日韩 欧美 成人 在线观看 | 成人免费视频在线观看 | 99精品国产综合久久久久五月天 | 婷婷丁香五月天综合东京热 | 日韩人妻无码一区二区三区久久99 | 国产 浪潮av性色四虎 | 青草青草久热国产精品 | 亚洲熟妇自偷自拍另类 | 最近的中文字幕在线看视频 | 欧美黑人巨大xxxxx | 好爽又高潮了毛片免费下载 | 久久午夜无码鲁丝片午夜精品 | 日本熟妇乱子伦xxxx | 精品偷自拍另类在线观看 | 国产精品无码mv在线观看 | 中文字幕人妻无码一区二区三区 | 亚洲熟妇色xxxxx欧美老妇y | 一区二区三区乱码在线 | 欧洲 | 亚洲色欲色欲天天天www | 婷婷五月综合缴情在线视频 | 亚洲欧洲中文日韩av乱码 | 亚洲中文无码av永久不收费 | 婷婷综合久久中文字幕蜜桃三电影 | 无码国产激情在线观看 | 色噜噜亚洲男人的天堂 | 人人爽人人澡人人高潮 | а√天堂www在线天堂小说 | 露脸叫床粗话东北少妇 | 夜夜影院未满十八勿进 | 国内精品久久毛片一区二区 | 人妻有码中文字幕在线 | 久久人人97超碰a片精品 | 十八禁视频网站在线观看 | 国产精品久久久久久久影院 | 丰满妇女强制高潮18xxxx | 麻花豆传媒剧国产免费mv在线 | 国产av无码专区亚洲awww | 清纯唯美经典一区二区 | 国产精品99久久精品爆乳 | 在线观看免费人成视频 | 国产网红无码精品视频 | 免费播放一区二区三区 | 又色又爽又黄的美女裸体网站 | v一区无码内射国产 | 国产内射爽爽大片视频社区在线 | 免费观看黄网站 | 欧美成人午夜精品久久久 | 最近的中文字幕在线看视频 | 亚洲乱亚洲乱妇50p | 欧美黑人乱大交 | 99视频精品全部免费免费观看 | 成人性做爰aaa片免费看 | 日韩av激情在线观看 | 亚洲精品一区二区三区四区五区 | 无码吃奶揉捏奶头高潮视频 | 少妇性荡欲午夜性开放视频剧场 | 亚洲人成无码网www | 亚洲色大成网站www国产 | 久久久精品456亚洲影院 | 无码乱肉视频免费大全合集 | 国产一区二区三区四区五区加勒比 | 夜夜高潮次次欢爽av女 | 久久国产精品偷任你爽任你 | 国产激情精品一区二区三区 | 99久久婷婷国产综合精品青草免费 | 性欧美熟妇videofreesex | 久久国内精品自在自线 | 伊人久久大香线蕉av一区二区 | 小泽玛莉亚一区二区视频在线 | 精品无人国产偷自产在线 | 欧美性色19p | 精品国产精品久久一区免费式 | 亚洲人成网站色7799 | 亚洲大尺度无码无码专区 | 亚洲熟悉妇女xxx妇女av | 黑人巨大精品欧美一区二区 | 久久精品女人天堂av免费观看 | 国产精品国产三级国产专播 | 欧美三级不卡在线观看 | 亚洲人成无码网www | 亚洲色成人中文字幕网站 | 麻豆人妻少妇精品无码专区 | 精品厕所偷拍各类美女tp嘘嘘 | 久久亚洲国产成人精品性色 | 欧美人与善在线com | 亚洲爆乳精品无码一区二区三区 | 亚洲啪av永久无码精品放毛片 | 国产精品欧美成人 | 亚洲精品一区二区三区四区五区 | 日本大香伊一区二区三区 | 国内精品人妻无码久久久影院蜜桃 | 国产在线aaa片一区二区99 | 色婷婷av一区二区三区之红樱桃 | 亚洲a无码综合a国产av中文 | 亚洲国产精品一区二区美利坚 | 午夜精品久久久内射近拍高清 | 青青青爽视频在线观看 | 男女爱爱好爽视频免费看 | 日本免费一区二区三区最新 | 性欧美大战久久久久久久 | 亚洲国产精品毛片av不卡在线 | 久久婷婷五月综合色国产香蕉 | 日韩精品成人一区二区三区 | 久久国产精品精品国产色婷婷 | 在线精品国产一区二区三区 | 国产农村乱对白刺激视频 | 人妻熟女一区 | 在线观看欧美一区二区三区 | 性欧美videos高清精品 | 国产亚洲日韩欧美另类第八页 | 亚洲s码欧洲m码国产av | 波多野结衣乳巨码无在线观看 | 国产精品va在线观看无码 | 老子影院午夜伦不卡 | a片在线免费观看 | 欧美熟妇另类久久久久久不卡 | 中文字幕色婷婷在线视频 | 国产又爽又猛又粗的视频a片 | 熟妇人妻中文av无码 | 色噜噜亚洲男人的天堂 | 亚洲 日韩 欧美 成人 在线观看 | 亚洲乱亚洲乱妇50p | 小泽玛莉亚一区二区视频在线 | а√天堂www在线天堂小说 | 国产精华av午夜在线观看 | 强奷人妻日本中文字幕 | 天天拍夜夜添久久精品 | 无码国产乱人伦偷精品视频 | 国产成人精品一区二区在线小狼 | 日日橹狠狠爱欧美视频 | 亚洲一区二区三区四区 | 中文字幕av伊人av无码av | 波多野结衣av一区二区全免费观看 | 噜噜噜亚洲色成人网站 | 免费乱码人妻系列无码专区 | 国产成人亚洲综合无码 | 成人精品一区二区三区中文字幕 | 双乳奶水饱满少妇呻吟 | 一区二区三区乱码在线 | 欧洲 | 99riav国产精品视频 | 国产乱码精品一品二品 | 国产精品人妻一区二区三区四 | 国产成人精品视频ⅴa片软件竹菊 | 日本大乳高潮视频在线观看 | 高清国产亚洲精品自在久久 | 中文字幕乱码人妻二区三区 | 国产午夜无码精品免费看 | 97久久精品无码一区二区 | 日日鲁鲁鲁夜夜爽爽狠狠 | 99精品无人区乱码1区2区3区 | 国产av无码专区亚洲awww | 少妇性荡欲午夜性开放视频剧场 | 无码中文字幕色专区 | 无遮挡啪啪摇乳动态图 | 在线观看免费人成视频 | 嫩b人妻精品一区二区三区 | 欧美xxxxx精品 | 久久综合九色综合欧美狠狠 | 亚洲中文字幕va福利 | 久久国语露脸国产精品电影 | 国产sm调教视频在线观看 | 国产精品美女久久久久av爽李琼 | 久久 国产 尿 小便 嘘嘘 | 又大又硬又黄的免费视频 | 成人免费视频视频在线观看 免费 | www成人国产高清内射 | 国产9 9在线 | 中文 | 欧美黑人乱大交 | 欧洲欧美人成视频在线 | 人人妻人人澡人人爽人人精品浪潮 | 国产一区二区三区精品视频 | 欧美日韩综合一区二区三区 | 亚洲精品久久久久久一区二区 | 国内揄拍国内精品少妇国语 | 国产亚洲精品久久久久久久久动漫 | 成人无码精品1区2区3区免费看 | 在线播放免费人成毛片乱码 | 日韩欧美中文字幕在线三区 | 国产亚洲精品久久久久久久久动漫 | 国产精品va在线播放 | 少妇被粗大的猛进出69影院 | 精品国产青草久久久久福利 | 亚洲日本va午夜在线电影 | 中文字幕人妻丝袜二区 | 97精品人妻一区二区三区香蕉 | 亚洲人成网站色7799 | 中文字幕+乱码+中文字幕一区 | 亚洲精品成人福利网站 | 国内精品人妻无码久久久影院 | 精品午夜福利在线观看 | 欧美国产日韩亚洲中文 | 国产无遮挡又黄又爽免费视频 | 白嫩日本少妇做爰 | 国产精品亚洲专区无码不卡 | 一本久久a久久精品亚洲 | 亚洲爆乳精品无码一区二区三区 | 中文字幕av伊人av无码av | 国产美女极度色诱视频www | 亚洲欧美日韩国产精品一区二区 | 欧洲美熟女乱又伦 | 国产口爆吞精在线视频 | 国产精品高潮呻吟av久久 | 国产精品视频免费播放 | 激情亚洲一区国产精品 | 青春草在线视频免费观看 | 日韩 欧美 动漫 国产 制服 | 极品尤物被啪到呻吟喷水 | 老熟女重囗味hdxx69 | 在教室伦流澡到高潮hnp视频 | 初尝人妻少妇中文字幕 | 暴力强奷在线播放无码 | 亚洲人成影院在线观看 | 国产精品欧美成人 | 野外少妇愉情中文字幕 | 成人免费视频在线观看 | 日韩欧美群交p片內射中文 | 午夜福利一区二区三区在线观看 | 一二三四在线观看免费视频 | 77777熟女视频在线观看 а天堂中文在线官网 | 婷婷五月综合缴情在线视频 | 漂亮人妻洗澡被公强 日日躁 | 欧美老妇交乱视频在线观看 | 奇米影视7777久久精品人人爽 | 久久精品99久久香蕉国产色戒 | 久久久精品国产sm最大网站 | 狠狠色噜噜狠狠狠7777奇米 | 在线播放无码字幕亚洲 | 野外少妇愉情中文字幕 | 国产av久久久久精东av | 国产激情一区二区三区 | 国产午夜亚洲精品不卡下载 | 娇妻被黑人粗大高潮白浆 | 无码人妻少妇伦在线电影 | 国产猛烈高潮尖叫视频免费 | 亚洲国产欧美国产综合一区 | 帮老师解开蕾丝奶罩吸乳网站 | 永久黄网站色视频免费直播 | 欧美老熟妇乱xxxxx | 成在人线av无码免费 | 欧美freesex黑人又粗又大 | 好爽又高潮了毛片免费下载 | 亚洲大尺度无码无码专区 | 性史性农村dvd毛片 | 国产97色在线 | 免 | 亚洲精品久久久久久一区二区 | 露脸叫床粗话东北少妇 | 乱码av麻豆丝袜熟女系列 | 女人被爽到呻吟gif动态图视看 | 日本爽爽爽爽爽爽在线观看免 | 国产精品无码一区二区桃花视频 | 亚洲精品一区二区三区大桥未久 | 在线天堂新版最新版在线8 | 蜜桃臀无码内射一区二区三区 | 中文无码精品a∨在线观看不卡 | 一本久道久久综合狠狠爱 | 美女极度色诱视频国产 | 全黄性性激高免费视频 | 国产福利视频一区二区 | 欧美freesex黑人又粗又大 | 色综合久久久无码网中文 | 日产精品高潮呻吟av久久 | 国产人妻人伦精品1国产丝袜 | 日韩人妻少妇一区二区三区 | 国产超碰人人爽人人做人人添 | 欧美国产日韩亚洲中文 | 亚洲国产欧美日韩精品一区二区三区 | 美女极度色诱视频国产 | 久久熟妇人妻午夜寂寞影院 | 国产精品国产三级国产专播 | 久久人人爽人人爽人人片av高清 | 亚洲精品国产精品乱码视色 | 欧美成人高清在线播放 | 日日噜噜噜噜夜夜爽亚洲精品 | 伊人久久大香线蕉午夜 | 久9re热视频这里只有精品 | 亚洲s色大片在线观看 | 午夜精品久久久久久久 | 国产精品久久久久9999小说 | 成人无码视频免费播放 | 亚洲狠狠婷婷综合久久 | 日本免费一区二区三区最新 | 无码播放一区二区三区 | 亚洲天堂2017无码中文 | 久久久久se色偷偷亚洲精品av | 免费人成在线观看网站 | 亚洲精品无码国产 | 丰满妇女强制高潮18xxxx | 特级做a爰片毛片免费69 | 国产亚av手机在线观看 | 久久综合给合久久狠狠狠97色 | 少妇高潮喷潮久久久影院 | 亚洲一区二区三区四区 | 精品厕所偷拍各类美女tp嘘嘘 | 久久久久久a亚洲欧洲av冫 | 国产精品国产三级国产专播 | av小次郎收藏 | 亚洲乱亚洲乱妇50p | 少妇久久久久久人妻无码 | 纯爱无遮挡h肉动漫在线播放 | 国产精品二区一区二区aⅴ污介绍 | 丝袜 中出 制服 人妻 美腿 | 激情综合激情五月俺也去 | 99麻豆久久久国产精品免费 | 免费观看的无遮挡av | 黑人巨大精品欧美黑寡妇 | 亚洲精品鲁一鲁一区二区三区 | 亚洲 a v无 码免 费 成 人 a v | 久久精品中文字幕一区 | 精品久久久久香蕉网 | 成熟女人特级毛片www免费 | 黑人玩弄人妻中文在线 | 思思久久99热只有频精品66 | 成熟女人特级毛片www免费 | 日产精品99久久久久久 | 女人高潮内射99精品 | 波多野结衣av一区二区全免费观看 | 亚洲国产精品一区二区第一页 | 无码纯肉视频在线观看 | 久久99精品久久久久婷婷 | v一区无码内射国产 | 亚洲一区二区三区无码久久 | 成人精品天堂一区二区三区 | 久久精品中文字幕一区 | 久久精品女人的天堂av | 欧美肥老太牲交大战 | 午夜福利不卡在线视频 | 亚洲乱码中文字幕在线 | 亚洲欧洲无卡二区视頻 | 天堂在线观看www | √天堂资源地址中文在线 | 国产香蕉97碰碰久久人人 | 国产精品毛片一区二区 | 亚洲一区二区观看播放 | 日日碰狠狠躁久久躁蜜桃 | 国产精品无码mv在线观看 | 狂野欧美性猛xxxx乱大交 | 国产无套内射久久久国产 | 人妻体内射精一区二区三四 | 日日天日日夜日日摸 | 国语精品一区二区三区 | 装睡被陌生人摸出水好爽 | 亚洲色欲久久久综合网东京热 | 日产精品99久久久久久 | 免费看男女做好爽好硬视频 | 少妇高潮喷潮久久久影院 | 性色欲网站人妻丰满中文久久不卡 | 色综合久久久无码中文字幕 | aⅴ亚洲 日韩 色 图网站 播放 | 免费无码av一区二区 | 99久久99久久免费精品蜜桃 | 无码福利日韩神码福利片 | 天天av天天av天天透 | 人人妻人人澡人人爽人人精品浪潮 | 亚洲aⅴ无码成人网站国产app | 国产内射老熟女aaaa | 国内老熟妇对白xxxxhd | 成 人影片 免费观看 | 成人欧美一区二区三区 | 青青青爽视频在线观看 | 久久亚洲精品中文字幕无男同 | 狠狠cao日日穞夜夜穞av | 国产无套粉嫩白浆在线 | 波多野结衣一区二区三区av免费 | 国产日产欧产精品精品app | 狠狠躁日日躁夜夜躁2020 | 中文无码成人免费视频在线观看 | 人妻少妇精品久久 | 国产av一区二区精品久久凹凸 | 最新国产麻豆aⅴ精品无码 | www国产亚洲精品久久久日本 | 欧美性猛交xxxx富婆 | 无码av免费一区二区三区试看 | 成人无码影片精品久久久 | 色五月丁香五月综合五月 | 色综合天天综合狠狠爱 | 国产午夜亚洲精品不卡下载 | 国产舌乚八伦偷品w中 | 色 综合 欧美 亚洲 国产 | 久久精品一区二区三区四区 | 欧美日本免费一区二区三区 | 亚洲阿v天堂在线 | 免费网站看v片在线18禁无码 | 欧美乱妇无乱码大黄a片 | 精品亚洲成av人在线观看 | 5858s亚洲色大成网站www | 成人欧美一区二区三区黑人 | 鲁大师影院在线观看 | 大肉大捧一进一出好爽视频 | 国产精品资源一区二区 | 欧美日本免费一区二区三区 | 夜先锋av资源网站 | 久久久亚洲欧洲日产国码αv | 亚洲中文字幕无码一久久区 | 亚洲七七久久桃花影院 | 麻花豆传媒剧国产免费mv在线 | 亚洲色在线无码国产精品不卡 | 亚洲国产精品久久人人爱 | 亚洲 a v无 码免 费 成 人 a v | 欧美性生交xxxxx久久久 | 亚洲精品久久久久久久久久久 | 成人性做爰aaa片免费看不忠 | www成人国产高清内射 | 国内少妇偷人精品视频免费 | 伊人久久大香线蕉亚洲 | 国产 精品 自在自线 | 四虎影视成人永久免费观看视频 | 少妇久久久久久人妻无码 | 国产区女主播在线观看 | 蜜桃无码一区二区三区 | 亚洲人成无码网www | 夜夜夜高潮夜夜爽夜夜爰爰 | 久久99精品国产.久久久久 | 欧美人与牲动交xxxx | 精品偷自拍另类在线观看 | 综合激情五月综合激情五月激情1 | 免费播放一区二区三区 | 在线观看国产午夜福利片 | 成人一在线视频日韩国产 | 亚洲欧美色中文字幕在线 | 中文字幕无码免费久久99 | 国产三级精品三级男人的天堂 | 天天综合网天天综合色 | 一区二区三区乱码在线 | 欧洲 | 国产偷抇久久精品a片69 | 亚洲精品一区二区三区婷婷月 | 日本又色又爽又黄的a片18禁 | 亚洲欧洲无卡二区视頻 | 国产亚洲日韩欧美另类第八页 | 高中生自慰www网站 | 久久久久人妻一区精品色欧美 | 强伦人妻一区二区三区视频18 | 久久国产精品萌白酱免费 | 亚洲精品国产精品乱码不卡 | 蜜臀aⅴ国产精品久久久国产老师 | 久久综合给合久久狠狠狠97色 | 人人澡人人妻人人爽人人蜜桃 | 久久99精品国产.久久久久 | 丰满人妻一区二区三区免费视频 | 国内老熟妇对白xxxxhd | 色窝窝无码一区二区三区色欲 | 99麻豆久久久国产精品免费 | 亚洲精品国偷拍自产在线麻豆 | 亚洲性无码av中文字幕 | 国产人妻久久精品二区三区老狼 | 一本久久a久久精品vr综合 | 天堂久久天堂av色综合 | 牲欲强的熟妇农村老妇女视频 | 一区二区三区高清视频一 | 超碰97人人做人人爱少妇 | 精品厕所偷拍各类美女tp嘘嘘 | 一本久道久久综合狠狠爱 | 在线观看国产一区二区三区 | 大色综合色综合网站 | 日本精品人妻无码77777 天堂一区人妻无码 | 无码成人精品区在线观看 | 色婷婷香蕉在线一区二区 | 久久精品国产一区二区三区 | 国产人妻大战黑人第1集 | 亚洲中文字幕在线无码一区二区 | 精品久久久无码人妻字幂 | 国产精品久久久久无码av色戒 | 偷窥日本少妇撒尿chinese | 久久国产精品偷任你爽任你 | 丰满人妻被黑人猛烈进入 | 300部国产真实乱 | 97久久超碰中文字幕 | 东京一本一道一二三区 | 中文精品无码中文字幕无码专区 | 久久综合激激的五月天 | 131美女爱做视频 | 夜夜影院未满十八勿进 | 在线视频网站www色 | 2020最新国产自产精品 | 欧美 亚洲 国产 另类 | 97久久超碰中文字幕 | 国产精品香蕉在线观看 | 在线观看欧美一区二区三区 | 久久久久se色偷偷亚洲精品av | 少妇性荡欲午夜性开放视频剧场 | 国产精品久久久av久久久 | 丰满少妇弄高潮了www | 亚洲无人区一区二区三区 | 国产国产精品人在线视 | 亚洲va欧美va天堂v国产综合 | 人人妻人人澡人人爽人人精品 | 国产精品二区一区二区aⅴ污介绍 | 亚洲国产av精品一区二区蜜芽 | 亚洲中文字幕无码中文字在线 | 四虎影视成人永久免费观看视频 | 中文字幕无码人妻少妇免费 | 国产精品二区一区二区aⅴ污介绍 | 久久久久久a亚洲欧洲av冫 | 国产欧美精品一区二区三区 | 日本肉体xxxx裸交 | 欧美人与物videos另类 | 国产精品久久国产精品99 | 未满小14洗澡无码视频网站 | 国产午夜福利亚洲第一 | 欧美性生交活xxxxxdddd | 鲁一鲁av2019在线 | 亚洲国产成人av在线观看 | 人人妻人人澡人人爽人人精品浪潮 | 人人超人人超碰超国产 | 内射后入在线观看一区 | 在线 国产 欧美 亚洲 天堂 | 乱码午夜-极国产极内射 | 国产97色在线 | 免 | 欧洲精品码一区二区三区免费看 | 日日橹狠狠爱欧美视频 | 欧美精品免费观看二区 | 美女极度色诱视频国产 | 大肉大捧一进一出视频出来呀 | 少妇高潮一区二区三区99 | 亚洲a无码综合a国产av中文 | 国产亚洲人成在线播放 | 麻豆蜜桃av蜜臀av色欲av | 精品国产麻豆免费人成网站 | 国产美女极度色诱视频www | 亚洲综合在线一区二区三区 | 少妇的肉体aa片免费 | 国产乱人偷精品人妻a片 | 无码乱肉视频免费大全合集 | 美女毛片一区二区三区四区 | 日本爽爽爽爽爽爽在线观看免 | 国产偷自视频区视频 | 婷婷色婷婷开心五月四房播播 | 午夜不卡av免费 一本久久a久久精品vr综合 | 在线亚洲高清揄拍自拍一品区 | 中文毛片无遮挡高清免费 | 国产激情精品一区二区三区 | 国产无遮挡又黄又爽又色 | 俺去俺来也在线www色官网 | 岛国片人妻三上悠亚 | 日韩少妇白浆无码系列 | 97无码免费人妻超级碰碰夜夜 | 亲嘴扒胸摸屁股激烈网站 | 麻豆国产人妻欲求不满 | 狠狠综合久久久久综合网 | 大肉大捧一进一出好爽视频 | 一本久道久久综合狠狠爱 | 精品人人妻人人澡人人爽人人 | 色窝窝无码一区二区三区色欲 | 亚洲成a人片在线观看日本 | 午夜理论片yy44880影院 | 国产xxx69麻豆国语对白 | 国产欧美熟妇另类久久久 | 亚洲欧美国产精品专区久久 | 狠狠躁日日躁夜夜躁2020 | 久久久婷婷五月亚洲97号色 | 亚洲乱码日产精品bd | www国产亚洲精品久久网站 | 性欧美牲交xxxxx视频 | 久久综合狠狠综合久久综合88 | 国内精品人妻无码久久久影院 | 日本乱人伦片中文三区 | 无码国产色欲xxxxx视频 | 日本乱人伦片中文三区 | 色婷婷久久一区二区三区麻豆 | 国精品人妻无码一区二区三区蜜柚 | 欧美老熟妇乱xxxxx | 最近中文2019字幕第二页 | 天干天干啦夜天干天2017 | 性啪啪chinese东北女人 | 久久精品国产一区二区三区 | 综合人妻久久一区二区精品 | 日欧一片内射va在线影院 | 一本久道久久综合婷婷五月 | 99久久精品国产一区二区蜜芽 | 欧美大屁股xxxxhd黑色 | 精品成人av一区二区三区 | 丰满岳乱妇在线观看中字无码 | 中文无码精品a∨在线观看不卡 | 免费看少妇作爱视频 | 99精品视频在线观看免费 | av无码不卡在线观看免费 | 精品偷自拍另类在线观看 | 亚洲综合色区中文字幕 | a片免费视频在线观看 | 成人性做爰aaa片免费看 | 美女扒开屁股让男人桶 | 国产精品igao视频网 | 亚洲日韩中文字幕在线播放 | 国产三级精品三级男人的天堂 | 精品水蜜桃久久久久久久 | 亚洲成a人片在线观看无码3d | 麻豆国产97在线 | 欧洲 | 露脸叫床粗话东北少妇 | 老熟女乱子伦 | 国产日产欧产精品精品app | 国产 精品 自在自线 | 久久久精品国产sm最大网站 | 狠狠色噜噜狠狠狠7777奇米 | 沈阳熟女露脸对白视频 | 天堂亚洲免费视频 | 国内精品人妻无码久久久影院蜜桃 | 日本熟妇浓毛 | 玩弄人妻少妇500系列视频 | 99久久久无码国产aaa精品 | 无码中文字幕色专区 | 国产人妻精品午夜福利免费 | 久久国产精品萌白酱免费 | 色五月五月丁香亚洲综合网 | 日韩视频 中文字幕 视频一区 | 久久亚洲中文字幕精品一区 | 国产精品高潮呻吟av久久 | 天堂在线观看www | 乌克兰少妇xxxx做受 | 久久zyz资源站无码中文动漫 | 色婷婷综合激情综在线播放 | 国产sm调教视频在线观看 | 日韩精品乱码av一区二区 | 成人动漫在线观看 | 夜夜高潮次次欢爽av女 | 国产乱人无码伦av在线a | 久久久精品人妻久久影视 | av在线亚洲欧洲日产一区二区 | 国产真人无遮挡作爱免费视频 | 波多野42部无码喷潮在线 | 国产乱人偷精品人妻a片 | 又紧又大又爽精品一区二区 | 久久久精品456亚洲影院 | 国产一区二区三区精品视频 | 强伦人妻一区二区三区视频18 | 55夜色66夜色国产精品视频 | 人人妻人人澡人人爽欧美精品 | 99精品国产综合久久久久五月天 | 天天躁夜夜躁狠狠是什么心态 | 玩弄中年熟妇正在播放 | 丰满少妇人妻久久久久久 | 青春草在线视频免费观看 | 影音先锋中文字幕无码 | √8天堂资源地址中文在线 | 久久综合激激的五月天 | 丰满少妇女裸体bbw | 在线a亚洲视频播放在线观看 | 亚洲人交乣女bbw | 天下第一社区视频www日本 | 无码国产激情在线观看 | 久久伊人色av天堂九九小黄鸭 | 99久久精品无码一区二区毛片 | 亚洲七七久久桃花影院 | 六月丁香婷婷色狠狠久久 | 无码福利日韩神码福利片 | 欧洲极品少妇 | 精品一区二区三区无码免费视频 | 丰满妇女强制高潮18xxxx | 国产一区二区三区精品视频 | 成人片黄网站色大片免费观看 | 国产精品怡红院永久免费 | 东北女人啪啪对白 | 青草视频在线播放 | 午夜丰满少妇性开放视频 | 国产精品视频免费播放 | 欧美人与物videos另类 | 国产在线无码精品电影网 | 中文字幕无码av激情不卡 | 国产成人无码区免费内射一片色欲 | 亚洲 日韩 欧美 成人 在线观看 | 领导边摸边吃奶边做爽在线观看 | 久久婷婷五月综合色国产香蕉 | 欧美35页视频在线观看 | 呦交小u女精品视频 | 香港三级日本三级妇三级 | 爆乳一区二区三区无码 | 亚洲国产一区二区三区在线观看 | 搡女人真爽免费视频大全 | 国产精品久久久久久久影院 | 国产又爽又黄又刺激的视频 | 国产两女互慰高潮视频在线观看 | 国产成人精品三级麻豆 | 亚洲一区二区三区无码久久 | 免费人成网站视频在线观看 | 国产精品沙发午睡系列 | 国产熟妇另类久久久久 | 国产舌乚八伦偷品w中 | 精品午夜福利在线观看 | 欧美人与牲动交xxxx | 丰满人妻翻云覆雨呻吟视频 | 国产精品亚洲一区二区三区喷水 | 综合人妻久久一区二区精品 | 亚洲综合无码久久精品综合 | 青青青手机频在线观看 | 亚洲精品国偷拍自产在线麻豆 | 奇米影视7777久久精品 | 1000部夫妻午夜免费 | 在线亚洲高清揄拍自拍一品区 | 一个人看的视频www在线 | 日韩精品无码免费一区二区三区 | 免费看男女做好爽好硬视频 | 熟妇人妻无乱码中文字幕 | 亚洲成a人片在线观看无码3d | 四虎4hu永久免费 | 精品一二三区久久aaa片 | 熟妇女人妻丰满少妇中文字幕 | 人妻人人添人妻人人爱 | 日韩欧美中文字幕在线三区 | 国产成人久久精品流白浆 | 国产女主播喷水视频在线观看 | 高潮毛片无遮挡高清免费 | 在线成人www免费观看视频 | 成人欧美一区二区三区 | 激情国产av做激情国产爱 | 国产色在线 | 国产 | 黑人玩弄人妻中文在线 | 久久99精品久久久久久动态图 | 免费无码的av片在线观看 | 精品久久久久久人妻无码中文字幕 | 人人澡人人妻人人爽人人蜜桃 | 青草视频在线播放 | 国产av一区二区精品久久凹凸 | 久久精品国产99久久6动漫 | 亚洲综合无码久久精品综合 | 日本大乳高潮视频在线观看 | 国产偷抇久久精品a片69 | 国产国语老龄妇女a片 | 老子影院午夜伦不卡 | 日本一卡2卡3卡四卡精品网站 | 性欧美熟妇videofreesex | 特级做a爰片毛片免费69 | av无码不卡在线观看免费 | 黑人巨大精品欧美黑寡妇 | 精品无码av一区二区三区 | 精品一二三区久久aaa片 | 熟女体下毛毛黑森林 | 沈阳熟女露脸对白视频 | 欧美 亚洲 国产 另类 | 国产精品欧美成人 | 夜精品a片一区二区三区无码白浆 | 男女爱爱好爽视频免费看 | 97久久精品无码一区二区 | 久久精品99久久香蕉国产色戒 | 精品国产av色一区二区深夜久久 | 亚洲人成网站色7799 | 国产亚洲人成在线播放 | 麻豆国产人妻欲求不满谁演的 | 欧美真人作爱免费视频 | 国产99久久精品一区二区 | 亚洲一区av无码专区在线观看 | 日本成熟视频免费视频 | 久久99精品国产麻豆蜜芽 | 亚洲综合精品香蕉久久网 | 牲交欧美兽交欧美 | 国产69精品久久久久app下载 | 啦啦啦www在线观看免费视频 | 牲欲强的熟妇农村老妇女视频 | 久久国产劲爆∧v内射 | 性欧美熟妇videofreesex | 免费无码午夜福利片69 | 久久久精品欧美一区二区免费 | 无码精品人妻一区二区三区av | 丰满人妻精品国产99aⅴ | 奇米影视7777久久精品人人爽 | 漂亮人妻洗澡被公强 日日躁 | 东京热无码av男人的天堂 | 国产卡一卡二卡三 | 男人扒开女人内裤强吻桶进去 | 国产人妻精品一区二区三区不卡 | 亚洲精品无码人妻无码 | 麻花豆传媒剧国产免费mv在线 | 色噜噜亚洲男人的天堂 | 欧美精品一区二区精品久久 | 国产精品成人av在线观看 | 亚洲乱码国产乱码精品精 | 亚洲精品午夜无码电影网 | 亚洲国产欧美国产综合一区 | 精品久久久无码中文字幕 | 午夜熟女插插xx免费视频 | 国产内射爽爽大片视频社区在线 | 国产亚洲tv在线观看 | 国产真实乱对白精彩久久 | 亚洲中文字幕在线观看 | 欧美人与善在线com | 人人妻人人澡人人爽欧美一区九九 | 欧美一区二区三区 | 红桃av一区二区三区在线无码av | 国产成人精品必看 | 内射爽无广熟女亚洲 | 日本护士毛茸茸高潮 | a片免费视频在线观看 | 日韩av无码中文无码电影 | 亚洲中文字幕在线无码一区二区 | 国产亚洲精品久久久ai换 | 亚洲娇小与黑人巨大交 | v一区无码内射国产 | 无码国内精品人妻少妇 | 搡女人真爽免费视频大全 | 99精品国产综合久久久久五月天 | 国产无套粉嫩白浆在线 | 黑人巨大精品欧美黑寡妇 | 亚洲人成网站免费播放 | 亚洲 另类 在线 欧美 制服 | 亚洲s色大片在线观看 | 国产 精品 自在自线 | 免费观看激色视频网站 | 日本xxxx色视频在线观看免费 | 丰满少妇女裸体bbw | 亚洲熟妇色xxxxx欧美老妇y | 国产精品人人妻人人爽 | 蜜桃视频韩日免费播放 | 成人无码影片精品久久久 | 鲁鲁鲁爽爽爽在线视频观看 | 67194成是人免费无码 | √8天堂资源地址中文在线 | 久久伊人色av天堂九九小黄鸭 | 人妻无码αv中文字幕久久琪琪布 | 国产精品二区一区二区aⅴ污介绍 | 亚洲欧美综合区丁香五月小说 | 亚洲欧洲日本无在线码 | 精品成人av一区二区三区 | 黑人粗大猛烈进出高潮视频 | 亚洲欧洲日本无在线码 | 四十如虎的丰满熟妇啪啪 | 青春草在线视频免费观看 | 国产综合色产在线精品 | 中文字幕乱码人妻二区三区 | 天堂在线观看www | 黄网在线观看免费网站 | 免费无码肉片在线观看 | 乱人伦中文视频在线观看 | 日韩人妻系列无码专区 | 亚洲の无码国产の无码影院 | 爆乳一区二区三区无码 | 天堂一区人妻无码 | 在线播放无码字幕亚洲 | 少妇被黑人到高潮喷出白浆 | 欧美日本日韩 | 国产乱人偷精品人妻a片 | 国产卡一卡二卡三 | 亚洲天堂2017无码中文 | 中文字幕av无码一区二区三区电影 | 欧美freesex黑人又粗又大 | 少妇被黑人到高潮喷出白浆 | 婷婷六月久久综合丁香 | 亚洲一区二区三区四区 | 男人和女人高潮免费网站 | 国产精品久久久久9999小说 | 2019nv天堂香蕉在线观看 | 国产舌乚八伦偷品w中 | 国产乱子伦视频在线播放 | 一本无码人妻在中文字幕免费 | 精品国产一区二区三区四区 | 四虎永久在线精品免费网址 | 欧美喷潮久久久xxxxx | 极品嫩模高潮叫床 | 亚洲一区二区三区香蕉 | 国产成人一区二区三区在线观看 | 波多野结衣aⅴ在线 | 1000部夫妻午夜免费 | 国产精品怡红院永久免费 | 爆乳一区二区三区无码 | 欧美日韩综合一区二区三区 | 国产无套内射久久久国产 | 国产极品视觉盛宴 | 久在线观看福利视频 | 国产午夜手机精彩视频 | 亚洲精品成人福利网站 | 人人妻人人藻人人爽欧美一区 | 女人被男人爽到呻吟的视频 | 中文字幕乱码中文乱码51精品 | 免费乱码人妻系列无码专区 | 久久午夜无码鲁丝片午夜精品 | 亚洲日本va中文字幕 | 国产精品久久久久久久影院 | 亚洲精品美女久久久久久久 | 理论片87福利理论电影 | 国产精品国产自线拍免费软件 | 97精品国产97久久久久久免费 | 国产免费久久久久久无码 | 欧洲熟妇色 欧美 | 久久国产36精品色熟妇 | 国产无遮挡又黄又爽又色 | av无码电影一区二区三区 | 一区二区三区高清视频一 | 久久人妻内射无码一区三区 | 帮老师解开蕾丝奶罩吸乳网站 | 丝袜 中出 制服 人妻 美腿 | 国产sm调教视频在线观看 | 无码国模国产在线观看 | 国产av剧情md精品麻豆 | 久久精品一区二区三区四区 | 亚洲国产一区二区三区在线观看 | 女人和拘做爰正片视频 | 国产午夜亚洲精品不卡下载 | 久久久久久a亚洲欧洲av冫 | 国产麻豆精品精东影业av网站 | 亚洲日韩av片在线观看 | 久久综合给合久久狠狠狠97色 | 久久亚洲精品中文字幕无男同 | 超碰97人人射妻 | 国产超级va在线观看视频 | 西西人体www44rt大胆高清 | 色情久久久av熟女人妻网站 | 高中生自慰www网站 | 桃花色综合影院 | 亚洲の无码国产の无码影院 | 国内精品久久久久久中文字幕 | 久久精品一区二区三区四区 | 精品熟女少妇av免费观看 | 人人澡人人透人人爽 | 精品国产av色一区二区深夜久久 | 国语自产偷拍精品视频偷 | 国产后入清纯学生妹 | 久久国产精品偷任你爽任你 | 国产午夜无码视频在线观看 | 亚洲精品久久久久久久久久久 | 又湿又紧又大又爽a视频国产 | 亚洲啪av永久无码精品放毛片 | 国产精品毛片一区二区 | 巨爆乳无码视频在线观看 | 日韩精品成人一区二区三区 | 一本久道高清无码视频 | 麻豆人妻少妇精品无码专区 | 极品尤物被啪到呻吟喷水 | 久久亚洲日韩精品一区二区三区 | 国产亚洲人成a在线v网站 | 国产精品久免费的黄网站 | 综合激情五月综合激情五月激情1 | 亚洲色偷偷偷综合网 | 黑人大群体交免费视频 | 中文字幕av日韩精品一区二区 | 久久天天躁夜夜躁狠狠 | 欧美自拍另类欧美综合图片区 | 夜夜躁日日躁狠狠久久av | 骚片av蜜桃精品一区 | 美女黄网站人色视频免费国产 | 亚洲の无码国产の无码影院 | 亚洲国产欧美国产综合一区 | 成熟人妻av无码专区 | 撕开奶罩揉吮奶头视频 | 亚洲 高清 成人 动漫 | 国产av无码专区亚洲a∨毛片 | 欧美性猛交内射兽交老熟妇 | 狠狠cao日日穞夜夜穞av | 成人三级无码视频在线观看 | 又紧又大又爽精品一区二区 | 国产偷抇久久精品a片69 | 久久久中文字幕日本无吗 | 狂野欧美激情性xxxx | 蜜桃av抽搐高潮一区二区 | 亚洲人成影院在线无码按摩店 | 蜜桃av抽搐高潮一区二区 | 在线精品亚洲一区二区 | 无码成人精品区在线观看 | 成人免费视频视频在线观看 免费 | 国产无遮挡吃胸膜奶免费看 | 久久精品国产日本波多野结衣 | 国产又粗又硬又大爽黄老大爷视 | 亚洲人亚洲人成电影网站色 | 国内精品人妻无码久久久影院 | 亚洲最大成人网站 | 国产香蕉尹人视频在线 | 国产香蕉97碰碰久久人人 | 巨爆乳无码视频在线观看 | 夜夜高潮次次欢爽av女 | √8天堂资源地址中文在线 | 中文字幕无码乱人伦 | 樱花草在线播放免费中文 | 成人无码视频在线观看网站 | 男女性色大片免费网站 | 精品无码av一区二区三区 | 久久久久亚洲精品中文字幕 | 国产美女极度色诱视频www | 国产精品久久国产精品99 | 精品国产麻豆免费人成网站 | 精品无码国产自产拍在线观看蜜 | 色综合久久久无码中文字幕 | 国产香蕉97碰碰久久人人 | 精品久久8x国产免费观看 | 欧美熟妇另类久久久久久多毛 | 丰满妇女强制高潮18xxxx | 久久久精品成人免费观看 | 婷婷丁香六月激情综合啪 | 装睡被陌生人摸出水好爽 | 欧美日韩一区二区综合 | 亚洲中文字幕无码中文字在线 | 98国产精品综合一区二区三区 | 国产av剧情md精品麻豆 | 欧美日韩人成综合在线播放 | 国产精品二区一区二区aⅴ污介绍 | 成年美女黄网站色大免费视频 | 国产综合久久久久鬼色 | 中文字幕精品av一区二区五区 | 日本饥渴人妻欲求不满 | 色婷婷av一区二区三区之红樱桃 | 国产精品鲁鲁鲁 | 黑人玩弄人妻中文在线 | 丰满肥臀大屁股熟妇激情视频 | 国内丰满熟女出轨videos | 国内少妇偷人精品视频免费 | 精品国偷自产在线 | 国产精品国产自线拍免费软件 | 亚洲aⅴ无码成人网站国产app | 国内少妇偷人精品视频 | 午夜理论片yy44880影院 | 久激情内射婷内射蜜桃人妖 | 奇米影视7777久久精品人人爽 | 伊人久久大香线蕉av一区二区 | 中文字幕无码免费久久99 | 窝窝午夜理论片影院 | 亚洲国产欧美日韩精品一区二区三区 | 伦伦影院午夜理论片 | 久久久婷婷五月亚洲97号色 | 亚洲天堂2017无码 | 亚洲自偷自偷在线制服 | 性色欲网站人妻丰满中文久久不卡 | 久久人人爽人人爽人人片ⅴ | aⅴ亚洲 日韩 色 图网站 播放 | 国产做国产爱免费视频 | 中国女人内谢69xxxx | 亚无码乱人伦一区二区 | 18无码粉嫩小泬无套在线观看 | 捆绑白丝粉色jk震动捧喷白浆 | 国产精品视频免费播放 | 久久久久99精品成人片 | 2020久久香蕉国产线看观看 | 高清无码午夜福利视频 | 国产9 9在线 | 中文 | 亚洲精品一区三区三区在线观看 | 最近免费中文字幕中文高清百度 | 人妻尝试又大又粗久久 | 亚洲精品欧美二区三区中文字幕 | 亚洲区小说区激情区图片区 | 日产国产精品亚洲系列 | 久久久久久国产精品无码下载 | 18禁黄网站男男禁片免费观看 | 日韩欧美中文字幕在线三区 | 天天拍夜夜添久久精品大 | 精品无码一区二区三区的天堂 | 无码av免费一区二区三区试看 | 久久五月精品中文字幕 | 国产精品久久久久9999小说 | 无码中文字幕色专区 | 99久久婷婷国产综合精品青草免费 | 女人被男人爽到呻吟的视频 | 麻豆果冻传媒2021精品传媒一区下载 | a片在线免费观看 | 亚洲乱码国产乱码精品精 | 99精品视频在线观看免费 | 亚洲综合久久一区二区 | 午夜肉伦伦影院 | 国产精品va在线观看无码 | 日韩无码专区 | 久久亚洲日韩精品一区二区三区 | 欧美兽交xxxx×视频 | 亚洲成av人片天堂网无码】 | 亚洲一区二区三区在线观看网站 | 99久久久无码国产精品免费 | 久久精品丝袜高跟鞋 | 亚洲伊人久久精品影院 | 午夜男女很黄的视频 | 日韩av无码一区二区三区 | 日本高清一区免费中文视频 | 少妇人妻大乳在线视频 | 人妻少妇精品无码专区二区 | 99国产精品白浆在线观看免费 | 亚洲一区二区三区播放 | 亚洲狠狠色丁香婷婷综合 | 男人扒开女人内裤强吻桶进去 | 一本久久a久久精品亚洲 | 青青青爽视频在线观看 | 国产精品香蕉在线观看 | 黑森林福利视频导航 | 天干天干啦夜天干天2017 | 国产无套粉嫩白浆在线 | 国产无av码在线观看 | 色 综合 欧美 亚洲 国产 | 日韩亚洲欧美精品综合 | 亚洲精品www久久久 | 久久久久成人片免费观看蜜芽 | 无码国模国产在线观看 | 一本色道久久综合狠狠躁 | 欧美国产日韩久久mv | 亚洲国产精品一区二区美利坚 | 亚洲国产精品久久人人爱 | 无码人妻丰满熟妇区毛片18 | 中文字幕精品av一区二区五区 | 内射白嫩少妇超碰 | 欧美变态另类xxxx | 国产成人精品久久亚洲高清不卡 | 国产成人综合在线女婷五月99播放 | 国产精品香蕉在线观看 | 国产美女极度色诱视频www | 激情亚洲一区国产精品 | 成熟女人特级毛片www免费 | 妺妺窝人体色www在线小说 | 精品偷拍一区二区三区在线看 | 亚洲国产综合无码一区 | 久久人妻内射无码一区三区 | 97久久国产亚洲精品超碰热 | 日本成熟视频免费视频 | 久久99热只有频精品8 | 久久国产精品萌白酱免费 | 999久久久国产精品消防器材 | 日本一卡2卡3卡四卡精品网站 | 国产av一区二区三区最新精品 | 在线成人www免费观看视频 | 日本爽爽爽爽爽爽在线观看免 | 亚洲精品一区二区三区四区五区 | 亚洲熟熟妇xxxx | 精品人人妻人人澡人人爽人人 | 一本色道久久综合狠狠躁 | 一本久道久久综合婷婷五月 | 又黄又爽又色的视频 | 99久久亚洲精品无码毛片 | 亚洲成a人一区二区三区 | 久久视频在线观看精品 | 欧美国产日产一区二区 | 97精品国产97久久久久久免费 | 欧美xxxxx精品 | 久久久国产一区二区三区 | 欧美zoozzooz性欧美 | 久久99久久99精品中文字幕 | 精品无码一区二区三区爱欲 | 国产又粗又硬又大爽黄老大爷视 | 无码一区二区三区在线观看 | 蜜桃av抽搐高潮一区二区 | 成年美女黄网站色大免费视频 | 日本护士毛茸茸高潮 | 亚洲午夜福利在线观看 | 国产极品美女高潮无套在线观看 | 欧美高清在线精品一区 | 国产午夜亚洲精品不卡下载 | 大乳丰满人妻中文字幕日本 | 久久亚洲中文字幕无码 | 亚洲欧洲日本综合aⅴ在线 | 精品久久8x国产免费观看 | 4hu四虎永久在线观看 | 欧美激情综合亚洲一二区 | 国产免费观看黄av片 | 少妇愉情理伦片bd | а√天堂www在线天堂小说 | аⅴ资源天堂资源库在线 | 久久久av男人的天堂 | 少妇的肉体aa片免费 | 婷婷丁香五月天综合东京热 | 最新国产乱人伦偷精品免费网站 | 国产另类ts人妖一区二区 | 在线а√天堂中文官网 | 日本va欧美va欧美va精品 | 超碰97人人做人人爱少妇 | 我要看www免费看插插视频 | 国产精品高潮呻吟av久久4虎 | 国产一区二区不卡老阿姨 | 精品国产青草久久久久福利 | 欧美自拍另类欧美综合图片区 | 国产又粗又硬又大爽黄老大爷视 | 日本大香伊一区二区三区 | www国产亚洲精品久久网站 | 中文字幕无码免费久久99 | 全球成人中文在线 | 成人免费无码大片a毛片 | 亚洲精品成人av在线 | 高潮毛片无遮挡高清免费视频 | 成在人线av无码免观看麻豆 | 国语精品一区二区三区 | 国产精品99爱免费视频 | 四十如虎的丰满熟妇啪啪 | 精品偷拍一区二区三区在线看 | 精品无码国产自产拍在线观看蜜 | 成 人 网 站国产免费观看 | 天天摸天天透天天添 | 成 人影片 免费观看 | 中文字幕无码人妻少妇免费 | 性做久久久久久久免费看 | 亚洲伊人久久精品影院 | 国产成人无码午夜视频在线观看 | 一本一道久久综合久久 | 国产精品沙发午睡系列 | 国产麻豆精品一区二区三区v视界 | 中文字幕无码日韩专区 | 国产99久久精品一区二区 | 中文无码精品a∨在线观看不卡 | 国产特级毛片aaaaaaa高清 | 亚洲国产精品一区二区美利坚 | 亚洲成av人在线观看网址 | 精品国产精品久久一区免费式 | 国产成人久久精品流白浆 | 成在人线av无码免费 | 人妻熟女一区 | 国产人妻精品午夜福利免费 | 岛国片人妻三上悠亚 | 亲嘴扒胸摸屁股激烈网站 | 国产精品久久国产三级国 | 老司机亚洲精品影院无码 | 色欲av亚洲一区无码少妇 | 曰韩少妇内射免费播放 | 131美女爱做视频 | 欧美日韩视频无码一区二区三 | 亚洲成熟女人毛毛耸耸多 | 扒开双腿吃奶呻吟做受视频 | 日本精品少妇一区二区三区 | 真人与拘做受免费视频 | 国产成人无码午夜视频在线观看 | 一本大道久久东京热无码av | 少妇被粗大的猛进出69影院 | 精品无码一区二区三区爱欲 | 国产av无码专区亚洲awww | 国产精品a成v人在线播放 | 又色又爽又黄的美女裸体网站 | 国产内射爽爽大片视频社区在线 | 麻豆md0077饥渴少妇 | 国产精品亚洲а∨无码播放麻豆 | 日韩人妻无码一区二区三区久久99 | 无码免费一区二区三区 | 中文精品无码中文字幕无码专区 | 久久久久久久女国产乱让韩 | 亚洲成a人片在线观看无码3d | 久久天天躁夜夜躁狠狠 | 九九综合va免费看 | 国产精品99久久精品爆乳 | 麻豆果冻传媒2021精品传媒一区下载 | 一本精品99久久精品77 | 人妻互换免费中文字幕 | 亚洲 激情 小说 另类 欧美 | 一本一道久久综合久久 | 日韩av无码中文无码电影 | 国产一区二区三区精品视频 | 最近免费中文字幕中文高清百度 | 亚洲精品国产品国语在线观看 | 精品国产国产综合精品 | 日韩成人一区二区三区在线观看 | 久久久久久av无码免费看大片 | 亚洲无人区午夜福利码高清完整版 | 国产精品亚洲一区二区三区喷水 | 亚洲 另类 在线 欧美 制服 | 亚洲精品一区二区三区大桥未久 | 久久综合久久自在自线精品自 | 精品人妻人人做人人爽夜夜爽 | 精品久久综合1区2区3区激情 | 樱花草在线社区www | 天堂亚洲2017在线观看 | 香蕉久久久久久av成人 | 国产精品欧美成人 | 无码一区二区三区在线 | 精品一二三区久久aaa片 | 午夜福利不卡在线视频 | 午夜福利试看120秒体验区 | 丰满岳乱妇在线观看中字无码 | 午夜精品久久久久久久 | 纯爱无遮挡h肉动漫在线播放 | 日本精品人妻无码77777 天堂一区人妻无码 | 亚洲精品久久久久久久久久久 | 东京热一精品无码av | 久久久久久久久888 | 领导边摸边吃奶边做爽在线观看 | 中文字幕人妻无码一区二区三区 | 自拍偷自拍亚洲精品被多人伦好爽 | 久久综合给久久狠狠97色 | 香蕉久久久久久av成人 | 亚洲午夜福利在线观看 | 国产精品美女久久久久av爽李琼 | 曰韩无码二三区中文字幕 | 亚洲爆乳精品无码一区二区三区 | 亚洲色大成网站www国产 | 中文无码精品a∨在线观看不卡 | 国产精品va在线播放 | 国产高潮视频在线观看 | 久久97精品久久久久久久不卡 | 红桃av一区二区三区在线无码av | 蜜臀av无码人妻精品 | 日本熟妇乱子伦xxxx | 人人妻人人澡人人爽人人精品 | 久久综合久久自在自线精品自 | 色婷婷香蕉在线一区二区 | 国产精品理论片在线观看 | 三级4级全黄60分钟 | 亚洲中文字幕久久无码 | 日韩成人一区二区三区在线观看 | 一本无码人妻在中文字幕免费 | 久久久久久av无码免费看大片 | 天堂无码人妻精品一区二区三区 | 国产精品久久久久久久影院 | 亚洲色偷偷偷综合网 | 久久精品成人欧美大片 | 亚洲自偷精品视频自拍 | 荫蒂添的好舒服视频囗交 | 国产成人精品久久亚洲高清不卡 | 久久国内精品自在自线 | 亚洲一区二区三区国产精华液 | 久久视频在线观看精品 | 无码一区二区三区在线观看 | 久在线观看福利视频 | 久久午夜无码鲁丝片 | 久久久久人妻一区精品色欧美 | 99er热精品视频 | 久久久久国色av免费观看性色 | 中文字幕人妻丝袜二区 | 少妇无码av无码专区在线观看 | 久久精品中文字幕一区 | 伊人久久大香线焦av综合影院 | 呦交小u女精品视频 | 人人妻人人澡人人爽人人精品 | a在线亚洲男人的天堂 | 一本色道婷婷久久欧美 | 久久aⅴ免费观看 | 少妇被粗大的猛进出69影院 | 美女张开腿让人桶 | 丰满肥臀大屁股熟妇激情视频 | 亚洲成av人在线观看网址 | 精品亚洲成av人在线观看 | 精品久久8x国产免费观看 | 亚洲综合久久一区二区 | 国产免费久久精品国产传媒 | 97久久超碰中文字幕 | 欧美黑人性暴力猛交喷水 | 日韩精品无码一区二区中文字幕 | 野狼第一精品社区 | aⅴ亚洲 日韩 色 图网站 播放 | 人妻体内射精一区二区三四 | 久久久精品欧美一区二区免费 | 图片区 小说区 区 亚洲五月 | 亚洲中文字幕在线观看 | 午夜理论片yy44880影院 | 给我免费的视频在线观看 | 国产亚洲精品久久久闺蜜 | 成人无码精品1区2区3区免费看 | 在线欧美精品一区二区三区 | 色婷婷香蕉在线一区二区 | 国产精品人人爽人人做我的可爱 | 人妻有码中文字幕在线 | 久久无码专区国产精品s | 中文字幕亚洲情99在线 | 成人精品视频一区二区 | 少妇被黑人到高潮喷出白浆 | 蜜臀av在线播放 久久综合激激的五月天 | 中文亚洲成a人片在线观看 | 国产精品无码一区二区三区不卡 | 国产精品久久精品三级 | 性生交片免费无码看人 | 国产成人一区二区三区在线观看 |