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

面對現(xiàn)實,超越自己
逆水行舟,不進則退
posts - 269,comments - 32,trackbacks - 0
本文轉(zhuǎn)自:http://blog.csdn.net/bao_qibiao/article/details/4528860

在MFC程序中,可以用以下幾種方法來獲取命令行參數(shù)。
為方便說明,我們假設(shè)執(zhí)行了命令:C:/test/app.exe -1 -2

方法一

1 ::GetCommandLine ();
2 //將獲取到 "C:/test/app.exe"  -1 -2 

方法二

1 for (int i=0;i<__argc ;i++)
2 {
3 __argv [i];
4 //將依次得到C:/test/app.exe   -1   -2 
5 }

方法三

1 AfxGetApp ()->m_lpCmdLine;
2 //將獲取到 -1 -2 

 

posted @ 2012-04-12 12:26 王海光 閱讀(656) | 評論 (0)編輯 收藏
本文轉(zhuǎn)自:http://www.flighty.cn/html/bushu/20110322_114.html

最新的WinVer.nsh下載:
http://nsis.sourceforge.net/Include/WinVer.nsh(下載后置于\NSIS\Inclued中)

AtLeastWin<version> 檢測是否高于指定版本
IsWin<version> 檢測指定版本(唯一限定版本)
AtMostWin<version> 檢測是否低于指定版本

<version> 允許的值:
95、98、ME、NT4、2000、XP、2003、Vista、2008、7、2008R2

示例1:

折疊NSIS 代碼
 1 !include "MUI.nsh"  
 2 !include "WinVer.nsh"  
 3 !insertmacro MUI_LANGUAGE "simpchinese"  
 4   
 5 Section     
 6 ${If} ${AtLeastWinVista}   
 7   MessageBox MB_OK "系統(tǒng)為 Vista 或 Vista 以上系統(tǒng)!"  
 8 ${EndIf}   
 9   
10 ${If} ${IsWin2000}   
11 ${OrIf} ${IsWinXP}   
12   MessageBox MB_OK "系統(tǒng)為 2000 或 XP!"  
13 ${EndIf}   
14   
15 ${If} ${AtMostWinXP}   
16   MessageBox MB_OK "系統(tǒng)版本為 XP 或更低版本的系統(tǒng)!"  
17 ${EndIf}
18 SectionEnd    

示例2:

折疊NSIS 代碼
 1 !include "MUI.nsh"  
 2 !include "WinVer.nsh"  
 3 !insertmacro MUI_LANGUAGE "simpchinese"  
 4   
 5 Section     
 6 ${Unless} ${ISWinXP}   
 7 MessageBox MB_OK "本程序只能安裝在 Windows XP 系統(tǒng)上!"  
 8 Abort   
 9 ${EndIf}   
10 SectionEnd 
posted @ 2012-04-11 17:11 王海光 閱讀(3398) | 評論 (0)編輯 收藏
    創(chuàng)建一個新類用來隱藏主對話框閃爍問題

    注釋下段代碼:
 1   CPrinterMonitorExDlg dlg;
 2   m_pMainWnd = &dlg;
 3   INT_PTR nResponse = dlg.DoModal();
 4   if (nResponse == IDOK)
 5   {
 6    // TODO: Place code here to handle when the dialog is
 7    //  dismissed with OK
 8   }
 9   else if (nResponse == IDCANCEL)
10   {
11    // TODO: Place code here to handle when the dialog is
12    //  dismissed with Cancel
13   }

    替換成:
1  CMainDialog dlg;  //新類對象
2  m_pMainWnd = &dlg;
3  dlg.Create(CMainDialog::IDD); 
4  dlg.ShowWindow(SW_HIDE);      
5  dlg.RunModalLoop();

    用對話框隱藏等待程序,在xp系統(tǒng)下會出現(xiàn)一個問題,就是:如果程序是system權(quán)限啟動,第一次注銷機器正常,但第二次注銷時就會出現(xiàn)注銷失敗的情況。隱藏的對話框在注銷時無法被關(guān)閉。
    可以用事件等待來代替上面的程序。
