青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

 說明:
         感謝luckycat陳梓瀚(vczh) 的留言。
         下面的代碼已經(jīng)在Windows VC6/ Cygwin/ Suse Linux環(huán)境下編譯測試通過.

#include <iostream>
#include 
<list>
#include 
<string>
#include 
<cctype>

using namespace std;

typedef unsigned 
int    UINT32;
typedef unsigned 
short  UINT16;

/************************************************************************/
/* 枚舉定義: 性別                                         */
/************************************************************************/
typedef 
enum enumSexyType
{
    SEXY_TYPE_MAN,   
//男性
    SEXY_TYPE_WOMAN, //女性
    SEXY_TYPE_GAY,   //男同性戀
    SEXY_TYPE_LESIBAIN, //女同性戀

    SEXY_TYPE_BUTT   
//未知性別
}ENUM_SEXY_TYPE;

/************************************************************************/
/* 結(jié)構(gòu)體定義:  人                                                      */
/************************************************************************/
typedef 
struct structMan
{
    UINT32    sexType; 
// 性別 ENUM_SEXY_TYPE
    UINT16      usAge;   // 年齡
    string    strName; // 名字
    string    strAddress; // 工作地址
    
    
bool operator < (const structMan &man) const
    {
        
return usAge < man.usAge;
    }

    
bool operator > (const structMan &man) const
    {
        
return usAge > man.usAge;
    }

    structMan(UINT32 enumSexType 
= SEXY_TYPE_MAN,\
              UINT16 usAge 
= 0 ,\
              
const string &refStrName = "" ,\
              
const string &refStrAddress = "")\
              : 
              sexType(enumSexType),\
              usAge(usAge) ,\
              strName(refStrName),\
              strAddress(refStrAddress)
    {
        
//DO NOTHING HERE
    }; 
}MAN;



//////////////////////////////////////////////////////////////////////////

typedef list
<MAN> Family;
typedef list
<MAN>::iterator FamilyIterator;

/*
 *    main函數(shù) 定義
 
*/
int main()
{
    
/* 初始化 */
    MAN stFather(SEXY_TYPE_MAN,   
28"倒霉熊老爸""華為技術(shù)有限公司");
    MAN stMother(SEXY_TYPE_WOMAN, 
27"蝦米老媽""鄭州大學(xué)第二附屬醫(yī)院");
    MAN stBaby  (SEXY_TYPE_BUTT,  
0,  "小天使",   "未知");
    Family myFamily;

    
/* 依次存放到list中    */
    myFamily.push_back(stFather);
    myFamily.push_back(stMother);
    myFamily.push_back(stBaby);

    
/* 調(diào)用list的sort函數(shù)進行排序, 默認會使用結(jié)構(gòu)體重載的<號, 進行從小到大排序 */
    myFamily.sort();

    printf(
"按年齡從小到大排序:\n");
    FamilyIterator it 
= myFamily.begin();
    
while(it != myFamily.end())
    {
        printf(
"姓名: %s \n", it->strName.c_str());
        it
++;
    }

    
/* 調(diào)用模板函數(shù) greater, 傳入MAN結(jié)構(gòu)體, 這樣會調(diào)用結(jié)構(gòu)體重載的>號, 進行從大到小排序 */
    greater
<MAN> gt;
    myFamily.sort(gt);

    printf(
"\n按年齡從大到小排序:\n");
    it 
= myFamily.begin();
    
while(it != myFamily.end())
    {
        printf(
"姓名: %s \n", it->strName.c_str());
        it
++;
    }

    
return 0;
}


Feedback

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)[未登錄]  回復(fù)  更多評論   

