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

面對現(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://m.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://m.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://m.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://m.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://m.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://m.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视频精品免费观看| 一区二区三区在线视频播放| 在线日韩日本国产亚洲| 亚洲区中文字幕| 日韩一级不卡| 亚洲欧美精品suv| 欧美在线视频免费观看| 久久激情视频| 亚洲第一狼人社区| 亚洲第一成人在线| 99在线观看免费视频精品观看| 亚洲精品中文字幕女同| 亚洲免费视频一区二区| 久久久在线视频| 欧美日韩天堂| 国产亚洲一区二区在线观看| 亚洲国产欧美久久| 亚洲免费视频观看| 蜜桃久久av一区| 亚洲人成小说网站色在线| 亚洲一区二区在线播放| 久久精品一区二区三区中文字幕| 欧美黄色一区二区| 国产日韩欧美一区在线| 日韩一级在线| 久久免费视频网| 夜夜夜精品看看| 久久久久久国产精品mv| 欧美精品一区三区| 黄色一区二区在线观看| 亚洲免费在线电影| 亚洲国产日韩一区二区| 一区二区欧美日韩视频| 午夜精品久久久久久久白皮肤| 久久亚洲色图| 亚洲伊人一本大道中文字幕| 欧美粗暴jizz性欧美20| 国产亚洲欧美日韩一区二区| 亚洲天天影视| 亚洲国产精品视频| 久久久爽爽爽美女图片| 国产视频一区欧美| 亚洲在线不卡| 日韩视频一区二区| 毛片av中文字幕一区二区| 国产亚洲福利社区一区| 亚洲特黄一级片| 亚洲国产一区二区在线| 久久精品夜色噜噜亚洲aⅴ| 国产精品日本| 午夜天堂精品久久久久| 在线综合亚洲欧美在线视频| 欧美精品一区二区精品网 | 久久精品国产精品亚洲精品| 国产精品麻豆va在线播放| 99精品视频一区| 欧美激情一区二区三区在线视频| 校园激情久久| 国产亚洲精品aa| 久久精品国产一区二区电影| 亚洲免费在线| 国产日韩综合一区二区性色av| 亚洲欧美在线免费| 亚洲免费人成在线视频观看| 国产日韩精品久久久| 欧美在线视频全部完| 久久av最新网址| 狠狠网亚洲精品| 欧美91精品| 欧美精品一区二区三| 亚洲午夜精品国产| 制服丝袜激情欧洲亚洲| 国产精品久久久久永久免费观看| 亚洲免费影视| 久久成人精品| 亚洲国产婷婷综合在线精品| 欧美黄色免费网站| 欧美日韩在线播放一区二区| 亚洲一区在线播放| 羞羞色国产精品| 亚洲国产精品一区二区久| 亚洲二区三区四区| 国产精品电影观看| 久久人人爽爽爽人久久久| 老司机一区二区| 一区二区三区四区精品| 亚洲欧美日韩国产一区二区| 红桃视频亚洲| 亚洲人成在线观看一区二区| 国产精品青草久久| 牛牛影视久久网| 日韩一级欧洲| 国产精品午夜在线| 美日韩精品视频| 狠狠入ady亚洲精品经典电影| 亚洲精品一级| 亚洲美女视频在线观看| 久久久欧美一区二区| 久久综合综合久久综合| 国产区精品视频| 久久国产主播精品| 一区二区三区.www| 亚洲高清网站| 亚洲精选一区二区| 国产亚洲欧洲| 9久re热视频在线精品| 国产一本一道久久香蕉| 亚洲精品美女| 精品99视频| 亚洲一区二区三区精品动漫| 亚洲丰满少妇videoshd| 亚洲一区在线播放| 亚洲日本成人| 久久婷婷国产麻豆91天堂| 午夜精品视频在线| 欧美劲爆第一页| 另类欧美日韩国产在线| 国产精品欧美久久| 99re6这里只有精品| 91久久精品日日躁夜夜躁欧美 | 国产精品普通话对白| 最近中文字幕日韩精品| 在线欧美不卡| 久久久国产精品亚洲一区 | 激情文学一区| 亚洲在线视频一区| 亚洲永久网站| 欧美啪啪一区| 亚洲欧洲一区二区三区在线观看 | 久久手机精品视频| 欧美资源在线| 国产亚洲毛片在线| 香蕉久久精品日日躁夜夜躁| 中文国产亚洲喷潮| 欧美日韩一区在线视频| 一本色道久久88综合日韩精品| 99精品久久| 国产精品va在线播放我和闺蜜| 亚洲肉体裸体xxxx137| 日韩视频在线你懂得| 欧美日韩国产123区| 久久久久久97三级| 欧美欧美全黄| 亚洲国产高清自拍| 亚洲人体影院| 欧美日韩高清在线| 亚洲免费观看高清完整版在线观看| 亚洲精品乱码久久久久久久久 | 国产午夜精品视频免费不卡69堂| 亚洲性线免费观看视频成熟| 亚洲午夜成aⅴ人片| 国产精品区一区二区三| 性欧美精品高清| 免费看的黄色欧美网站| 亚洲精品在线观看免费| 欧美日韩综合在线免费观看| 在线一区二区三区四区五区| 午夜精品久久久久久久99热浪潮| 国产日韩欧美综合精品| 欧美制服丝袜第一页| 欧美成人精品在线观看| 一本一本久久| 国产视频一区欧美| 欧美电影美腿模特1979在线看| 99re亚洲国产精品| 久久精视频免费在线久久完整在线看| 激情综合电影网| 欧美高清视频一区| 亚洲天堂视频在线观看| 麻豆成人综合网| 中文高清一区| 在线观看欧美成人| 欧美色欧美亚洲高清在线视频| 亚洲在线一区| 亚洲福利视频三区| 欧美一站二站| 亚洲三级视频在线观看| 国产欧美一区二区三区另类精品| 久久一本综合频道| 亚洲永久免费| 最新国产成人在线观看| 久久久欧美精品| 亚洲综合日韩在线| 亚洲国产欧美一区| 国产精品一区三区| 欧美日本一道本| 另类春色校园亚洲| 亚洲欧美乱综合| 一本色道久久综合亚洲精品高清 | 美腿丝袜亚洲色图| 亚洲男同1069视频| 亚洲精品午夜精品| 国模一区二区三区| 国产精品美女午夜av| 欧美精品在欧美一区二区少妇| 久久精品99| 午夜性色一区二区三区免费视频| 亚洲卡通欧美制服中文|