1 CEvent    m_evtWait;
2 if (WAIT_FAILED == ::WaitForSingleObject(m_evtWait, INFINITE))
3     {
4         DWORD wError = GetLastError();
5         LOG("WaitForSingleObject函數(shù)出現(xiàn)錯誤,錯誤代碼:%d,程序退出", wError);
6         return FALSE;
7     }
posted @ 2012-04-10 16:02 王海光 閱讀(619) | 評論 (0)編輯 收藏
轉(zhuǎn)自:http://www.shnenglu.com/humanchao/archive/2008/08/29/60368.html

問題找出整數(shù)1~N范圍和為M的所有集合,M<=N且M>1,集合里的數(shù)不允許重復(fù)。

解答:這個問題用遞歸解決最簡單,代碼如下:

 1 #define MAX_NUM 20        //要足夠大
 2 int log[MAX_NUM];        //記錄和數(shù)
 3 int index = 0;            //log[]數(shù)組的當前指針
 4 
 5 void calc(int start, int n)
 6 {
 7     if (n == 0)  
 8     {
 9         for(int j = 0; j < index; j++)
10             printf("%d ", log[j]);
11         printf("\n");
12     }
13     else
14     {
15         for(int i = start; i<=n; i++)
16         {
17             log[index++= i;    
18             calc(i + 1, n - i);
19         }
20     }
21 
22     index--;
23 }

如果允許重復(fù)只需要將上面第18條代碼改為:

calc(i, n - i);

即可。

擴展問題在數(shù)組{5,1,7,9,2,10,11,4,13,14}中找到和為28的所有集合,集合中不允許有重復(fù)的數(shù)。

解答:第一步要先對數(shù)組排序,然后按照上去的思路,對程序略做一些改動。
代碼如下:

 1 #define MAX_NUM 20        //要足夠大
 2 int log[MAX_NUM];        //記錄和數(shù)
 3 int index = 0;            //log[]數(shù)組的當前指針
 4 
 5 void calc__(int *nArr     //數(shù)組, 
 6             int start    //數(shù)組起始元素下標, 
 7             int nArrLen    //數(shù)組長度, 
 8             int sum)
 9 {
10     if (sum == 0)  
11     {
12         for(int j = 0; j < index; j++)
13             printf("%d ", log[j]);
14         printf("\n");
15     }
16     else
17     {
18         for(int i = start; i < nArrLen; i++)
19         {
20             log[index++= nArr[i];    
21             calc__(nArr, i+1, nArrLen, sum - nArr[i]);
22         }
23     }
24     
25     index--;
26 }

posted @ 2012-04-10 12:37 王海光 閱讀(688) | 評論 (0)編輯 收藏
轉(zhuǎn)自:http://www.shnenglu.com/humanchao/archive/2008/04/17/47357.html


有一個單鏈表,其中可能有一個環(huán),也就是某個節(jié)點的next指向的是鏈表中在它之前的節(jié)點,這樣在鏈表的尾部形成一環(huán)。

問題:

1、如何判斷一個鏈表是不是這類鏈表?
2、如果鏈表為存在環(huán),如何找到環(huán)的入口點?

解答:

一、判斷鏈表是否存在環(huán),辦法為:

設(shè)置兩個指針(fast, slow),初始值都指向頭,slow每次前進一步,fast每次前進二步,如果鏈表存在環(huán),則fast必定先進入環(huán),而slow后進入環(huán),兩個指針必定相遇。(當然,fast先行頭到尾部為NULL,則為無環(huán)鏈表)程序如下:

bool IsExitsLoop(slist *head)
{
    slist
*slow = head*fast = head;

    while ( fast && fast->next ) 
    {
        slow 
= slow->next;
        fast 
= fast->next->next;
       
if ( slow == fast ) break;
    }

    return !(fast == NULL || fast->next == NULL);
}

二、找到環(huán)的入口點

當fast若與slow相遇時,slow肯定沒有走遍歷完鏈表,而fast已經(jīng)在環(huán)內(nèi)循環(huán)了n圈(1<=n)。假設(shè)slow走了s步,則fast走了2s步(fast步數(shù)還等于s 加上在環(huán)上多轉(zhuǎn)的n圈),設(shè)環(huán)長為r,則:

2s = s + nr
s= nr

設(shè)整個鏈表長L,入口環(huán)與相遇點距離為x,起點到環(huán)入口點的距離為a。
a + x = nr
a + x = (n – 1)r +r = (n-1)r + L - a
a = (n-1)r + (L – a – x)

(L – a – x)為相遇點到環(huán)入口點的距離,由此可知,從鏈表頭到環(huán)入口點等于(n-1)循環(huán)內(nèi)環(huán)+相遇點到環(huán)入口點,于是我們從鏈表頭、與相遇點分別設(shè)一個指針,每次各走一步,兩個指針必定相遇,且相遇第一點為環(huán)入口點。程序描述如下:

slist* FindLoopPort(slist *head)
{
    slist
*slow = head, *fast = head;

    while ( fast && fast->next ) 
    {
        slow 
= slow->next;
        fast 
= fast->next->next;
       
if ( slow == fast ) break;
    }

    if (fast == NULL || fast->next == NULL)
   
    return NULL;

    slow 
= head;
    while (slow != fast)
    {
         slow 
= slow->next;
         fast 
= fast->next;
    }

    return slow;
}


擴展問題:

判斷兩個單鏈表是否相交,如果相交,給出相交的第一個點(兩個鏈表都不存在環(huán))。

比較好的方法有兩個:

一、將其中一個鏈表首尾相連,檢測另外一個鏈表是否存在環(huán),如果存在,則兩個鏈表相交,而檢測出來的依賴環(huán)入口即為相交的第一個點。

二、如果兩個鏈表相交,那個兩個鏈表從相交點到鏈表結(jié)束都是相同的節(jié)點,我們可以先遍歷一個鏈表,直到尾部,再遍歷另外一個鏈表,如果也可以走到同樣的結(jié)尾點,則兩個鏈表相交。

這時我們記下兩個鏈表length,再遍歷一次,長鏈表節(jié)點先出發(fā)前進(lengthMax-lengthMin)步,之后兩個鏈表同時前進,每次一步,相遇的第一點即為兩個鏈表相交的第一個點。

posted @ 2012-04-09 16:56 王海光 閱讀(769) | 評論 (0)編輯 收藏
轉(zhuǎn)自:http://www.shnenglu.com/humanchao/archive/2008/02/29/43446.html


void printSList(slist *pList)
{
    assert(pList);
    
if (pList == NULL)
        
return;

    string str;
    
while (pList)
    {
        str 
= string(*pList) + str;
        pList 
= pList->next;
    }

    printf(
"%s", str.c_str());
}

遞歸:

void printSList(slist *pList)
{
    assert(pList);
    
if (pList == NULL)
        
return;
    
    
if (pList->next == NULL)
        printf(
"%s"*pList);
    
else
    {
        printSList(pList
->next);
        printf(
"%s"*pList);
    }
}

分配一個數(shù)組,把指針放到數(shù)組中,然后for倒著打印
Status display(LinkList &L)

      printf("\n---------------------------顯示單鏈線性表----------------------\n"); 
      LinkList p; 
      int n[100]; 
      int j=100; 
      p=L->next; //打印的時候應(yīng)該從頭結(jié)點的下一個結(jié)點開始打印,否則會出現(xiàn)亂碼 
      printf("\n單鏈表為:\t"); 
      if(p!=NULL) 
      { 
            for(;p!=NULL;--j) 
            { 
                  n[j-1]=p->date; //j-1是因為100要存放頭結(jié)點的位置 
                  p=p->next; 
            } 
            for(;j<100;j++) 
            { 
                  printf("%d",n[j]); 
            } 
      } 
      free(p); 
      return 1;
}//display 
posted @ 2012-04-09 16:41 王海光 閱讀(775) | 評論 (0)編輯 收藏

轉(zhuǎn)自:http://www.shnenglu.com/humanchao/archive/2008/09/12/61708.html

將字符串里詞順序倒置,如"Times New Roman"變?yōu)?Roman New Times"。以空格為分隔符。