2010-03-06 16:23 by luckycat
看完代碼,給我的第一感覺:代碼存在嚴(yán)重的bug(不知道你自己測試過沒有).
簡單的說就是"不要對非POD類型進行memset操作".
在C++中不要對class進行memset操作;盡量不要對struct進行memset操作.

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 16:37 by luckycat
@小蘇
sorry,沒有注意到最后一句話"注意: 以上代碼在VC6環(huán)境下編譯、測試通過".
我所指出的bug依然存在,不同的編譯器對"memset 非POD處理方式可能不一樣".
即使VC6測試通過,你可以換個編譯器試試.

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 18:23 by 陳梓瀚(vczh)
@luckycat
沒有通過VC9或者GCC或者C++Builder編譯過的C++代碼,即使測試通過了,也是不能相信的。

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 18:24 by 小蘇
@luckycat
你講的非常又道理,這個代碼拿到Cygwin和SuseLinux下面跑都是會出現(xiàn)段錯誤的。

我又重新修改了一下,你在審閱下,看看還有什么問題?
因為我的焦點在List排序方法上,所以沒有考慮內(nèi)存越界問題...hoho

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 18:54 by 小蘇
@luckycat

恩,說的沒錯。

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 19:01 by 空明流轉(zhuǎn)
@luckycat
有關(guān)于POD的問題:
如果所有成員均為POD,且不帶虛函數(shù)的struct,class,由于采用的是C兼容的內(nèi)存布局,仍然可以看成是POD的。

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 19:52 by 陳梓瀚(vczh)
@小蘇
亂來嘛。luckycat跟你說非POD不要用memset,也就是說你原本類用的是string就寫個構(gòu)造函數(shù)嘛。現(xiàn)在倒好,回歸原始……而且還先賦值給string再memcpy,干嘛不直接strcpy了事。

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 20:29 by luckycat
呵呵,我就喜歡大家這種踴躍討論的氛圍,互相學(xué)習(xí):)

上面的代碼你在VC6下面測試通過了,因為從我的第一感覺來看,必定:coredump.
當(dāng)時我還真不太相信,所以我自己也測試了一下,結(jié)果如下:
Win32: VC2005 debug/release下均可運行正常,不過因為memset非POD,出現(xiàn)內(nèi)存泄漏.
Win32: MinGW Studio 直接abort.(這是我預(yù)期的結(jié)果).

Linux: Slackware32/GCC 直接abort.(這也是我預(yù)期的結(jié)果).

為了證明上在win32/VC2005下上面的代碼出現(xiàn)內(nèi)存泄漏,大家可以用下面的代碼做測試:
(這里把小蘇同學(xué)的代碼取了一部分用于配合測試)

運行下面的代碼,大家在任務(wù)管理器中觀察內(nèi)存增長情況:)


#include "Windows.h"

#include <string>
#include <cstring>
#include <cstdlib>

using namespace std;

typedef unsigned int UINT32;
typedef unsigned short UINT16;

typedef struct structMan
{
UINT32 sexType; //ENUM_SEXY_TYPE
UINT16 usAge;
string strName;
string strAddress;

bool operator < (const structMan &man) const
{
return usAge < man.usAge;
}

bool operator > (const structMan &man) const
{
return usAge > man.usAge;
}
}MAN;

int main( int argc , char *argv[] )
{

while( true )
{
MAN man;
memset( &man , 0 , sizeof( MAN ) );
man.strAddress = "abcdef";
man.strName = "abc";
Sleep( 10 ); //這里sleep是為了讓大家有時間在任務(wù)管理器中看到內(nèi)存增長的過程,不至于一下子耗盡內(nèi)存.
}


return 0;
}

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 21:01 by luckycat
@小蘇
你后續(xù)修改的代碼,在我看來,即使在多個編譯器下都是OK的,但是就代碼風(fēng)格來說,還有改進的地方.
在編碼過程中,我很少會對struct進行memset操作,只是偶爾會對sockaddr進行memset操作;更不會對class進行memset操作.

在你上述的代碼中,你對MAN進行memset操作,無非也就是想將各個成員的初值清零,如果基于這個出發(fā)點,那設(shè)計一個構(gòu)造函數(shù)多好:
structMan::structMan( UINT32 enumSexType = SEXY_TYPE_MAN , \
UINT16 uiAge = 0 , \
const std::string &refStrName = "" , \
const std::string &refStrAddress = "" )
:sexType( enumSexType ) , usAge( uiAge ) , \
strName( refStrName ) , strAddress( refStrAddress )
{
// check parameters here。
}

