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

OldJiang.com

浩毛的博客

OldJiang.com
posts - 14, comments - 81, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

置頂隨筆

Stool - Easily switch VPN server for  Mac 發布

軟件主頁:www.oldjiang.com

主要功能:
1.方便管理大量VPN服務器和賬戶
2.批量檢測VPN服務器速度
3.方便的切換VPN連接,并自動監測VPN連接狀態.
4.支持L2TP和PPTP.
完全免費,歡迎大家使用.
下一步:計劃加入狀態欄支持.

版本 1.0
下載地址: Download

截圖:







posted @ 2014-12-10 12:34 浩毛 閱讀(1650) | 評論 (0)編輯 收藏

2014年12月10日

Stool - Easily switch VPN server for  Mac 發布

軟件主頁:www.oldjiang.com

主要功能:
1.方便管理大量VPN服務器和賬戶
2.批量檢測VPN服務器速度
3.方便的切換VPN連接,并自動監測VPN連接狀態.
4.支持L2TP和PPTP.
完全免費,歡迎大家使用.
下一步:計劃加入狀態欄支持.

版本 1.0
下載地址: Download

截圖:







posted @ 2014-12-10 12:34 浩毛 閱讀(1650) | 評論 (0)編輯 收藏

2011年8月11日

weak table是什么意思,建議不要看中文翻譯的,我以前看了半天還是沒懂啥子意思.

lua 手冊原文是這樣解釋的:
A weak table is a table whose elements are weak references. A weak reference is ignored by the garbage collector. In other words, if the only references to an object are weak references, then the garbage collector will collect this object.
A weak table can have weak keys, weak values, or both. A table with weak keys allows the collection of its keys, but prevents the collection of its values. A table with both weak keys and weak values allows the collection of both keys and values. In any case, if either the key or the value is collected, the whole pair is removed from the table. The weakness of a table is controlled by the __mode field of its metatable. If the __mode field is a string containing the character 'k', the keys in the table are weak. If __mode contains 'v', the values in the table are weak.
After you use a table as a metatable, you should not change the value of its __mode field. Otherwise, the weak behavior of the tables controlled by this metatable is undefined.

在lua中,像table,userdata,function這些類型的值都是引用傳遞,通過引用計數來判斷是否收掉對象,而弱引用(weak reference)會被垃圾回收器忽略.weak table就是它的元素是弱引用的,一個元素(鍵值對)可能鍵是弱引用,也可能值是弱引用的,也可能都是弱引用, 這個特性是通過弱表的metatable的__mode的值來設置的,特別有意思的是,當弱表中一個鍵值對,它的鍵或值關聯(引用/指向)的那個對象被垃圾回收器回收的時候,這個鍵值對會從弱表中被自動刪除掉.這是個很重要的特點.

那么弱表到底有什么用呢? 在lua的wiki中有一篇使用userdata的例子 ,其中就很巧妙的用到了弱表,原文地址 http://lua-users.org/wiki/CppBindingWithLunar
這篇文章介紹了如何通過userdata綁定c++對象到腳本中
fulluserdata能夠設置metatable,也就能模擬出對象的效果出來,對一個C++的類的對象實例來說,push到腳本中,一般是創建了一個userdata,文章中用弱表避免了同一個對象實例(指針) push到腳本中,多次創建userdata的問題.
換句話來說,如果C++對象的生存周期是靠lua的垃圾回收來控制的話(userdata被回收時,調用元表的__gc方法,__gc方法中析構c++對象),一個C++對象只能有一個唯一的userdata. 在userdata的metatable中創建一個值是弱引用的弱表,用C++對象指針做鍵,每次push c++對象的時候,就去用指針值查弱表,如果有,就push那個userdata,沒有就創建,  同時,當userdata是被弱引用的,當被垃圾回收掉的時候,弱表中它所在的鍵值對自動被銷毀了. 



posted @ 2011-08-11 14:33 浩毛 閱讀(7063) | 評論 (0)編輯 收藏

最近做了個DEMO,飛機追飛機的.
利用AOI模塊產生的enterAOI,LeaveAOI事件 觸發NPC追隨玩家

順便也測試下服務器實體的歐拉角計算


先運行RegionApp.exe
然后再運行ClientDemo

WSAD 前后左右 J上K下

客戶端做的很簡單..., 支持多開...

下載DEMO

posted @ 2011-08-11 11:22 浩毛 閱讀(2997) | 評論 (0)編輯 收藏

2011年6月20日

