久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区


曙海教育集團(tuán)論壇開(kāi)發(fā)語(yǔ)言培訓(xùn)專區(qū)VB語(yǔ)言 → VB真是想不到系列之二:VB《葵花寶典》--指針技


  共有8350人關(guān)注過(guò)本帖樹(shù)形打印

主題:VB真是想不到系列之二:VB《葵花寶典》--指針技

美女呀,離線,留言給我吧!
wangxinxin
  1樓 個(gè)性首頁(yè) | 博客 | 信息 | 搜索 | 郵箱 | 主頁(yè) | UC


加好友 發(fā)短信
等級(jí):青蜂俠 帖子:1393 積分:14038 威望:0 精華:0 注冊(cè):2010-11-12 11:08:23
VB真是想不到系列之二:VB《葵花寶典》--指針技  發(fā)帖心情 Post By:2010-12-14 12:35:56

《VB真是想不到系列》
    每次看大師的東西到了精彩之處,我就會(huì)拍案叫絕:"哇噻,真是想不到!"。在經(jīng)過(guò)很多次這種感慨之后,我發(fā)現(xiàn)只要我們動(dòng)了腦筋,我們自己也能有讓別人想不到的東西。于是想到要把這些想不到的東拿出來(lái)和大家一起分享,希望拋磚引玉,能引出更多讓人想不到的東西。
   
                  VB真是想不到系列之二:VB《葵花寶典》--指針技術(shù)
關(guān)鍵字:VB、指針、動(dòng)態(tài)內(nèi)存分配、效率、安全
難度:中級(jí)至高級(jí)
要求:熟悉VB,掌握基本的C,了解匯編,了解內(nèi)存分配原理。
    想當(dāng)年?yáng)|方不敗,黑木崖密室一戰(zhàn),僅憑一根繡花針獨(dú)戰(zhàn)四大高手,神出鬼沒(méi),堪稱天下武林第一高手。若想成為VB里的東方不敗,熟習(xí)VB《葵花寶典》,掌握VB指針技術(shù),乃是不二的法門。
    欲練神功,引刀……,其實(shí)掌握VB指針技術(shù),并不需要那么痛苦。因?yàn)檎f(shuō)穿了,也就那么幾招,再勤加練習(xí),終可至神出鬼沒(méi)之境。廢話少說(shuō),讓我們先從指針的定義說(shuō)起。
   
    一、指針是什么?
    不需要去找什么標(biāo)準(zhǔn)的定義,它就是一個(gè)32位整數(shù),在C語(yǔ)言和在VB里都可以用Long類型來(lái)表示。在32位Windows平臺(tái)下它和普通的32位長(zhǎng)整型數(shù)沒(méi)有什么不同,只不過(guò)它的值是一個(gè)內(nèi)存地址,正是因?yàn)檫@個(gè)整數(shù)象針一樣指向一個(gè)內(nèi)存地址,所以就有了指針的概念。
    有統(tǒng)計(jì)表明,很大一部分程序缺陷和內(nèi)存的錯(cuò)誤訪問(wèn)有關(guān)。正是因?yàn)橹羔樦苯雍蛢?nèi)存打交道,所以指針一直以來(lái)被看成一個(gè)危險(xiǎn)的東西。以至于不少語(yǔ)言,如著名的JAVA,都不提供對(duì)指針操作的支持,所有的內(nèi)存訪問(wèn)方面的處理都由編譯器來(lái)完成。而象C和C++,指針的使用則是基本功,指針給了程序員極大的自由去隨心所欲地處理內(nèi)存訪問(wèn),很多非常巧妙的東西都要依靠指針技術(shù)來(lái)完成。
    關(guān)于一門高級(jí)的程序設(shè)計(jì)語(yǔ)言是不是應(yīng)該取消指針操作,關(guān)于沒(méi)有指針操作算不算一門語(yǔ)言的優(yōu)點(diǎn),我在這里不討論,因?yàn)榛ヂ?lián)網(wǎng)上關(guān)于這方面的沒(méi)有結(jié)果的討論,已經(jīng)造成了占用幾個(gè)GB的資源。無(wú)論最終你是不是要下定決心修習(xí)指針技術(shù)《葵花寶典》,了解這門功夫總是有益處的。
    注意:在VB里,官方是不鼓勵(lì)使用什么指針的,本文所講的任何東西你都別指望取得官方的技術(shù)支持,一切都要靠我們自己的努力,一切都更刺激!
    讓我們開(kāi)始神奇的VB指針探險(xiǎn)吧!

 

   順便提一下,聽(tīng)說(shuō)VB.NET里沒(méi)有這幾個(gè)函數(shù),但只要還能調(diào)用API,我們就可以試試上面的幾個(gè)聲明,這樣在VB.NET里我們一樣可以進(jìn)行指針操作。
    但是請(qǐng)注意,如果通過(guò)API調(diào)用來(lái)使用VarPtr,整個(gè)程序二SwapPtr將比原來(lái)使用內(nèi)置VarPtr函數(shù)時(shí)慢6倍。)
    如果你喜歡刨根問(wèn)底,那么下面就是VarPtr函數(shù)在C和匯編語(yǔ)言里的樣子:
    在C里樣子是這樣的:
    long VarPtr(void* pv){
        return (long)pv;
    }
    所對(duì)就的匯編代碼就兩行:
    mov         eax,dword ptr [esp+4]
    ret         4           '彈出棧里參數(shù)的值并返回。
    之所以讓大家了解VarPtr的具體實(shí)現(xiàn),是想告訴大家它的開(kāi)銷并不大,因?yàn)樗鼈儾贿^(guò)兩條指令,即使加上參數(shù)賦值、壓棧和調(diào)用指令,整個(gè)獲取指針的過(guò)程也就六條指令。當(dāng)然,同樣的功能在C語(yǔ)言里,由于語(yǔ)言的直接支持,僅需要一條指令即可。但在VB里,它已經(jīng)算是最快的函數(shù)了,所以我們完全不用擔(dān)心使用VarPtr會(huì)讓我們失去效率!速度是使用指針技術(shù)的根本要求。
    一句話,VarPtr返回的是變量所在處的內(nèi)存地址,也可以說(shuō)返回了指向變量?jī)?nèi)存位置的指針,它是我們?cè)赩B里處理指針最重要的武器之一。