只需要少量的代碼就會帶來大量的方便,而且你也就再也不用memset.
你也就不需要對struct的各個成員依次賦值了,直接傳參構(gòu)造就可以了,這樣代碼應(yīng)該會更優(yōu)雅一些.

另一方面,對 std::list 進行sort操作從邏輯上是沒有問題的,但是設(shè)計風(fēng)格上是有問題的:
因為std::list中的每一個成員是基于鏈的形式連接在一起的,所以我們不能對其進行隨機訪問,
如果我們要訪問std::list中的第N個成員,那么我們需要從鏈表頭開始向鏈表尾部依次迭代N次,
在這種情況下,如果一個鏈表過大,那么這里就有效率問題.

一般情況下,我們只對"類似于數(shù)組的可以隨機訪問"的std容器進行排序.

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 21:25 by 陳梓瀚(vczh)
@luckycat
我在想他用list估計是因為別的語言都叫l(wèi)ist,不知道C++叫的是vector……

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 21:29 by 小蘇
@luckycat

這段測試代碼我跑了二十分鐘,內(nèi)存也沒見增長啊~~~
各位大俠都看出來啦,我很少用C++寫程序~~~~

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 21:35 by luckycat
@小蘇
你運行后仔細觀察這個編譯后運行的exe在"windows任務(wù)管理器"中對應(yīng)的
"內(nèi)存使用"數(shù)值.
我用VC2005和VC2008都測試過,結(jié)果是"內(nèi)存不停增長".

還用哪位同學(xué)運行過我上面的測試代碼,出來公布一下測試結(jié)果,謝謝!

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 22:10 by 小蘇
@luckycat

能否解釋一下,為什么內(nèi)存使用會不停增長呢?

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 22:50 by luckycat
@小蘇
在閱讀下面的分析之前,希望你對"C++對象的內(nèi)部布局"有一定的了解.
既然你也發(fā)現(xiàn)了內(nèi)存泄漏的情況,那么你再用下面的測試代碼運行一下:



#include "Windows.h"

#include <string>
#include <cstring>
#include <cstdlib>

using namespace std;

typedef unsigned int UINT32;
typedef unsigned short UINT16;

typedef struct structMan
{
UINT32 sexType; //ENUM_SEXY_TYPE
UINT16 usAge;
string strName;
string strAddress;

bool operator < (const structMan &man) const
{
return usAge < man.usAge;
}

bool operator > (const structMan &man) const
{
return usAge > man.usAge;
}
}MAN;

int main( int argc , char *argv[] )
{

while( true )
{
MAN man;
fprintf( stdout , "before memset: char buffer address( heap address ) to store string = %p , size = %lu , capacity = %lu\n" , \
*reinterpret_cast< const int* >( man.strName.c_str() ) , \
man.strName.size() , man.strName.capacity() );
memset( &man , 0 , sizeof( MAN ) );
fprintf( stdout , "after memset: char buffer address( heap address ) to store string = %p , size = %lu , capacity = %lu\n\n\n" , \
*reinterpret_cast< const int* >( man.strName.c_str() ) , \
man.strName.size() , man.strName.capacity() );

man.strAddress = "abcdef";
man.strName = "abc";
Sleep( 1000 ); //這里sleep是為了讓大家有時間在任務(wù)管理器中看到內(nèi)存增長的過程,不至于一下子耗盡內(nèi)存.
}


return 0;
}


我選取我這里的一個循環(huán)中的輸出,如下:


before memset: char buffer address( heap address ) to store string = 00636200 ,
size = 0 , capacity = 15
after memset: char buffer address( heap address ) to store string = 00000000 ,
size = 0 , capacity = 0

下面把上述代碼進行簡化便于分析:

while( true )
{
MAN man; //這里會使用man由編譯器自動生成缺省構(gòu)造函數(shù)來調(diào)用strName的缺省構(gòu)造函數(shù)對strName進行構(gòu)造.

memset( &man , 0 , sizeof( MAN ) );
上面的memset操作會把 &man 這個地址開始的 sizeof( MAN )字節(jié)的內(nèi)存空間全部清零.
這也就意味著 man 對象內(nèi)部的每個成員子對象所占據(jù)的內(nèi)存都被清零.
man 對象內(nèi)部一個 std::string , 而std::string 內(nèi)部包含一個std::string用于實際存儲字符串的指向動態(tài)分配的堆內(nèi)存的指針,
我們假設(shè)這個指針的名稱為 m_pCharBuffer;
在std::string的析構(gòu)函數(shù)中釋放這個動態(tài)分配的堆內(nèi)存的時候需要使用這個m_pCharBuffer,也即是調(diào)用 delete[] m_pCharBuffer;
如果我寫出下在的代碼:
char *m_pCharBuffer = new char[ BUFFER_SIZE ]; 這一個操作即是strName的缺少構(gòu)造函數(shù)的操作,只不過 BUFFER_SIZE = 15 + 1(最后有一個'\0');
m_pCharBuffer = NULL; //這一個操作與上述的 memset 對 man.strName中用于指向動態(tài)內(nèi)存的指針?biāo)a(chǎn)生的作用相同:將指針?biāo)赶虻亩褍?nèi)存地址清零.
delete[] m_pCharBuffer; //此時 m_pCharBuffer 為NULL , 不過在C++中, delete NULL指針是安全的.不過因為 m_pCharBuffer 已經(jīng)不指向上述new出來的內(nèi)存
//所以這里進行 delete[] m_pCharBuffer 時已經(jīng)不能進行資源的釋放了,也即是發(fā)生了內(nèi)存泄漏.

man.strName = "abc";
上面的賦值操作中,實際上要調(diào)用: std::string::operator=( const char* );
首先,operator=會判斷當(dāng)前的strName的 capacity能否容納下"abc",由上面的memset之后我們可以看出此時存儲 capacity 值的變量因為memset為0,所以
man.strName.capacity() 輸出為0,這也就意味著這個"容積"不能容納下3個字節(jié)的"abc".

所以這時 operator= 要擴大內(nèi)部用于存儲字符串的緩沖區(qū),擴充的基本原理如下:(代碼進行簡化處理)

std::string& operator=( const char *szString )
{
// check parameter

if( m_pCharBuffer != szString ) // 防止 self-assign
{
delete[] m_pCharBuffer;
m_pCharBuffer = new char[ NEW_SIZE ];
memcpy( m_pCharBuffer , szString , strlen( szString ) + 1 );
}

return *this;

}

上面的操作: *reinterpret_cast< const int* >( man.strName.c_str() ) 即是相當(dāng)于獲取這個 m_pCharBuffer 的地址.
這一點你一定要明白.

由上面的代碼以及運行輸出可以知道,
注意: 在調(diào)用 strName = "abc"時,已經(jīng)進行了memset操作,此時的 m_pCharBuffer 已經(jīng)因為上面的 memset操作而被清零,即是 m_pCharBuffer = NULL,
因為memset操作不會調(diào)用析構(gòu)函數(shù) ,所以實際上在清零之前它所指向的動態(tài)內(nèi)存塊并沒有被釋放,
在 operator=中,delete[] m_pCharBuffer; 相當(dāng)于 delete[] NULL;
這就不能釋放 m_pCharBuffer 之前在缺省構(gòu)造時所指向的動態(tài)分配的 15 + 1 字節(jié)的內(nèi)存了,所以出現(xiàn)了內(nèi)存泄漏.

}

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 23:10 by luckycat
@小蘇
為了更好的理解我上面的分析,你可以打開VC2005/VC2008(我這里是VC2008)的單步調(diào)試,
在調(diào)試模式下的"自動窗口"(位于IDE下方).
觀察memset 前后"man -> strName -> _Bx -> _Ptr"的值的變化
_Ptr 實際上就是std::string內(nèi)部用于存儲字符串的堆內(nèi)存緩沖區(qū)的地址,也相當(dāng)于我上面提到的 m_pCharBuffer

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 23:10 by 小蘇
@luckycat