最近在優化游戲服務器的AOI(area of interest)部分,位置有關的游戲實體一般都有一個視野或關心的范圍,
當其他實體進出某個實體的這個范圍的時候,就會觸發leaveAOI或enterAOI事件,并維護一份AOI 實體列表。
我們來考慮最簡單的實現,假設區域R中有1000個Entity,當某個entity位置發生變化時,需要計算entity的AOI事件和列表,偽代碼如下:

function onEntityMove(who)   
  for entity in entities do
    if who <> entity then
        計算who和entity之間的距離
        如果who移動前entity在who的AOI范圍內,且現在在范圍外
           觸發who.onLeaveAOI(entity)
        如果who移動前entity在who的AOI范圍外,且現在在范圍內
           觸發who.onEnterAOI(entity) 
         如果who移動前在 entity的AOI范圍內,且現在在范圍外  
          觸發entity.onLeaveAOI(who)
          如果who移動前在 entity的AOI范圍外,且現在在 范圍內
           觸發entity.onEntityAOI(who)
      end
  end
end
每次一個實體移動一次位置就要遍歷1000個實體來計算,這 樣做顯然不行,效率太低了,
那么就需要引入場景管理,將區域R分成n個格子,每個格子維護一個實體鏈表,entity移動時,只遍歷它所在的格子和周圍的8個格子的實體鏈表,
再優化下,可以加入AOI圓和格子的碰撞檢查,9個格子中再去掉沒有相交的格子。。。等等
也有用四叉樹來進行場景管理的。

還有些方案更簡單,直接是畫格子,按以實體為中心的九個格子進行位置廣播, 實體從一個格子移動到另外的格子時觸發事體。。好處是計算量簡單,缺點是帶寬占用大

我上面的方案都試過了,效率和帶寬占用都不理想,最近終于弄出一個新的方案,現在的AOI計算量是我們服務器以前計算量的1/40-1/80,由于涉及到公司的保密制度,不便細說,上幾個測試的抓圖:

機器配置:win7 ,T5870 inter雙核2G,2G內存
20個entity 隨機運動計算一次所有entity AOI的時間在0.02毫秒左右:

220個實體,選擇的實體AOI范圍里有68個實體:

4000個實體,選擇的實體的AOI區域里有465個實體

AOIDemo.exe 下載

posted @ 2011-06-20 01:25 浩毛 閱讀(18139) | 評論 (23)編輯 收藏

2010年12月29日