3、ByVal和ByRef
    ByVal傳遞的參數(shù)值,而B(niǎo)yRef傳遞的參數(shù)的地址。在這里,我們不用去區(qū)別傳指針/傳地址/傳引用的不同,在VB里,它們根本就是一個(gè)東西的三種不同說(shuō)法,即使VB的文檔里也有地方在混用這些術(shù)語(yǔ)(但在C++里的確要區(qū)分指針和引用)
    初次接觸上面的程序二SwapPtr的朋友,一定要搞清在里面的CopyMemory調(diào)用中,在什么地方要加ByVal,什么地方不加(不加ByVal就是使用VB缺省的ByRef)
    準(zhǔn)確的理解傳值和傳地址(指針)的區(qū)別,是在VB里正確使用指針的基礎(chǔ)。
    現(xiàn)在一個(gè)最簡(jiǎn)單的實(shí)驗(yàn)來(lái)看這個(gè)問(wèn)題,如下面的程序三:
【程序三】:'體會(huì)ByVal和ByRef
    Sub TestCopyMemory()
        Dim k As Long
        k = 5
Note:   CopyMemory ByVal VarPtr(k), 40000, 4
        Debug.Print k
    End Sub
    上面標(biāo)號(hào)Note處的語(yǔ)句的目的,是將k賦值為40000,等同于語(yǔ)句k=40000,你可以在"立即"窗口試驗(yàn)一下,會(huì)發(fā)現(xiàn)k的值的確成了40000。
    實(shí)際上上面這個(gè)語(yǔ)句,翻譯成白話,就是從保存常數(shù)40000的臨時(shí)變量處拷貝4個(gè)字節(jié)到變量k所在的內(nèi)存中。
    現(xiàn)在我們來(lái)改變一個(gè)Note處的語(yǔ)句,若改成下面的語(yǔ)句:
Note2:   CopyMemory ByVal VarPtr(k), ByVal 40000, 4
    這句話的意思就成了,從地址40000拷貝4個(gè)字節(jié)到變量k所在的內(nèi)存中。由于地址40000所在的內(nèi)存我們無(wú)權(quán)訪問(wèn),操作系統(tǒng)會(huì)給我們一個(gè)Access Violation內(nèi)存越權(quán)訪問(wèn)錯(cuò)誤,告訴我們"試圖讀取位置0x00009c40處內(nèi)存時(shí)出錯(cuò),該內(nèi)存不能為'Read'"。
    我們?cè)俑某扇缦碌恼Z(yǔ)句看看。
Note3:   CopyMemory VarPtr(k), 40000, 4
    這句話的意思就成了,從保存常數(shù)40000的臨時(shí)變量處拷貝4個(gè)字節(jié)到到保存變量k所在內(nèi)存地址值的臨時(shí)變量處。這不會(huì)出出內(nèi)存越權(quán)訪問(wèn)錯(cuò)誤,但k的值并沒(méi)有變。
    我們可以把程序改改以更清楚的休現(xiàn)這種區(qū)別,如下面的程序四:
【程序四】:'看看我們的東西被拷貝到哪兒去了
    Sub TestCopyMemory()
        Dim i As Long, k As Long
        k = 5
        i = VarPtr(k)
NOTE4:  CopyMemory i, 40000, 4
        Debug.Print k
        Debug.Print i
        i = VarPtr(k)
NOTE5:  CopyMemory ByVal i, 40000, 4
        Debug.Print k
    End Sub

程序輸出:
5
40000
40000
    由于NOTE4處使用缺省的ByVal,傳遞的是i的地址(也就是指向i的指針),所以常量40000拷貝到了變量i里,因此i的值成了40000,而k的值卻沒(méi)有變化。但是,在NOTE4前有:i=VarPtr(k),本意是要把i本身做為一個(gè)指針來(lái)使用。這時(shí),我們必須如NOTE5那樣用ByVal來(lái)傳遞指針i,由于i是指向變量k的指針,所以最后常量40000被拷貝了變量k里。
    希望你已經(jīng)理解了這種區(qū)別,在后面問(wèn)題的討論中,我還會(huì)再談到它。

4、AddressOf
    它用來(lái)得到一個(gè)指向VB函數(shù)入口地址的指針,不過(guò)這個(gè)指針只能傳遞給API使用,以使得API能回調(diào)VB函數(shù)。
    本文不準(zhǔn)備詳細(xì)討論函數(shù)指針,關(guān)于它的使用請(qǐng)參考VB文檔。

5、拿來(lái)主義。
    實(shí)際上,有了CopyMemory,VarPtr,AddressOf這三把斧頭,我們已經(jīng)可以將C里基本的指針操作拿過(guò)來(lái)了。
    如下面的C程序包括了大部分基本的指針指針操作:
    struct POINT{
        int x; int y;
    };
    int Compare(void* elem1, void* elem2){}
    void PtrDemo(){
    //指針聲明:
        char c = 'X';        //聲明一個(gè)char型變量
        char* pc; long* pl;  //聲明普通指針
        POINT* pPt;          //聲明結(jié)構(gòu)指針
        void* pv;            //聲明無(wú)類型指針
        int (*pfnCastToInt)(void *, void*);//聲明函數(shù)指針:
    //指針賦值:
       pc = &c;              //將變量c的地址值賦給指針pc
       pfnCompare = Compare; //函數(shù)指針賦值。
    //指針取值:
       c = *pc;              //將指針pc所指處的內(nèi)存值賦給變量c
    //用指針賦值:
       *pc = 'Y'             //將'Y'賦給指針pc所指內(nèi)存變量里。
    //指針移動(dòng):
       pc++; pl--;
    }

    這些對(duì)指針操作在VB里都有等同的東西,
    前面討論ByVal和ByRef時(shí)曾說(shuō)過(guò)傳指針和傳地址是一回事,實(shí)際上當(dāng)我們?cè)赩B里用缺省的ByRef聲明函數(shù)參數(shù)時(shí),我們已經(jīng)就聲明了指針。
    如一個(gè)C聲明的函數(shù):long Func(char* pc)
    其對(duì)應(yīng)的VB聲明是:Function Func(pc As Byte) As Long
    這時(shí)參數(shù)pc使用缺省的ByRef傳地址方式來(lái)傳遞,這和C里用指針來(lái)傳遞參數(shù)是一樣。
    那么怎么才能象C里那樣明確地聲明一個(gè)指針呢?
    很簡(jiǎn)單,如前所說(shuō),用一個(gè)32位長(zhǎng)整數(shù)來(lái)表達(dá)指針就行。在VB里就是用Long型來(lái)明確地聲明指針,我們不用區(qū)分是普通指針、無(wú)類型指針還是函數(shù)指針,通通都可用Long來(lái)聲明。而給一個(gè)指針賦值,就是賦給它用VarPar得到的另一個(gè)變量的地址。具體見(jiàn)程序五。