我的測試結(jié)果是:
before memset: char buffer address( heap address ) to store string = 0000000 ,
size = 0 , capacity = 0
after memset: char buffer address( heap address ) to store string = 00000000 ,
size = 0 , capacity = 0

這里沒法貼圖,我的QQ是270083015,比這里討論快一點
我用的VC6 我想這是我的內(nèi)存沒有增長的原因吧。

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-06 23:15 by luckycat
@小蘇
VC6我這里沒有,我上面的輸出是在VC2008下的測試結(jié)果,你換用VC2005/2008再試試.
我的建議是學(xué)習(xí)C++就不要用VC6了,可以用VC2005/2008.
如果你想用一個輕量級的環(huán)境學(xué)習(xí)C++,MinGW Studio,
wxDev-Cpp , CodeBlocks , CodeLite 都是不錯的選擇.

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-07 10:07 by zuhd
luckcat解釋的很中肯,學(xué)習(xí)了

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-07 13:03 by 凡客誠品官方網(wǎng)站
施法時間開的飛快見說道

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2010-03-07 21:02 by 一個建議
瞄了一眼代碼,輸出全是printf ,C語言的不良習(xí)慣太多了。為什么不用cout呢。

# re: C++基礎(chǔ)知識: list結(jié)構(gòu)體排序方法(一)  回復(fù)  更多評論   