SOA:Service-oriented architecture
最近在做游戲服務器引擎,查了不少有關SOA的設計方面的資料。發現JAVA世界有相當多的技術標準。
其中比較好的是OSGi (http://www.osgi.org/About/WhatIsOSGi),OSGi技術是面向Java的動態模型系統。OSGi服務平臺向Java提供服務,這些服務使Java成為軟件集成和軟件開發的首選環境。Java提供在多個平臺支持產品的可移植性。OSGi技術提供允許應用程序使用精煉、可重用和可協作的組件構建的標準化原語。這些組件能夠組裝進一個應用和部署中。
參考它的思路,結合C++語言的特點,我將一個服務器基礎框架設計成了這樣一種:

一個服務器應用,由多個組件組成,組件物理上可以是動態庫,也可以是EXE里一段實際的代碼,每個組件可以向ApplicationFramework注冊多個服務(比如日志服務,網絡服務等)。
ApplicationFramework啟動時,通過配置文件,動態加載和啟動組件,讀取服務的可配置屬性。Framework觸發IComponentActivator的OnStart() 和OnStop()事件,在Start事件中,可以注冊組件自己的服務,也可以加入一個服務監聽器來監聽關心的服務的注冊,注銷等事件。
我隨便畫了幾個大概的接口:
  

posted @ 2010-12-29 00:31 浩毛 閱讀(2775) | 評論 (1)編輯 收藏

2010年10月15日

替換^M字符
在Linux下使用vi來查看一些在Windows下創建的文本文件,有時會發現在行尾有一些“^M”。有幾種方法可以處理。

1.使用dos2unix命令。一般的分發版本中都帶有這個小工具(如果沒有可以根據下面的連接去下載),使用起來很方便:
$ dos2unix myfile.txt
上面的命令會去掉行尾的^M。

2.使用vi的替換功能。啟動vi,進入命令模式,輸入以下命令:
:%s/^M$//g # 去掉行尾的^M。

:%s/^M//g # 去掉所有的^M。

:%s/^M/[ctrl-v]+[enter]/g # 將^M替換成回車。

:%s/^M/\r/g # 將^M替換成回車。

3.使用sed命令。和vi的用法相似:
$ sed -e ‘s/^M/\n/g’ myfile.txt

注意:這里的“^M”要使用“CTRL-V CTRL-M”生成,而不是直接鍵入“^M”。

轉自:http://hi.baidu.com/mofeis/blog/item/23c7b2fb92dc97234e4aea6d.html

posted @ 2010-10-15 11:28 浩毛 閱讀(2474) | 評論 (0)編輯 收藏

2010年8月30日

    在游戲服務器中,處理玩家登陸需要向數據庫查詢玩家的賬號和密碼,玩家上線和下線需要對玩家的角色數據從數據庫中讀取和保存。可以說,相對于游戲邏輯處理來說,數據庫操作是一種相對很慢的操作,即便你通過使用多個線程多個數據庫連接來提高數據庫操作的處理能力,但是,在高并發高負載的服務器應用中,這樣仍然會是相當的負載瓶頸。設想這樣一種設計方案,見下圖:

    在大量玩家登陸游戲服務器時,由于有大量的數據庫訪問請求,即便是有自己實現的CACHE機制,還是會導致服務器耗盡所有的邏輯線程資源,服務器的處理能力將降低成DBMS的處理能力。
    
     為了不阻塞邏輯線程,可以采用異步數據庫訪問的方式,即數據庫操作請求提交給專門的數據庫處理線程池,然后邏輯線程不再等待數據庫處理結果,繼續處理其他,不再阻塞在這里。
     抽象的來看,對于一個需要持久化的游戲對象來說,可以考慮它有2個方法,讀取和保存。那么我們抽象一個DBO接口:
   

struct IDbo
{
    
virtual bool SaveToDB(DB*)=0;
    
virtual bool LoadFromDB(DB*)=0;
}
;
   
     然后把設計方案改成下面這種:

 

     改成數據庫異步處理后,在想想現在的游戲數據的保存機制應該是怎樣改進的,為了保障數據安全,我們希望不只是玩家下線的時候才會保存玩家數據,而是希望每隔一段時間統一保存所有在線玩家的數據,那么,可以考慮這樣的思路:假設我們有一個GAMEDB服務器,GAMEDB緩存了所有在線玩家的角色數據,每到保存時間,GAMEDB就將所有在線玩家的數據(DBO)的副本都統一提交給DB線程池,讓它保存數據,提交的過程很快,提交完后,GAMEDB的邏輯線程仍能繼續處理游戲服務器的更新和讀取CACHE的請求。為什么要保存副本呢,DB線程的執行保存隊列的過程也許很耗時,但是隊列中的數據都是GAMEDB提交DBO那個時刻的數據,這樣就能保證玩家的游戲數據的完整性。
      當然,我這里提的這只是個思路,這里面還有很多細節沒有討論,例如如果DB線程池正在保存九點鐘時刻保存的數據,到了十點鐘新的保存時刻時,DB線程池還沒保存完九點鐘時刻的DBO副本隊列,這時應該怎么處理;DBO對象的劃分粒度的問題;DBO隊列的優先級的問題等等。

     PS:這篇文章里的架構其實就是一個GAMEDB服務器,里面的邏輯處理就是GAMEDB的邏輯處理。你可以把這篇文章理解成:一個GAMEDB服務器 的實現思路。。。

posted @ 2010-08-30 11:35 浩毛 閱讀(8557) | 評論 (12)編輯 收藏

2010年7月29日

編輯~/.vimrc 加入以下代碼

 1 autocmd BufNewFile *.[ch],*.hpp,*.cpp exec ":call SetTitle()" 
 2 
 3 "加入注釋
 4 func SetComment()
 5     call setline(1,"/*==============================================================="
 6     call append(line("."),   "*   Copyright (C) ".strftime("%Y")." All rights reserved.")
 7     call append(line(".")+1"*   "
 8     call append(line(".")+2"*   文件名稱:".expand("%:t")) 
 9     call append(line(".")+3"*   創 建 者:蔣浩")
10     call append(line(".")+4"*   創建日期:".strftime("%Y年%m月%d日")) 
11     call append(line(".")+5"*   描    述:"
12     call append(line(".")+6"*")
13     call append(line(".")+7"*   更新日志:"
14     call append(line(".")+8"*"
15     call append(line(".")+9"================================================================*/"
16 endfunc
17 
18 "定義函數SetTitle,自動插入文件頭 
19 func SetTitle()
20     call SetComment()
21     if expand("%:e"== 'hpp' 
22  call append(line(".")+10"#ifndef _".toupper(expand("%:t:r"))."_H"
23  call append(line(".")+11"#define _".toupper(expand("%:t:r"))."_H"
24  call append(line(".")+12"#ifdef __cplusplus"
25  call append(line(".")+13"extern \"C\""
26  call append(line(".")+14"{"
27  call append(line(".")+15"#endif"
28  call append(line(".")+16""
29  call append(line(".")+17"#ifdef __cplusplus"
30  call append(line(".")+18"}"
31  call append(line(".")+19"#endif"
32  call append(line(".")+20"#endif //".toupper(expand("%:t:r"))."_H"
33     elseif expand("%:e"== 'h' 
34  call append(line(".")+10"#pragma once"
35     elseif &filetype == 'c' 
36  call append(line(".")+10,"#include \"".expand("%:t:r").".h\""
37     elseif &filetype == 'cpp' 
38  call append(line(".")+10"#include \"".expand("%:t:r").".h\""
39     endif
40 endfunc
41 


 

posted @ 2010-07-29 12:26 浩毛 閱讀(7761) | 評論 (1)編輯 收藏

2010年7月6日

一個典型的游戲服務器設計中,一般都是用的多線程,服務器中一般運行兩類線程,N個SOCKET IO線程,1個邏輯線程,
IO線程接受客戶端發來的信息,通過消息隊列發送給邏輯線程處理后,再發送消息給客戶端,發送消息這里一般是IO線程處理實際發送。

其實我認為,如果邏輯線程都是消耗的CPU運算資源的話,服務器完全采用單線程的方式來做。

首先,我們看IO處理,基本就是數據入隊、出隊,send、recv操作,作為服務器的SOCKET處理一般都是異步SOCKET,也就是說,send、recv操作只是將信息copy到socket底層的發送接收緩沖區去了,不存在IO堵塞的問題。

然后,我們再來看邏輯處理,前面已經說了,采用單線程的前提是邏輯處理只是消耗CPU運算資源,那么,不管你開幾個線程,對單核的CPU來說,它的處理速度就是這么多,并不會因為你線程開的越多,就處理的越快。

因此我們可不可以這樣說呢,在單核機器上,只消耗CPU運算的服務,多線程并不比單線程能提高多少效率。

接下來,我們再討論下多核的情況,你肯定要想,我這臺服務器是4個雙核CPU,就只跑一個單線程的服務器不是虧死了,多線程多好,我開8個線程,就能很好的利用我的機器啦。是啊,我也覺得這樣很好,不過在LINUX、UNIX下,對線程的支持并不像WINDOWS下那么好,LINUX、UNIX下一般都是用LWP(輕量級進程)的方式來支持多線程程序的,Linux內核只提供了輕量進程的支持,限制了更高效的線程模型的實現,但Linux著重優化了進程的調度開銷,一定程度上也彌補了這一缺陷。同時,濫用多線程也會造成不必要的上下文切換,不必要的同步機制的引入(如pthread_mutex),讓程序頻繁的在內核和用戶間頻繁切換。另外,從開發角度來看,單線程開發比多線程環境開發更不容易出錯和更加健壯。

在游戲服務器架構中,為了提高玩家在線人數,實現負載均衡,現在一般都是采用分布式的多進程服務器集群的方式,我們來看看服務器集群中,每個服務進程是采用多線程的方式還是單線程的方式好呢?我覺得,對于有慢速IO訪問的需求的應用進程,多線程肯定比單線程好,最典型的情況就是數據庫訪問這塊,完全可以采用N個DB線程,一個邏輯線程的架構,而對只是消耗CPU運算資源的應用進程,盡量單線程就行了,如果覺得單線程負載不行的話,完全可以分成多個進程來跑。。

以上只是我自己的一些看法,表達有限,歡迎指正。。。

posted @ 2010-07-06 00:06 浩毛 閱讀(9816) | 評論 (13)編輯 收藏

2010年7月5日

    boost里的program_options提供程序員一種方便的命令行和配置文件進行程序選項設置的方法。
    其文檔例子中有如下代碼:
   
1 using namespace boost::program_options;
2 //聲明需要的選項
3 options_description desc("Allowed options");
4 desc.add_options()
5         ("help,h""produce help message")
6         ("person,p", value<string>()->default_value("world"), "who");

    看第4到6行,是不是感覺很怪?這種方式體現了函數式編程中最大的特點:函數是一類值,引用資料來說,所謂“函數是一類值(First Class Value)”指的是函數和值是同等的概念,一個函數可以作為另外一個函數的參數,也可以作為值使用。如果函數可以作為一類值使用,那么我們就可以寫出一些函數,使得這些函數接受其它函數作為參數并返回另外一個函數。比如定義了f和g兩個函數,用compose(f,g)的風格就可以生成另外一個函數,使得這個函數執行f(g(x))的操作,則可稱compose為高階函數(Higher-order Function)。

    program_options里的這種方式是怎么實現的呢?通過分析boost的源代碼,我們自己來寫個類似的實現看看:
     test.h   
 1 #pragma once
 2 
 3 #include <iostream>
 4 using namespace std;
 5 
 6 class Test;
 7 
 8 class Test_easy_init
 9 {
10 public:
11     Test_easy_init(Test* owner):m_owner(owner){}
12 
13     Test_easy_init & operator () (const char* name);
14     Test_easy_init & operator () (const char* name,int id);
15 private:
16     Test* m_owner;
17 };
18 
19 
20 class Test
21 {
22 public:
23     void add(const char* name);
24     void add(const char* name,int id);
25 
26     Test_easy_init add_some();
27 
28 };

test.cpp
 1 #include "test.h"
 2 
 3 Test_easy_init & Test_easy_init::operator () (const char* name,int id)
 4 {
 5 
 6     m_owner->add(name,id);
 7     return *this;
 8 }
 9 
10 
11 Test_easy_init & Test_easy_init::operator () (const char* name)
12 {
13 
14     m_owner->add(name);
15     return *this;
16 }
17 
18 Test_easy_init Test::add_some()
19 {
20     return Test_easy_init(this);
21 }
22 
23 
24 void Test::add(const char* name)
25 {
26     cout<<"add:"<<name<<endl;
27 }
28 
29 void Test::add(const char* name,int id)
30 {
31     cout<<"add:"<<name<<"-"<<id<<endl;
32 }

使用方式:
1 Test t1;
2 
3 t1.add_some()
4     ("hello",1)
5     ("no id")
6     ("hello2",2);

是不是很有意思。add_some()方法返回一個Test_easy_init類的對象,Test_easy_init類重載了操作符(),操作符()方法返回Test_easy_init類對象自身的引用。。

posted @ 2010-07-05 23:08 浩毛 閱讀(1835) | 評論 (2)編輯 收藏

OldJiang.com
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美在线黄色| 午夜性色一区二区三区免费视频| 模特精品裸拍一区| 久久久久久亚洲精品中文字幕| 午夜在线观看免费一区| 亚洲欧美三级伦理| 久久成人综合网| 久久久欧美一区二区| 美女精品在线| 欧美日韩国产三区| 国产麻豆精品theporn| 好看的av在线不卡观看| 亚洲精品社区| 欧美在线观看视频一区二区| 久久综合久久综合这里只有精品| 欧美不卡在线| 亚洲无线一线二线三线区别av| 小嫩嫩精品导航| 欧美二区在线播放| 国产麻豆一精品一av一免费| 亚洲国产精品va在线看黑人| 亚洲综合首页| 欧美不卡一区| 午夜精品久久久久久久99热浪潮 | 欧美一区二区免费观在线| 久久免费视频网站| 欧美性猛片xxxx免费看久爱| 加勒比av一区二区| 亚洲特色特黄| 欧美成人精品影院| 亚洲欧美日韩中文视频| 欧美极品aⅴ影院| 国产自产在线视频一区| 这里是久久伊人| 欧美aⅴ一区二区三区视频| 99国产精品| 午夜一区二区三视频在线观看 | 欧美激情免费在线| 国产日韩精品入口| 在线视频日韩| 欧美激情四色 | 国产日韩欧美综合精品| 99av国产精品欲麻豆| 久久免费偷拍视频| 在线亚洲激情| 欧美日韩成人在线视频| 亚洲国产日韩欧美在线动漫| 久久久久久久久久久久久女国产乱 | 免费一级欧美片在线播放| 久久免费视频网站| 国产亚洲va综合人人澡精品| 亚洲一区二区3| 亚洲美女av网站| 欧美精品成人| 日韩午夜在线电影| 欧美国产乱视频| 久久久久久久久久久久久女国产乱 | 久久精品国产亚洲5555| 欧美大秀在线观看| 久久手机免费观看| 一区二区三区在线免费观看| 久久国产精品久久久久久| 亚洲婷婷综合久久一本伊一区| 欧美日韩一区二区免费在线观看| 日韩小视频在线观看| 亚洲人体大胆视频| 久久成人综合网| 在线欧美日韩精品| 亚洲大片在线观看| 欧美日韩www| 亚洲一区日韩| 亚洲欧美在线磁力| 好看的亚洲午夜视频在线| 欧美国产亚洲另类动漫| 欧美精品大片| 性一交一乱一区二区洋洋av| 欧美一区二区三区的| 亚洲国产三级网| 欧美11—12娇小xxxx| 韩国成人福利片在线播放| 美日韩精品视频| 欧美xx视频| 亚洲综合日韩在线| 久久精品国产第一区二区三区| 1024成人网色www| 亚洲人成久久| 国产日韩精品一区二区三区在线 | 久久久久国色av免费看影院 | 国产一区二区三区四区在线观看| 久久一区二区视频| 欧美激情第4页| 欧美中文字幕视频在线观看| 久久亚洲春色中文字幕| 亚洲私人影院| 久久久久久久精| 亚洲综合视频网| 欧美成人精品一区| 久久精品国产99| 欧美日韩国产一区二区三区| 久久久久久久波多野高潮日日| 欧美日韩国产精品一区二区亚洲 | 亚洲自拍电影| 91久久精品国产91久久性色tv| 亚洲色诱最新| 最新国产の精品合集bt伙计| 亚洲欧美精品| 99亚洲伊人久久精品影院红桃| 欧美自拍偷拍| 午夜精品一区二区三区在线| 女女同性精品视频| 久久久久久亚洲综合影院红桃| 欧美剧在线免费观看网站| 久久综合狠狠综合久久综青草| 国产精品wwwwww| 亚洲黄一区二区三区| 精品成人a区在线观看| 亚洲伊人色欲综合网| 99国产精品一区| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美在线一区二区| 欧美性大战久久久久| 最新高清无码专区| 亚洲国产精品久久久久秋霞蜜臀| 亚洲欧美日韩第一区| 亚洲一区二区三区免费观看| 欧美激情视频免费观看| 亚洲成人在线网| 亚洲电影在线播放| 久久精品视频免费播放| 久久久久国色av免费看影院| 国产一区二区三区在线观看网站 | 午夜视频久久久久久| 亚洲天堂视频在线观看| 欧美国产日韩亚洲一区| 亚洲国产精品99久久久久久久久| 亚洲卡通欧美制服中文| 国产一区二区主播在线| 亚洲一区二区三区免费视频| 亚洲在线视频| 国产精品欧美精品| 亚洲午夜一区二区| 亚洲欧美变态国产另类| 国产精品日韩欧美综合| 欧美一级二区| 免费成人高清| 亚洲美女毛片| 欧美三级黄美女| 亚洲欧美另类中文字幕| 欧美综合激情网| 狠狠综合久久| 欧美大胆成人| 亚洲视频欧洲视频| 久久九九全国免费精品观看| 国产一区在线视频| 美国十次了思思久久精品导航| 亚洲国产精品一区| 亚洲特黄一级片| 国内外成人在线视频| 欧美国产日韩xxxxx| 一本色道久久加勒比88综合| 欧美与欧洲交xxxx免费观看 | 狠狠爱www人成狠狠爱综合网| 欧美在线首页| 亚洲高清视频一区| 午夜精品www| 亚洲国产精品国自产拍av秋霞| 欧美视频观看一区| 久久久久.com| 99精品欧美一区二区蜜桃免费| 欧美在线一级视频| 99在线精品免费视频九九视| 国产亚洲激情在线| 欧美日产一区二区三区在线观看| 午夜精品久久久久久久99热浪潮 | 久久久人成影片一区二区三区观看| 欧美黄色大片网站| 性欧美超级视频| 亚洲日本中文字幕免费在线不卡| 国产精品久久久久av| 蜜桃av一区二区在线观看| 亚洲性视频h| 亚洲精品国产精品国自产在线 | 亚洲视频导航| 欧美成人精品在线| 欧美怡红院视频一区二区三区| 99在线观看免费视频精品观看| 黄色一区二区在线观看| 国产精品久久波多野结衣| 女人色偷偷aa久久天堂| 久久经典综合| 午夜精品美女久久久久av福利| 亚洲精品小视频| 欧美1区3d| 久久精品99| 欧美一区二区三区男人的天堂| 国产精品99久久不卡二区| 亚洲日韩中文字幕在线播放| 黄色av一区| 国产情侣久久| 国产日韩av一区二区|