【程序五】:同C一樣,各種指針。
    Type POINT
        X As Integer
        Y As Integer
    End Type
    Public Function Compare(elem1 As Long, elem2 As Long) As Long
    '
    End Function
    Function FnPtrToLong(ByVal lngFnPtr As Long) As Long
        FnPtrToLong = lngFnPtr
    End Function
    Sub PtrDemo()
       Dim l As Long, c As Byte, ca() As Byte, Pt As POINT
       Dim pl As Long, pc As Long, pv As Long, pPt As Long, pfnCompare As Long
       c = AscB("X")
       pl = VarPtr(l)     '對(duì)應(yīng)C里的long、int型指針
       pc = VarPtr(c)     '對(duì)應(yīng)char、short型指針
       pPt = VarPtr(Pt)   '結(jié)構(gòu)指針
       pv = VarPtr(ca(0)) '字節(jié)數(shù)組指針,可對(duì)應(yīng)任何類型,也就是void*
       pfnCompare = FnPtrToLong(AddressOf Compare) '函數(shù)指針
       CopyMemory c, ByVal pc, LenB(c)   '用指針取值
       CopyMemory ByVal pc, AscB("Y"), LenB(c) '用指針賦值
       pc = pc + LenB(c) : pl = pl - LenB(l)   '指針移動(dòng)
    End Sub
    我們看到,由于VB不直接支持指針操作,在VB里用指針取值和用指針賦值都必須用CopyMemory這個(gè)API,而調(diào)用API的代價(jià)是比較高的,這就決定了我們?cè)赩B里使用指針不能象在C里那樣自由和頻繁,我們必須要考慮指針操作的代價(jià),在后面的"指針應(yīng)用"我們會(huì)再變談這個(gè)問(wèn)題。
    程序五中關(guān)于函數(shù)指針的問(wèn)題請(qǐng)參考VB文檔,無(wú)類型指針void*會(huì)在下面"關(guān)于Any的問(wèn)題"里說(shuō)。
    程序五基本上已經(jīng)包括了我們能在VB里進(jìn)行的所有指針操作,僅此而已。

    下面有一個(gè)小測(cè)試題,如果現(xiàn)在你就弄懂了上面程咬金的三板斧,你就應(yīng)該能做得出來(lái)。
    上面提到過(guò),VB.NET中沒(méi)有VarPtr,我們可以用聲明API的方式來(lái)引入MSVBVM60.DLL中的VarPtr。現(xiàn)在的問(wèn)題如果不用VB的運(yùn)行時(shí)DLL文件,你能不能自己實(shí)現(xiàn)一個(gè)ObjPtr。答案在下一節(jié)后給出。

    四、指針使用中應(yīng)注意的問(wèn)題
    1、關(guān)于ANY的問(wèn)題
    如果以一個(gè)老師的身份來(lái)說(shuō)話,我會(huì)說(shuō):最好永遠(yuǎn)也不要用Any!是的,我沒(méi)說(shuō)錯(cuò),是永遠(yuǎn)!所以我沒(méi)有把它放在程咬金的三板斧里。當(dāng)然,這個(gè)問(wèn)題和是不是應(yīng)該使用指針這個(gè)問(wèn)題一樣會(huì)引發(fā)一場(chǎng)沒(méi)有結(jié)果的討論,我告訴你的只是一個(gè)觀點(diǎn),因?yàn)橛袝r(shí)我們會(huì)為了效率上的一點(diǎn)點(diǎn)提高或想偷一點(diǎn)點(diǎn)懶而去用Any,但這樣做需要要承擔(dān)風(fēng)險(xiǎn)。
    Any不是一個(gè)真正的類型,它只是告訴VB編譯器放棄對(duì)參數(shù)類型的檢查,這樣,理論上,我們可以將任何類型傳遞給API。
    Any在什么地方用呢?讓我們來(lái)看看,在VB文檔里的是怎么說(shuō)的,現(xiàn)在就請(qǐng)打開(kāi)MSDN(Visual Studio 6自帶的版本),翻到"Visual Basic文檔"->"使用Visual Basic"->"部件工具指南"->"訪問(wèn)DLL和Windows API"部分,再看看"將 C 語(yǔ)言聲明轉(zhuǎn)換為 Visual Basic 聲明"這一節(jié)。文檔里告訴我們,只有C的聲明為L(zhǎng)PVOID和NULL時(shí),我們才用Any。實(shí)際上如果你愿意承擔(dān)風(fēng)險(xiǎn),所有的類型你都可以用Any。當(dāng)然,也可以如我所說(shuō),永遠(yuǎn)不要用Any。   
    為什么要這樣?那為什么VB官方還要提供Any?是信我的,還是信VB官方的?有什么道理不用Any?
    如前面所說(shuō),VB官方不鼓勵(lì)我們使用指針。因?yàn)閂B所標(biāo)榜的優(yōu)點(diǎn)之一,就是沒(méi)有危險(xiǎn)的指針操作,所以的內(nèi)存訪問(wèn)都是受VB運(yùn)行時(shí)庫(kù)控制的。在這一點(diǎn)上,JAVA語(yǔ)言也有著同樣的標(biāo)榜。但是,同JAVA一樣,VB要避免使用指針而得到更高的安全性,就必須要克服沒(méi)有指針而帶來(lái)的問(wèn)題。VB已經(jīng)盡最大的努力來(lái)使我們遠(yuǎn)離指針的同時(shí)擁有強(qiáng)類型檢查帶來(lái)的安全性。但是操作系統(tǒng)是C寫(xiě)的,里面到處都需要指針,有些指針是沒(méi)有類型的,就是C程序員常說(shuō)的可怕的void*無(wú)類型指針。它沒(méi)有類型,因此它可以表示所有類型。如CopyMemory所對(duì)應(yīng)的是C語(yǔ)言的memcpy,它的聲明如下:
    void *memcpy( void *dest, const void *src, size_t count );
    因memcpy前兩個(gè)參數(shù)用的是void*,因此任何類型的參數(shù)都可以傳遞給他。
    一個(gè)用C的程序員,應(yīng)該知道在C函數(shù)庫(kù)里這樣的void*并不少見(jiàn),也應(yīng)該知道它有多危險(xiǎn)。無(wú)論傳遞什么類型的變量指針給上面memcpy的void*,C編譯器都不會(huì)報(bào)錯(cuò)或給任何警告。
    在VB里大多數(shù)時(shí)候,我們使用Any就是為了使用void*,和在C里一樣,VB也不對(duì)Any進(jìn)行類型檢查,我們也可以傳遞任何類型給Any,VB編譯器也都不會(huì)報(bào)錯(cuò)或給任何警告。
    但程序運(yùn)行時(shí)會(huì)不會(huì)出錯(cuò),就要看使用它時(shí)是不是小心了。正因?yàn)樵贑里很多錯(cuò)誤是和void*相關(guān)的,所以,C++鼓勵(lì)我們使用satic_cast<void*>來(lái)明確指出這種不安全的類型的轉(zhuǎn)換,已利于發(fā)現(xiàn)錯(cuò)誤。
    說(shuō)了這么多C/C++,其實(shí)我是想告訴所有VB的程序員,在使用Any時(shí),我們必須和C/C++程序員使用void*一樣要高度小心。
    VB里沒(méi)有satic_cast這種東西,但我們可以在傳遞指針時(shí)明確的使用long類型,并且用VarPtr來(lái)取得參數(shù)的指針,這樣至少已經(jīng)明確地指出我們?cè)谑褂梦kU(xiǎn)的指針。如程序二經(jīng)過(guò)這樣的處理就成了下面的程序:
【程序五】:'使用更安全的CopyMemory,明確的使用指針!
    Private Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (ByVal Destination As Long, ByVal Source As Long, ByVal Length As Long)
    Sub SwapStrPtr2(sA As String, sB As String)
        Dim lTmp As Long
        Dim pTmp As Long, psA As Long, psB As Long
        pTmp = VarPtr(lTmp): psA = VarPtr(sA): psB = VarPtr(sB)
        CopyMemory pTmp, psA, 4
        CopyMemory psA, psB, 4
        CopyMemory psB, pTmp, 4
    End Sub
   


支持(0中立(0反對(duì)(0單帖管理 | 引用 | 回復(fù) 回到頂部

返回版面帖子列表

VB真是想不到系列之二:VB《葵花寶典》--指針技








簽名
久久精品在这里_成人99免费视频_国产激情视频一区二区在线观看_国产伦精品一区二区三区免费 _亚洲午夜免费福利视频_色狠狠色狠狠综合_av在线综合网_91毛片在线观看_欧美视频一区二区在线观看_极品美女销魂一区二区三区免费_国产亚洲欧美激情_在线免费观看不卡av_日韩不卡一区二区三区_91精品国产麻豆国产自产在线_亚洲国产精品一区二区久久恐怖片_a4yy欧美一区二区三区
视频一区国产视频| 免费一区二区三区| 亚洲精品欧美二区三区中文字幕| 久久综合av免费| 精品少妇一区二区三区视频免付费 | 欧洲视频一区二区| 欧美日韩免费高清一区色橹橹| 在线观看亚洲精品视频| 欧美日韩精品欧美日韩精品| 欧美一区二区三区免费在线看| 日韩一区二区在线观看视频| 精品国产凹凸成av人网站| 国产亚洲一区二区在线观看| 中文字幕一区二区不卡| 一区二区三区四区国产精品| 亚洲18女电影在线观看| 精东粉嫩av免费一区二区三区| 国产黄人亚洲片| 国产精品对白刺激久久久| 欧美另类视频在线| 欧美亚洲一区二区在线观看| 宅男在线国产精品| 日本一区二区三区久久久久久久久不 | 精品无码久久久久久久动漫| 日韩妆和欧美的一区二区| 中文字幕一区二区三区有限公司| 欧美性xxxxxx少妇| 精品国产不卡一区二区三区| 亚洲色图在线看| 久久成人免费电影| 97人摸人人澡人人人超一碰| 欧美一区二区三区四区夜夜大片 | 欧美午夜不卡在线观看免费| 欧美mv和日韩mv的网站| 综合久久国产九一剧情麻豆| 日韩电影网1区2区| 91精品国产综合久久久久久丝袜| 欧洲精品久久| 欧美一级一级性生活免费录像| 国产精品蜜臀av| 老司机精品视频一区二区三区| 91视频一区二区| 香蕉久久夜色| 久久久.com| 视频一区二区三区在线| 91麻豆福利精品推荐| 亚洲人成77777| 久久久久久久久久电影| 午夜天堂影视香蕉久久| 99精品欧美一区二区三区小说 | 成人黄色小视频在线观看| 国产日韩欧美一区二区三区四区| 在线视频欧美区| 国产精品欧美一区喷水| 韩国精品主播一区二区在线观看| 国产精品一区二区a| 精品婷婷伊人一区三区三| 国产精品成人免费精品自在线观看| 老司机精品视频导航| 国产一区自拍视频| 欧美一级电影网站| 天堂在线一区二区| 久久久久久欧美精品色一二三四| 日韩三级视频中文字幕| 日韩电影在线看| 久久精品国产综合精品| 日韩精品中文字幕一区 | 粉嫩绯色av一区二区在线观看| 欧美极品色图| 久久久.com| 国产精品一级在线| 色综合久久久久| 亚洲精品乱码久久久久久久久 | 国产亚洲欧洲997久久综合| 老司机午夜精品| 日韩欧美亚洲区| 一区精品在线播放| 99电影网电视剧在线观看| 欧美日本高清视频在线观看| 亚洲精品成人少妇| 国产区一区二区三区| 欧美大白屁股肥臀xxxxxx| 奇米影视一区二区三区小说| 日本成人黄色免费看| 中文一区一区三区高中清不卡| 成人高清免费观看| 欧美一卡2卡三卡4卡5免费| 日本伊人色综合网| 亚洲日本精品国产第一区| 亚洲日韩欧美一区二区在线| www.成人av| 国产亚洲欧美在线| 91麻豆国产精品久久| 精品入口麻豆88视频| 国产成人精品综合在线观看| 欧美三级午夜理伦三级中视频| 五月天一区二区| 一区二区三区四区| 亚洲高清在线视频| 午夜精品一区二区在线观看的| 一个色妞综合视频在线观看| 麻豆av一区二区| 亚洲精品成人少妇| 亚洲国产一区在线| 日韩精品三区四区| 欧美伊人久久久久久久久影院| 三级欧美在线一区| 欧美无人高清视频在线观看| 免费不卡在线视频| 欧美性猛交xxxxxxxx| 国产一区二区三区美女| 6080国产精品一区二区| 东方aⅴ免费观看久久av| 精品欧美久久久| 99精品久久99久久久久| 国产亚洲精品久| 久久久久资源| 亚洲午夜成aⅴ人片| 中文字幕乱码一区二区三区| 琪琪一区二区三区| 制服丝袜国产精品| 2014亚洲精品| 亚洲日本成人在线观看| 影音欧美亚洲| 国产精品一卡二| 久久久久久免费网| 另类欧美小说| 日本午夜一区二区| 日韩一区二区高清| 国产二区一区| 天堂蜜桃91精品| 日韩一区国产二区欧美三区| yy111111少妇影院日韩夜片| 亚洲狠狠丁香婷婷综合久久久| 一区二区三视频| 国产99久久久国产精品潘金网站| 久久综合色之久久综合| 久久96国产精品久久99软件| 亚洲成av人片| 91精品国模一区二区三区| 91丨porny丨国产| 亚洲小说欧美激情另类| 欧美男女性生活在线直播观看| 不卡一区二区在线| 亚洲激情综合网| 欧美在线观看视频一区二区| 成人av免费在线观看| 亚洲另类春色国产| 欧美日韩精品电影| 国模精品娜娜一二三区| 另类人妖一区二区av| 欧美激情在线一区二区| 亚洲成色www久久网站| 国产精品一级片在线观看| 国产精品成人一区二区三区夜夜夜| 中文字幕久精品免| 99re8在线精品视频免费播放| 一区二区久久久久久| 欧美军同video69gay| 久久精品ww人人做人人爽| 国产一区二区免费在线| 亚洲精品国产一区二区精华液| 欧美日韩国产在线播放网站| 成人情视频高清免费观看电影| 麻豆精品国产91久久久久久| 国产午夜精品久久久久久免费视| 一卡二卡3卡四卡高清精品视频| www.日本不卡| 日本欧美一区二区三区| 国产精品久久久久久久浪潮网站 | 日产欧产美韩系列久久99| 国产亚洲精品免费| 日本高清成人免费播放| 国产自产在线视频一区| 国产成人欧美日韩在线电影| 一区二区三区中文在线观看| 精品成人一区二区三区四区| 色综合久久久久| 国产一区二区免费电影| 国产不卡视频一区| 午夜电影一区二区三区| 国产精品黄色在线观看 | 国产日产欧美精品一区二区三区| 日本电影亚洲天堂一区| 欧美深深色噜噜狠狠yyy| 91香蕉视频mp4| 激情六月婷婷久久| 亚洲va韩国va欧美va| 亚洲丝袜美腿综合| 久久久www成人免费无遮挡大片| 欧美日韩国产综合一区二区三区| 欧洲一区二区日韩在线视频观看免费 | 日韩免费看网站| 91精彩视频在线| 色涩成人影视在线播放| 国产精品我不卡| 99久久精品无码一区二区毛片| 国产精品自在欧美一区| 精品一区二区av| 毛片av一区二区三区|