解決方案為:先將整個字串倒置,然后依次把倒置后串中的每一個單詞倒置。

這個問題解答的思路很簡單,但是要考慮到很多種的情況,比如字符串的頭、尾有多余的空格怎么辦,如果字符串中只有空格,還有字符串中間可能會有兩個以上并列的空格。

程序如下:

 1 void ReverseStr(char *pStr, int len)
 2 {
 3     assert(pStr);
 4     
 5     char ch;
 6     for (int i = 0; i < len/2 ; i++)
 7     {
 8         ch = pStr[i];
 9         pStr[i] = pStr[len-1-i];
10         pStr[len-1-i] = ch;
11     }
12 }
13 
14 void ReverseStrWord(char *pStr, int len)
15 {
16     assert(pStr);
17 
18     if (len <= 1)
19         return;
20 
21     // 倒置整個字符串
22     ReverseStr(pStr, len);
23 
24     // 處理頭多余的空格
25     int i = 0;
26     if (pStr[0== ' ')            while (pStr[i] == ' ' && i < len)        i++;
27 
28     // 整個串都是空格
29     if (i == len)
30         return;
31 
32     // 處理尾多余的空格
33     if (pStr[len - 1== ' ')    while (pStr[len - 1== ' ' && len - 1 > 0)    len--;
34 
35     for (int start = i; i < len; i++)
36     {
37         // 最后的end要+1
38         if (i == len-1)
39         {
40             ReverseStr(pStr+start, i-start+1);
41             break;
42         }
43 
44         // 倒置一個單詞
45         if (pStr[i] == ' ')
46         {
47             ReverseStr(pStr+start, i-start);
48             start = i+1;
49             // 處理內(nèi)部并列的空格
50             if (pStr[start] == ' ')
51             {
52                 while(pStr[start] == ' ') {i++;start++;};
53             }
54         }
55     }
56 }
57 

 

posted @ 2012-04-09 13:47 王海光 閱讀(424) | 評論 (0)編輯 收藏

[轉(zhuǎn)]寫好代碼的10個秘密 收藏
作者:飛哥 (百度)

先給大家看一段據(jù)說是史上最強的程序:
e100 33 f6 bf 0 20 b5 10 f3 a5 8c c8 5 0 2 50 68 13 1 cb e 1f be a1 1 bf 0 1
e11b 6 57 b8 11 1 bb 21 13 89 7 4b 4b 48 79 f9 ad 86 e0 8b c8 bd ff ff e8 20
e134 0 3d 0 1 74 1a 7f 3 aa eb f3 2d ff 0 50 e8 f 0 5a f7 d8 8b d8 26 8a 1 aa
e14f 4a 75 f9 eb de cb 57 bb 21 13 8b c1 40 f7 27 f7 f5 8b fb ba 11 1 4f 4f 4a
e168 39 5 7f f9 52 8b c5 f7 25 f7 37 2b c8 95 f7 65 2 f7 37 95 2b e8 fe e fe
e181 10 79 6 c6 6 fe 10 7 46 d0 14 d1 d1 d1 e5 79 ec 5a b8 11 1 ff 7 4b 4b 48
e19b 3b d0 75 f7 5f c3 83 f7 83 a6 5d 59 82 cd b2 8 42 46 9 57 a9 c5 ca aa 1b
.............................................................................


這段程序是1997年世界程序設(shè)計大賽的一等獎作品的部分代碼(完整的代碼下載,把代碼復(fù)制粘貼到cmd的debug命令中,回車看到效果)。這個程序運行后將是一個3D的且伴隨著音樂的動畫。震撼吧!
是不是從事軟件開發(fā)的人員都希望成為這樣的武林高手呢?然而真要是用這樣的高手來設(shè)計、編寫我們的產(chǎn)品代碼,恐怕某一天,我們什么都不用干了,只能人手一本機器代碼,一句一句進行翻譯了;那么對于軟件產(chǎn)品開發(fā)而言,如何寫好代碼呢?一流的軟件產(chǎn)品的代碼具備哪些特征呢?


 

一流代碼的特征


1、穩(wěn)定可靠(Robustness)
代碼寫出來以后,一定要能夠運行得非常好,非常穩(wěn)定可靠。在現(xiàn)今的IT行業(yè),軟件產(chǎn)品都是是24*7,即要保證系統(tǒng)一天24小時,一星期7天中都可以無間斷的正常運行。比如我們百度的搜索引擎系統(tǒng),比如我們的通信系統(tǒng),等等。到了產(chǎn)品開發(fā)后期,大部分的成本都將投入到產(chǎn)品穩(wěn)定性的提高。

2、可維護且簡潔(Maintainable and Simple Code)
在寫代碼時,首先要考慮的是:寫出來的代碼不但要自己可以讀懂,而且我們的同事、測試工程師都可能要修改這些代碼,對其進行增減。如果代碼很復(fù)雜,不容易讀懂,如程序中的遞歸一大堆、程序不知何時或從何地跳出,則會使程序的可維護性和簡潔性降低。所以必要的注釋、統(tǒng)一的編程規(guī)范等都是非常重要的。

3、高效(Fast)
在軟件行業(yè)中效率是非常重要的,比如搜索引擎。有些軟件的搜索效率就不高,搜索過程特別緩慢,讓人難以接受。當然這里面有一個帶寬的問題,但是程序效率不高也是一個重要的原因。而實際上程序的效率提高,有時候很簡單,并沒有什么神秘之處,如使用數(shù)組索引時候,可以用指針方式而不使用數(shù)組下標;數(shù)組的空間定義應(yīng)該定義為2的N次冪等等。

4、簡短(Small)
這方面大家的感受可能不是很深,但是我的感受是很深的。配置過PSTN程控交換機、路由器、VoIP網(wǎng)關(guān)設(shè)備的人都知道,這些設(shè)備的軟件都是從PC機通過網(wǎng)口或串口下載到這些設(shè)備的Flash上(類似PC機的BIOS)再通過設(shè)備上的CPU啟動。如果程序?qū)懙暮芰_嗦,隨著特性不斷增加,程序規(guī)模將變大的巨大,F(xiàn)lash空間告急、內(nèi)存告急、下載升級變的不可忍受,等等,帶來的就是成本不斷增加,利潤不斷下降。

5、共享性(Reusable)
如果做大型產(chǎn)品開發(fā),程序的共享性也是非常重要的。我們產(chǎn)品有那么多開發(fā)人員,如果每一個人都自己定義字符串、鏈表等數(shù)據(jù)結(jié)構(gòu),那么開發(fā)效率就會降低,我們的產(chǎn)品恐怕到今天也不能出臺。我所說的“共享”不是指將別人的代碼復(fù)制到自己的代碼中,而是指直接調(diào)用別人的代碼,拿來即可用。這一方面可以減少代碼的冗余性,另一方面可以增強代碼的可維護性。如果別人的代碼里有Bug,只需修改他的代碼,而調(diào)用此代碼的程序不用進行任何修改就可以達到同步。這同時要求我們在設(shè)計的時候,如何考慮系統(tǒng)的內(nèi)聚和耦合的問題。

6、可測試性(Testable)
我們的產(chǎn)品開發(fā)里,除了軟件開發(fā)人員,還有一部分工程師負責(zé)軟件測試。軟件測試人員會將開發(fā)代碼拿來,一行一行地運行,看程序運行是否有錯。如果軟件開發(fā)人員的代碼不可測試,那測試工程師就沒有辦法進行工作。因此可測試性在大型軟件開發(fā)里是很重要的一點。可測試性有時候與可維護性是遙相呼應(yīng)的,一個具有好的可測試性和可維護性的代碼,測試人員可以根據(jù)開發(fā)提供的維護手冊、debug信息手冊等就可以判斷出程序出錯在哪個模塊。

7、可移植性(Portable)
可移植性是指程序?qū)懗鰜硪院螅粌H在windows 2000里可以運行,在NT/9X下可以運行,而且在Linux甚至Macintosh等系統(tǒng)下都可以運行。所有這些特性都是一流代碼所具備的特性。但是其中有些特性是會有沖突的。比如高效性,程序?qū)懙男屎芨撸涂赡茏兊煤軓?fù)雜,犧牲的就是簡潔。好的代碼要在這些特性中取得平衡。

 