2013-09-23 22:32 by toman
呵呵,路過,今天面試被問list vector區(qū)別,我竟然說vector比較好些,
然后就是胡謅........面試啊面試

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美成人免费全部| 欧美日韩国产精品成人| 久久久视频精品| 欧美日韩一区在线| 亚洲精品视频一区| 免费亚洲一区二区| 久久精品成人欧美大片古装| 国产精品国产三级国产专播品爱网| 亚洲人成网在线播放| 久久综合久久美利坚合众国| 亚洲欧美另类在线| 国产伦精品一区二区三区视频孕妇| 亚洲伊人伊色伊影伊综合网| 一本色道久久综合| 欧美日韩在线视频首页| 在线视频亚洲欧美| 一区二区三区久久久| 国产精品久久综合| 小处雏高清一区二区三区| 亚洲综合色在线| 国产精品区一区二区三区| 欧美一区成人| 久久精品欧洲| 亚洲国产老妈| 亚洲精品一级| 国产精品日日摸夜夜添夜夜av| 香蕉成人啪国产精品视频综合网| 亚洲在线成人| 欲色影视综合吧| 亚洲激情成人| 欧美激情精品久久久久久| 国产精品99久久久久久久女警| 一本久道久久综合中文字幕| 国产精品毛片| 久久综合999| 欧美激情亚洲综合一区| 亚洲免费在线| 久久裸体艺术| 一区二区激情视频| 午夜国产精品影院在线观看| 影音先锋亚洲视频| 亚洲精品小视频| 国产精品视频一| 开心色5月久久精品| 欧美www视频| 午夜亚洲精品| 美日韩在线观看| 午夜精品久久久久久久99樱桃| 久久久999| 亚洲午夜伦理| 久久久久久一区二区| 欧美sm视频| 先锋影音久久久| 奶水喷射视频一区| 性伦欧美刺激片在线观看| 久久视频国产精品免费视频在线| 日韩视频精品| 久久福利一区| 亚洲欧美亚洲| 欧美精品一区二区视频| 久久久久久成人| 欧美视频在线观看一区| 欧美成人国产va精品日本一级| 国产精品r级在线| 欧美成人国产一区二区| 国产欧美精品日韩精品| 亚洲国产一区二区在线| 精品51国产黑色丝袜高跟鞋| 亚洲私人影院在线观看| 亚洲激情在线观看视频免费| 欧美专区在线观看一区| 亚洲欧美成人一区二区三区| 欧美mv日韩mv国产网站app| 欧美在线视频播放| 欧美日韩视频| 亚洲高清久久| 亚洲丁香婷深爱综合| 午夜视频一区| 欧美一区=区| 国产精品v欧美精品∨日韩| 91久久精品www人人做人人爽| 精品999在线播放| 亚洲欧美伊人| 欧美亚洲专区| 国产精品视频网| 亚洲深夜av| 亚洲一区黄色| 欧美三级资源在线| 99国产麻豆精品| 99人久久精品视频最新地址| 欧美r片在线| 亚洲国产精品视频一区| 亚洲国产欧洲综合997久久| 久久久亚洲一区| 久久综合伊人77777蜜臀| 国内久久视频| 久久蜜桃av一区精品变态类天堂| 久久伊人精品天天| 激情视频亚洲| 另类尿喷潮videofree| 美玉足脚交一区二区三区图片| 极品中文字幕一区| 久热精品在线视频| 欧美国产欧美亚州国产日韩mv天天看完整 | 午夜精品视频在线观看| 欧美视频中文在线看| 99ri日韩精品视频| 亚洲一区3d动漫同人无遮挡| 欧美丝袜一区二区| 亚洲影视中文字幕| 欧美伊人精品成人久久综合97| 国产女人18毛片水18精品| 久久国产视频网站| 欧美成人精精品一区二区频| 亚洲经典在线| 欧美日韩精品一区二区| 中文日韩在线| 在线成人免费观看| 欧美国产精品v| 亚洲午夜影视影院在线观看| 久久激情一区| 亚洲第一主播视频| 欧美人与性动交α欧美精品济南到| 日韩亚洲欧美中文三级| 欧美一区观看| 亚洲人成网站色ww在线| 国产精品videossex久久发布| 久久av二区| 亚洲第一区在线观看| 亚洲图片激情小说| 国产香蕉久久精品综合网| 你懂的国产精品永久在线| 一区二区三区欧美在线| 蜜臀久久99精品久久久久久9| 一区二区欧美亚洲| 国内精品伊人久久久久av影院| 欧美激情第9页| 新片速递亚洲合集欧美合集| 亚洲国产网站| 久久青青草综合| 亚洲一级黄色av| 亚洲成人在线免费| 国产精品免费小视频| 欧美成人精品激情在线观看| 亚洲一区二区三区精品在线观看| 欧美成人国产| 欧美在线免费观看亚洲| 在线视频欧美日韩| 亚洲黄色在线视频| 国产亚洲精品自拍| 欧美色中文字幕| 免费不卡在线视频| 性做久久久久久| 一区二区三区回区在观看免费视频| 久久午夜羞羞影院免费观看| 午夜精品www| 一区二区三区高清不卡| 亚洲第一精品电影| 国产在线国偷精品产拍免费yy| 欧美日韩国产系列| 欧美成人免费在线| 久久国内精品自在自线400部| 一本色道久久综合狠狠躁篇的优点| 欧美电影在线播放| 久久一区二区精品| 久久不射网站| 午夜精品视频网站| 亚洲一区二区三区影院| 亚洲免费精彩视频| 亚洲精品一区二区三区樱花| 在线高清一区| 在线欧美三区| 亚洲国产精品va在看黑人| 狠狠综合久久| 一区二区三区在线视频免费观看| 国产日韩欧美不卡在线| 国产伦精品一区二区三区视频黑人| 欧美色图麻豆| 国产精品高潮在线| 国产精品久久久久久久久久ktv| 欧美视频网站| 国产精品国产三级国产专播精品人 | 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲国产欧美在线| 亚洲国产裸拍裸体视频在线观看乱了中文| 久久久久久久999| 久久青青草原一区二区| 美乳少妇欧美精品| 欧美黄色小视频| 亚洲福利av| 亚洲精品免费在线播放| 99精品久久| 亚洲制服丝袜在线| 久久综合伊人| 欧美成人免费在线视频| 亚洲日本黄色| 亚洲视频在线视频| 香蕉成人久久| 久久伊人亚洲| 欧美女同视频|