寫好代碼的10個秘密

1、百家之長歸我所有(Follow Basic Coding Style)
其實寫代碼的方式有很多,每個人都有自己的風(fēng)格,但是眾多的風(fēng)格中總有一些共性的、基本的寫代碼的風(fēng)格,如為程序?qū)懽⑨尅⒋a對齊,等等。是不是編程規(guī)范?對就是編程規(guī)范。

2、取個好名字(Use Naming Conventions)
取個好的函數(shù)名、變量名,最好按照一定的規(guī)則起名。還是編程規(guī)范。

3、凌波微步,未必摔跤(Evil goto's?Maybe Not...)
這里我用“凌波微步”來形容goto語句。通常,goto語句使程序跳來跳去,不容易讀,而且不能優(yōu)化,但是在某種情況下,goto語句反而可以增強程序的可讀性。Just go ahead,not go back。

4、先發(fā)制人,后發(fā)制于人(Practic Defensive Coding)
Defensive Coding指一些可能會出錯的情況,如變量的初始化等,要考慮到出現(xiàn)錯誤情況下的處理策略。測試時要多運行幾個線程。有些程序在一個線城下運行是正常的,但是在多個線程并行運行時就會出現(xiàn)問題;而有些程序在一個CPU下運行幾個線程是正常的,但是在多個CPU下運行時就會出現(xiàn)問題,因為單CPU運行線程只是狹義的并行,多CPU一起運行程序,才是真正的并行運算。

5、見招拆招,滴水不漏(Handle The Error Cases:They Will Occur!)
這里的Error Case(錯誤情況),是指那些不易重視的錯誤。如果不對Error Case進行處理,程序在多數(shù)情況下不會出錯,但是一旦出現(xiàn)異常,程序就會崩潰。 6、熟習(xí)劍法刀術(shù),所向無敵(Learn Win32 API Seriously)
用“劍法刀術(shù)”來形容一些API是因為它們都是經(jīng)過了很多優(yōu)秀開發(fā)人員的不斷開發(fā)、測試,其效率很高,而且簡潔易懂,希望大家能掌握它,熟悉它,使用它。是不是象我們的ULIB。

7、雙手互搏,無堅不摧(Test,but don't stop there)
這里的測試不是指別人來測試你的代碼,而是指自己去測試。因為你是寫代碼的原作者,對代碼的了解最深,別人不可能比你更了解,所以你自己在測試時,可以很好地去測試哪些邊界條件,以及一些意向不到的情況。

8、活用斷言(Use,don't abuse,assertions)
斷言(assertion)是個很好的調(diào)試工具和方法,希望大家能多用斷言,但是并不是所有的情況下都可以用到斷言。有些情況使用斷言反而不合適。

9、草木皆兵,不可大意(Avoid Assumptions)
是指在寫代碼時,要小心一些輸入的情況,比如輸入文件、TCP的sockets、函數(shù)的參數(shù)等等,不要認為使用我們的API的用戶都知道什么是正確的、什么是錯的,也就是說一定要考慮到對外接口的出錯處理問題。

10、最高境界、無招勝有招(Stop writing so much code)
意思就是說盡量避免寫太多的代碼,寫的越多,出錯的機會也越多。最好能重用別人開放的接口函數(shù)或直接調(diào)用別人的api。

 

本文來自CSDN博客,轉(zhuǎn)載請標明出處:http://www.shnenglu.com/humanchao/archive/2010/08/05/122334.html

posted @ 2012-04-09 13:36 王海光 閱讀(519) | 評論 (0)編輯 收藏
使用插件:http://nsis.sourceforge.net/NsRandom_plug-in

轉(zhuǎn)自:http://www.dreams8.com/thread-11726-1-1.html
 1 Function Random
 2 Exch $0
 3 Push $1
 4 System::Call 'kernel32::QueryPerformanceCounter(*l.r1)'
 5 System::Int64Op $1 % $0
 6 Pop $0
 7 Pop $1
 8 Exch $0
 9 FunctionEnd
10 
11 Push "100" 
12 Call Random
13 Pop $0


posted @ 2012-04-06 17:13 王海光 閱讀(1335) | 評論 (0)編輯 收藏
 轉(zhuǎn)自:http://www.shnenglu.com/huangyi5209/articles/143171.html
 1 !include MUI.nsh
 2        
 3 Function GetDiskVolumeSerialNumber
 4 !define GetVolumeInformation "Kernel32::GetVolumeInformation(t,t,i,*i,*i,*i,t,i) i"
 5 System::Call '${GetVolumeInformation}("$0",,${NSIS_MAX_STRLEN},.r0,,,,${NSIS_MAX_STRLEN})'
 6 FunctionEnd
 7 
 8 Section
 9 StrCpy $0 "C:\"
10 Call GetDiskVolumeSerialNumber
11 IntFmt $0 "%08X" $0
12 MessageBox MB_OK "$0"
13 SectionEnd


posted @ 2012-04-06 17:10 王海光 閱讀(828) | 評論 (0)編輯 收藏
僅列出標題
共27頁: First 19 20 21 22 23 24 25 26 27 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品激情偷乱一区二区∴| 亚洲第一偷拍| 你懂的一区二区| 久久国产主播| 小处雏高清一区二区三区| 亚洲精品一区二区三区99| 欧美日韩高清免费| 久久综合九色综合欧美就去吻| 亚洲伊人网站| 欧美一区三区三区高中清蜜桃| 亚洲深夜av| 久久国产精品99国产| 欧美在线一级va免费观看| 欧美夜福利tv在线| 性高湖久久久久久久久| 亚洲一区国产视频| 午夜一级久久| 欧美激情综合五月色丁香| 欧美激情第3页| 国产精品入口麻豆原神| 狠狠爱成人网| 99精品国产高清一区二区| 亚洲伦伦在线| 久久久999| 亚洲精品网站在线播放gif| 亚洲综合另类| 欧美日韩成人在线视频| 一区二区视频免费完整版观看| 亚洲美女在线看| 久久综合给合久久狠狠狠97色69| 欧美成人国产一区二区| 亚洲成色www久久网站| 亚洲欧美日本视频在线观看| 美女日韩在线中文字幕| 国户精品久久久久久久久久久不卡| 亚洲二区三区四区| 欧美在线视频一区二区三区| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲国产精品一区| 久久午夜精品| 久久久中精品2020中文| 国产无一区二区| 久久久999| 久久久久久精| 91久久精品国产91性色tv| 欧美成人精品在线视频| 久久久久久久91| 亚洲精品国产精品国自产观看浪潮| 久久av资源网站| 亚洲欧美日产图| 国产一区二区电影在线观看| 欧美一区二区在线视频| 香蕉乱码成人久久天堂爱免费| 国产精品视频福利| 久久久爽爽爽美女图片| 久久一区免费| 欧美一级成年大片在线观看| 亚洲午夜精品视频| 韩国成人精品a∨在线观看| 美女国产精品| 久久艳片www.17c.com| 亚洲精品日韩一| 亚洲一区二区三区免费观看 | 久久久福利视频| 久久精品国产一区二区电影| 亚洲二区视频| 亚洲一区二区三区涩| 亚洲国产欧洲综合997久久| 一区二区不卡在线视频 午夜欧美不卡在| 欧美日韩久久精品| 欧美成人免费在线观看| 欧美午夜国产| 一本久道久久久| 久久综合久久综合这里只有精品| 久久狠狠一本精品综合网| 在线性视频日韩欧美| 久久视频一区| 老巨人导航500精品| 国产三级精品在线不卡| 亚洲午夜在线| 欧美一区二区三区四区视频| 欧美日韩国产一中文字不卡| 亚洲国产成人91精品| 在线观看中文字幕不卡| 久久精品国产亚洲一区二区| 久久精品一区蜜桃臀影院| 国产视频自拍一区| 久久精品视频一| 亚洲成人在线免费| 美女脱光内衣内裤视频久久影院 | 狠狠久久婷婷| 久久亚洲私人国产精品va| 欧美成人网在线| 一区二区三区蜜桃网| 国产农村妇女精品一二区| 免费中文日韩| 一本色道久久综合一区| 亚洲在线视频| 久久精品视频在线播放| 亚洲成人在线免费| 欧美亚洲日本国产| 欧美大片免费观看| 欧美日韩精品伦理作品在线免费观看| 久久久免费精品视频| 亚洲国产高清高潮精品美女| 欧美日韩小视频| 欧美成年人视频网站| 亚洲免费影视| 亚洲视频axxx| 日韩亚洲综合在线| 欧美黄色日本| 久久亚洲精品网站| 久久精品中文| 欧美一区二区视频在线观看| 一区二区国产在线观看| 亚洲精品乱码久久久久久蜜桃91 | 国产精品国产三级国产aⅴ入口| 亚洲在线免费观看| 99成人免费视频| 夜夜嗨av一区二区三区免费区| 欧美国产精品va在线观看| 麻豆av一区二区三区| 欧美二区乱c少妇| 欧美激情亚洲精品| 99精品国产在热久久| 9久re热视频在线精品| 99精品免费视频| 国产精品99久久久久久久女警| 夜夜躁日日躁狠狠久久88av| 国产精品99久久99久久久二8| 日韩一区二区精品在线观看| 亚洲另类一区二区| 亚洲免费影院| 欧美好骚综合网| 国产日韩欧美| 夜夜嗨av一区二区三区网页 | 男女av一区三区二区色多| 毛片基地黄久久久久久天堂| 久久久欧美精品| 日韩视频在线你懂得| 午夜精品久久久久久久久久久久| 久久久精品久久久久| 国产精品美女999| 亚洲人成网站在线播| 欧美中文字幕精品| 亚洲激情欧美激情| 欧美一区二区三区日韩视频| 欧美99久久| 国产日韩在线一区| 夜夜精品视频一区二区| 免费观看成人www动漫视频| 亚洲欧洲精品成人久久奇米网| 国产精品99久久久久久久vr| 久久一区中文字幕| 国产在线观看精品一区二区三区| 亚洲欧洲午夜| 欧美激情一区二区三区不卡| 午夜精品福利在线| 国产视频观看一区| 性欧美精品高清| 久久福利资源站| 怡红院精品视频| 蜜臀久久99精品久久久久久9| 欧美一区久久| 亚洲国产精品久久| 亚洲国产精品一区二区三区| 欧美成人伊人久久综合网| 亚洲美女91| 亚洲制服av| 亚洲国产欧美在线| 一本一道久久综合狠狠老精东影业 | 在线一区日本视频| 欧美视频二区| 久久久亚洲成人| 久久久噜噜噜久久中文字幕色伊伊| 亚洲一区免费网站| 激情六月婷婷综合| 亚洲另类视频| 亚洲大片在线| 一区二区三区日韩在线观看 | 中文欧美字幕免费| 国内一区二区三区在线视频| 亚洲福利视频二区| 国产精品综合不卡av| 最新国产乱人伦偷精品免费网站| 国产精品一区二区久久国产| 欧美成人精品影院| 国产伦精品一区二区三区在线观看 | 欧美大色视频| 欧美中文字幕精品| 国产精品成av人在线视午夜片| 久久久精品国产免大香伊| 欧美日韩亚洲一区二区三区四区 | 亚洲国产高清一区| 国产日韩成人精品| 亚洲调教视频在线观看| 亚洲一区二区在线观看视频| 久久人91精品久久久久久不卡| 亚洲欧美日韩精品久久久| 欧美精品亚洲二区|