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

C++ Programmer's Cookbook

{C++ 基礎} {C++ 高級} {C#界面,C++核心算法} {設計模式} {C#基礎}

windows核心編程--作業

作業: 作業可以看作是一組進程的容器,把這些進程當作一個整體,對這個整體整個加入更多的限制.
         
          因為Wi n d o w s并不維護進程之間的父/子關系。即使父進程已經終止運行,子進程仍然會繼續運行。Microsoft Windoss 2000提供了一個新的作業內核對象,使你能夠將進程組合在一起,并且創建一個“沙框”,以便限制進程能夠進行的操作。最好將作業對象視為一個進程的容器。但是,創建包含單個進程的作業是有用的,因為這樣一來,就可以對該進程加上通常情況下不能加的限制。


創建一個新作業內核對象:
HANDLE CreateJobObject( PSECURITY_ATTRIBUTES psa, PCTSTR pszName);

與所有的內核對象一樣,它的第一個參數將安全信息與新作業對象關聯起來,并且告訴系統,是否想要使返回的句柄成為可繼承的句柄。最后一個參數用于給作業對象命名,使它可以供另一個進程通過下面所示的O p e n J o b O b j e c t函數進行訪問。

HANDLE OpenJobObject( DWORD dwDesiredAccess,
   BOOL bInheritHandle, PCTSTR pszName);
與平常一樣,如果知道你將不再需要訪問代碼中的作業對象,那么就必須通過調用C l o s e H a n d l e來關閉它的句柄。

應該知道,關閉作業對象并不會迫使作業中的所有進程終止運行。該作業對象實際上做上了刪除標記,只有當作業中的所有進程全部終止運行之后,該作業對象才被自動撤消。
注意,關閉作業的句柄后,盡管該作業仍然存在,但是該作業將無法被所有進程訪問。


將一個進程放入一個作業,以限制該進程進行某些操作的能力。 Windows 98 Windows 98不支持作業的操作。
void StartRestrictedProcess()
{
   //Create a job kernel object.
   HANDLE hjob = CreateJobObject(NULL, NULL);

   //Place some restrictions on processes in the job.
   //First,set some basic restrictions.
   JOBOBJECT_BASIC_LIMIT_INFORMATION jobli = { 0 };

   //The process always runs in the idle priority class.
   jobli.PriorityClass = IDLE_PRIORITY_CLASS;

   //The job cannot use more than 1 second of CPU time.
   jobli.PerJobUserTimeLimit.QuadPart = 10000000; 
   //1 sec in 100-ns intervals

   //These are the only 2 restrictions I want placed on the job (process).
   jobli.LimitFlags = JOB_OBJECT_LIMIT_PRIORITY_CLASS |
      JOB_OBJECT_LIMIT_JOB_TIME;
     
   SetInformationJobObject(hjob,
      JobObjectBasicLimitInformation,
      &jobli, sizeof(jobli));

   //Second, set some UI restrictions.
   JOBOBJECT_BASIC_UI_RESTRICTIONS jobuir;
   jobuir.UIRestrictionsClass = JOB_OBJECT_UILIMIT_NONE;    
   //A fancy zero

   //The process can't log off the system.
   jobuir.UIRestrictionsClass |= JOB_OBJECT_UILIMIT_EXITWINDOWS;

   //The process can't access USER objects
   //(such as other windows) in the system.
   jobuir.UIRestrictionsClass |= JOB_OBJECT_UILIMIT_HANDLES;

   SetInformationJobObject(hjob,JobObjectBasicUIRestrictions,
      &jobuir, sizeof(jobuir));

   //Spawn the process that is to be in the job.
   //Note: You must first spawn the process and then place the process in
   //the job. This means that the process's thread must be initially
   //suspended so that it can't execute any code outside
   //of the job's restrictions.

   STARTUPINFO si = { sizeof(si) };
   PROCESS_INFORMATION pi;
   CreateProcess(NULL, "CMD", NULL, NULL, FALSE,
      CREATE_SUSPENDED, NULL, NULL, &si, π);
   //Place the process in the job.
   //Note:if this process spawns any children,the children are
   //automatically part of the same job.
   AssignProcessToJobObject(hjob,pi.hProcess);

   //Now we can allow the child process's thread to execute code.
   ResumeThread(pi.hThread);
   CloseHandle(pi.hThread);

   //Wait for the process to terminate or for all the job's
   //allotted CPU time to be used.
   HANDLE h[2];
   h[0] = pi.hProcess;
   h[1] = hjob;
   DWORD dw = WaitForMultipleObjects(2,h,FALSE,INFINITE);
   switch( dw-WAIT_OBJECT_0 )
   {
     case 0:
        //The process has terminated
        break;
     case 1:
        //All of the job's allotted CPU time was used
        break;
    }

    //Clean up properly.
    CloseHandle(pi.hProcess);
    CloseHandle(hjob);
}


對作業進程的限制
進程創建后,通常需要設置一個沙框(設置一些限制),以便限制作業中的進程能夠進行的操作。可以給一個作業加上若干不同類型的限制:

• 基本限制和擴展基本限制,用于防止作業中的進程壟斷系統的資源。

• 基本的U I限制,用于防止作業中的進程改變用戶界面。

• 安全性限制,用于防止作業中的進程訪問保密資源(文件、注冊表子關鍵字等)。

通過調用下面的代碼,可以給作業加上各種限制:

 

BOOL SetInformationJobObject(
HANDLE hJob,
JOBOBJECTINFOCLASS JobObjectInformationClass,
PVOID pJobObjectInformation,
DWORD cbJobObjectInformationLength);
第一個參數用于標識要限制的作業。第二個參數是個枚舉類型,用于指明要使用的限制類型。第三個參數是包含限制設置值的數據結構的地址,第四個參數用于指明該結構的大小(用于確定版本)。

可以做的限制有:(具體參數的意思參看windows核心編程)
JOB_OBJECT_BASIC_LIMIT_INFORMATION結構類似下面的樣子: (基本限制)

typedef struct _JOBOBJECT_BASIC_LIMIT_INFORMATION{    LARGE_INTEGER  PerProcessUserTimeLimit;    LARGE_INTEGER  PerJobUserTimeLimit;    DWORD          LimitFlags;    DWORD          MinimumWorkingSetSize;    DWORD          MaximumWorkingSetSize;    DWORD          ActiveProcessLimit;    DWORD_PTR      Affinity;    DWORD          PriorityClass;    DWORD          SchedulingClass;} JOBOBJECT_BASIC_LIMIT_INFORMATION,  *PJOBOBJECT_BASIC_LIMIT_INFORMATION;

J O B O B J E C T _ E X T E N D E D _ L I M I T _ I N F O R M AT I O N結構對作業設置: (擴展限制)
typedef struct _JOBOBJECT_EXTENDED_LIMIT_INFORMATION
{
    JOBOBJECT_BASIC_LIMIT_INFORMATION   BasicLimitInformation;
    IO_COUNTERS                         oInfo;
    SIZE_T                              ProcessMemoryLimit;
    SIZE_T                              JobMemoryLimit;
    SIZE_T                              PeakProcessMemoryUsed;
    SIZE_T                              PeakJobMemoryUsed;
} JOBOBJECT_EXTENDED_LIMIT_INFORMATION,  *PJOBOBJECT_EXTENDED_LIMIT_INFORMATION;

J O B O B J E C T _ B A S I C _ U I _ R E S T R I C T I O NS結構的樣子: (其他限制)
typedef struct _JOBOBJECT_BASIC_UI_RESTRICTIONS
{
    DWORD UIRestrictionsClass;
} JOBOBJECT_BASIC_UI_RESTRICTIONS, *PJOBOBJECT_BASIC_UI_RESTRICTIONS;
J O B O B J E C T _ S E C U R I T Y _ L I M I T _ I N F O R M AT I O N的結構類似下面的形式: (安全限制)
typedef struct _JOBOBJECT_SECURITY_LIMIT_INFORMATION
{
    DWORD              SecurityLimitFlags;
    HANDLE             JobToken;
    PTOKEN_GROUPS      SidsToDisable;
    PTOKEN_PRIVILEGES  PrivilegesToDelete;
    PTOKEN_GROUPS      RestrictedSids;
} JOBOBJECT_SECURITY_LIMIT_INFORMATION, *PJOBOBJECT_SECURITY_LIMIT_INFORMATION;

當然,一旦給作業設置了限制條件,就可以查詢這些限制。通過調用下面的代碼,就可以進行這一操作:

 

BOOL QueryInformationJobObject(
HANDLE hJob,
JOBOBJECTINFOCLASS JobObjectInformationClass,
PVOID pvJobObjectInformation,
DWORD cbJobObjectInformationLength,
PDWORD pdwReturnLength);
你為該函數傳遞作業的句柄(就像你對SetInformationJobObject操作時那樣),這些句柄包括用于指明你想要的限制信息的枚舉類型,函數要進行初始化的數據結構的地址,以及包含該結構的數據塊的長度。最后一個參數是pdwReturnLength,用于指向該函數填寫的DWORD,它告訴你有多少字節放入了緩存。如果你愿意的話,可以(并且通常)為該參數傳遞N U L L。

將進程放入作業:

BOOL AssignProcessToJobObject(
   HANDLE hJob,
   HANDLE hProcess);
該函數告訴系統,將該進程(由hProcess標識)視為現有作業(由h J o b標識)的一部分。
注意,該函數只允許將尚未被賦予任何作業的進程賦予一個作業。一旦進程成為一個作業的組成部分,
它就不能轉到另一個作業,并且不能是無作業的進程。另外,當作為作業的一部分的進程生成另一個進程的時候,
新進程將自動成為父作業的組成部分。注意:調用此函數后要調用ResumeThread();這樣,
進程的線程就可以在作業的限制下執行代碼。終止作業中所有進程的運行
若要撤消作業中的進程,只需要調用下面的代碼:


BOOL TerminateJobObject(
HANDLE hJob,
UINT uExitCode);
這類似為作業中的每個進程調用TerminateProcess函數,將它們的所有退出代碼設置為uExitCode。

查詢作業統計信息
Q u e r y I n f o r m a t i o n J o b O b j e c t函數來獲取對作業的當前限制信息。也可以使用它來獲取關于作業的統計信息。通過傳入不同的參數,可以查詢到不同的作業統計信息.
例如,若要獲取基本的統計信息,可以調用Q u e r y I n f o r m a t i o n J o b O b j e c t,為第二個參數傳遞J o b O b j e c t B a s i c A c c o u n t i n g I n f o r m a t i o n ,并傳遞J O B O B J E C T _ B A S I C _ A C C O U N T I N G _ I N F O R M AT I O N結構的地址:

typedef struct _JOBOBJECT_BASIC_ACCOUNTING_INFORMATION{   LARGE_INTEGER TotalUserTime;   LARGE_INTEGER TotalKernelTime;   LARGE_INTEGER ThisPeriodTotalUserTime;   LARGE_INTEGER ThisPeriodTotalKernelTime;   DWORD TotalPageFaultCount;   DWORD TotalProcesses;   DWORD ActiveProcesses;   DWORD TotalTerminatedProcesses;} JOBOBJECT_BASIC_ACCOUNTING_INFORMATION, *PJOBOBJECT_BASIC_ACCOUNTING_INFORMATION;

 


除了查詢這些基本統計信息外,可以進行一次函數調用,以同時查詢基本統計信息和I/O統計信息。為此,必須為第二個參數傳遞J o b O b j e c t B a s i c A n d I o A c c o u n t i n g I n f o r m a t i o n ,并傳遞J O B O B J E C T _ B A S I C _ A N D _ I O _ A C C O U N T I N G _ I N F O R M AT I O N結構的地址:

typedef struct JOBOBJECT_BASIC_AND_IO_ACCOUNTING_INFORMATION
{
   JOBOBJECT_BASIC_ACCOUNTING_INFORMATION BasicInfo;
   IO_COUNTERS IoInfo;
} JOBOBJECT_BASIC_AND_IO_ACCOUNTING_INFORMATION;

如你所見,這個結構只返回一個J O B O B J E C T _ B A S I C _ A C C O U N T I N G _ I N F O R M AT I O N結構和I O _ C O U N T E R S結構:

 

typedef struct _IO_COUNTERS
{
   ULONGLONG ReadOperationCount;
   ULONGLONG WriteOperationCount;
   ULONGLONG OtherOperationCount;
   ULONGLONG ReadTransferCount;
   ULONGLONG WriteTransferCount;
   ULONGLONG OtherTransferCount;
} IO_COUNTERS;

另外,可以使用下面這個新的G e t P r o c e s s I o C o u n t e r s函數,以便獲取不是這些作業中的進程的這些信息:


BOOL GetProcessIoCounters(
   HANDLE hProcess,
   PIO_COUNTERS pIoCounters);
也可以隨時調用Q u e r y I n f o r m a t i o n J o b O b j e c t函數,以便獲取當前在作業中運行的進程的一組進程I D。若要進行這項操作,首先必須確定你想在作業中看到多少進程,然后必須分配足夠的內存塊,來放置這些進程I D的數組,并指定J O B O B J E C T _ B A S I C _ P R O C E S S _ I D _ L I S T結構的大小:


typedef struct _JOBOBJECT_BASIC_PROCESS_ID_LIST
{
DWORD NumberOfAssignedProcesses;
DWORD NumberOfProcessIdsInList;
DWORD ProcessIdList[1];
} JOBOBJECT_BASIC_PROCESS_ID_LIST,  *PJOBOBJECT_BASIC_PROCESS_ID_LIST;
因此,若要獲得當前作業中的一組進程I D,必須執行類似下面的代碼:

void EnumProcessIdsInJob(HANDLE hjob)
{
    //I assume that there will never be more
    //than 10 processes in this job.
    #define MAX_PROCESS_IDS     10

    //Calculate the number of bytes needed for
    //structure  & process IDs.
    DWORD Cb = sizeof(JOBOBJECT_BASIC_PROCESS_ID_LIST) +
       (MAX_PROCESS_IDS - 1) * sizeof(DWORD);

    //Allocate the block of memory.
    PJOBOBJECT_BASIC_PROCESS_ID_LIST pjobpil = _alloca(cb);

    //Tell the function the maximum number of processes
    //that we allocated space for.
    pjobpil->NumberOfAssignedProcesses = MAX_PROCESS_IDS;

    //Request the current set of process IDs.
    QueryInformationJobObject(hjob, JobObjectBasicProcessIdList,
       pjobpil, cb, &cb);

    //Enumerate the process IDs.
    for(int x=0; x < pjobpil -> NumberOfProcessIdsInList; x++)
    {
        //Use pjobpil->ProcessIdList[x]
    }

    //Since _alloca was used to allocate the memory,
    //we don't need to free it here.
}

 

作業通知信息

如果關心的是分配的所有C P U時間是否已經到期,那么可以非常容易地得到這個通知信息。當作業中的進程尚未用完分配的C P U時間時,作業對象就得不到通知。一旦分配的所有C P U時間已經用完, Wi n d o w s就強制撤消作業中的所有進程,并將情況通知作業對象。通過調用Wa i t F o r S i n g l e O b j e c t (或類似的函數),可以很容易跟蹤這個事件。有時,可以在晚些時候調用S e t I n f o r m a t i o n J o b O b j e c t函數,使作業對象恢復未通知狀態,并為作業賦予更多的C P U時間。

當開始對作業進行操作時,我覺得當作業中沒有任何進程運行時,應該將這個事件通知作業對象。畢竟當進程和線程停止運行時,進程和線程對象就會得到通知。因此,當作業停止運行時它也應該得到通知。這樣,就能夠很容易確定作業何時結束運行。但是, M i c r o s o f t選擇在分配的C P U時間到期時才向作業發出通知,因為這顯示了一個錯誤條件。由于許多作業啟動時有一個父進程始終處于工作狀態,直到它的所有子進程運行結束,因此只需要在父進程的句柄上等待,就可以了解整個作業何時運行結束。S t a r t R e s t r i c t e d P r o c e s s函數用于顯示分配給作業的C P U時間何時到期,或者作業中的進程何時終止運行。

前面介紹了如何獲得某些簡單的通知信息,但是尚未說明如何獲得更高級的通知信息,如進程創建/終止運行等。如果想要得到這些通知信息,必須將更多的基礎結構放入應用程序。特別是,必須創建一個I / O完成端口內核對象,并將作業對象或多個作業對象與完成端口關聯起來。然后,必須讓一個或多個線程在完成端口上等待作業通知的到來,這樣它們才能得到處理。

一旦創建了I / O完成端口,通過調用S e t I n f o r m a t i o n J o b O b j e c t函數,就可以將作業與該端口關聯起來,如下面的代碼所示:


 

JOBOBJECT_ASSOCIATE_COMPLETION_PORT joacp;
//Any value to uniquely identify this job
joacp.CompletionKey = 1;      

//Handle of completion port that receives notifications
joacp.CompletionPort = hIOCP; 
SetInformationJobObject(hJob,
   jobObjectAssociateCompletionPortInformation,
   &joacp, sizeof(jaocp));

當上面的代碼運行時,系統將監視該作業的運行,當事件發生時,它將事件送往I / O完成端口(順便說一下,可以調用Q u e r y I n f o r m a t i o m J o b O b j e c t函數來檢索完成關鍵字和完成端口句柄。但是,這樣做的機會很少)。線程通過調用G e t Q u e u e d C o m p l e t i o n S t a t u s函數來監控I / O完成端口:


BOOL GetQueuedCompletionStatus(
   HANDLE hIOCP,
   PDWORD pNumBytesTransferred,
   PULONG_PTR pCompletionKey,
   POVERLAPPED *pOverlapped,
   DWORD dwMilliseconds);

當該函數返回一個作業事件通知時,* p C o m p l e t i o n K e y包含了調用S e t I n f o r m a t i o n J o b O b j e c t時設置的完成關鍵字值,用于將作業與完成端口關聯起來。它使你能夠知道哪個作業存在一個事件。* p N u m B y t e s Tr a n s f e r r e d中的值用于指明發生了哪個事件。


 

posted on 2006-09-13 09:15 夢在天涯 閱讀(2206) 評論(1)  編輯 收藏 引用 所屬分類: Windows API

評論

# re: windows核心編程--作業 2013-10-10 20:14 panpan

好文章  回復  更多評論   

公告

EMail:itech001#126.com

導航

統計

  • 隨筆 - 461
  • 文章 - 4
  • 評論 - 746
  • 引用 - 0

常用鏈接

隨筆分類

隨筆檔案

收藏夾

Blogs

c#(csharp)

C++(cpp)

Enlish

Forums(bbs)

My self

Often go

Useful Webs

Xml/Uml/html

搜索

  •  

積分與排名

  • 積分 - 1812969
  • 排名 - 5

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 欧美日韩ab片| 伊人天天综合| 亚洲欧美日韩在线综合| 亚洲国产综合视频在线观看| 欧美影院精品一区| 国产精品久久久久久久9999 | 在线高清一区| 久久成人羞羞网站| 午夜激情综合网| 国产精品扒开腿爽爽爽视频| 日韩午夜免费视频| 亚洲另类视频| 欧美日本三级| 一区二区日韩| 99视频+国产日韩欧美| 欧美日韩1234| 亚洲一区二区三区四区五区午夜 | 久久久国产午夜精品| 国产精品一区2区| 久久国产欧美日韩精品| 欧美伊久线香蕉线新在线| 国产在线观看91精品一区| 久久久福利视频| 久久激五月天综合精品| 依依成人综合视频| 亚洲电影在线看| 欧美日韩国产一区精品一区| 亚洲视频久久| 亚洲欧美在线免费| 精品福利电影| 亚洲欧洲日产国产综合网| 欧美日韩在线播放| 性色av一区二区三区在线观看 | 校园春色综合网| 国内精品嫩模av私拍在线观看 | 亚洲国产精品999| 欧美成人免费全部| 在线视频一区观看| 午夜精品国产| 亚洲国产精品精华液2区45| 亚洲欧洲精品一区二区三区不卡 | 亚洲网在线观看| 国产一区二区欧美| 亚洲国产精品一区二区www| 欧美日韩在线电影| 久久偷看各类wc女厕嘘嘘偷窃| 免费成人在线观看视频| 亚洲一区二区三区精品在线| 久久se精品一区二区| 99pao成人国产永久免费视频| 亚洲伊人伊色伊影伊综合网| 在线观看91久久久久久| 一区二区三欧美| 一区二区三区中文在线观看| 一本久久综合| 亚洲电影免费观看高清| 亚洲精品国久久99热| 亚洲色图综合久久| 亚洲精品亚洲人成人网| 欧美一区二区三区电影在线观看| 亚洲免费高清| 久久久精品国产免大香伊| 999在线观看精品免费不卡网站| 新狼窝色av性久久久久久| 一级成人国产| 欧美a级一区| 老司机午夜免费精品视频| 国产精品久久久久久久免费软件| 欧美国产在线电影| 狠狠久久亚洲欧美专区| 亚洲免费在线电影| 亚洲天堂免费在线观看视频| 毛片基地黄久久久久久天堂| 久久av一区二区三区| 国产精品免费一区豆花| 亚洲激情影院| 91久久久在线| 鲁大师影院一区二区三区| 久久久亚洲高清| 国产美女诱惑一区二区| 亚洲色无码播放| 亚洲一级黄色片| 欧美日韩国产美| 亚洲乱码国产乱码精品精可以看| 亚洲精品久久久久久下一站| 免费日本视频一区| 欧美岛国在线观看| 狠狠色狠狠色综合| 久久激情综合网| 麻豆国产精品va在线观看不卡 | 亚洲色无码播放| 欧美激情第二页| 亚洲人成毛片在线播放| 欧美激情在线有限公司| 欧美一级淫片播放口| 国产精品扒开腿爽爽爽视频| 99在线精品视频| 亚洲一区二区在线免费观看| 欧美日韩一区二区三区在线| 日韩午夜电影| 亚洲欧美国产日韩天堂区| 国产精品久久久久久久久果冻传媒| 亚洲最新在线视频| 亚洲午夜高清视频| 国产精品夜夜夜| 午夜精品婷婷| 玖玖精品视频| 亚洲日韩欧美一区二区在线| 欧美欧美全黄| 中文av一区二区| 欧美在线视频全部完| 国产一区二区三区免费在线观看| 久久精视频免费在线久久完整在线看 | 亚洲精品中文在线| 欧美丝袜一区二区三区| 亚洲影院色在线观看免费| 久久精品国产99| 亚洲高清不卡一区| 欧美日韩高清免费| 亚洲欧美精品在线观看| 另类综合日韩欧美亚洲| 亚洲免费电影在线| 国产日韩精品入口| 蜜臀av性久久久久蜜臀aⅴ| 亚洲精品乱码久久久久久蜜桃91| 亚洲一区二区三区精品在线观看| 国产日产高清欧美一区二区三区| 久久久av毛片精品| 日韩午夜电影av| 久久久www成人免费毛片麻豆| 亚洲国产精品一区二区尤物区| 欧美日韩视频一区二区三区| 欧美中文字幕不卡| 日韩午夜电影av| 美女视频黄免费的久久| 一区二区欧美国产| 国产亚洲一区二区在线观看| 欧美国产成人在线| 先锋影院在线亚洲| 亚洲精品影视在线观看| 久久伊人一区二区| 亚洲欧美成人一区二区三区| 在线日韩欧美视频| 国产欧美精品日韩| 欧美日韩国产精品一区二区亚洲| 欧美在线你懂的| 9色国产精品| 亚洲国产另类久久精品| 久久亚洲色图| 欧美在线亚洲综合一区| 一区二区三区四区五区精品视频 | 国产精品久久久一区二区| 免费久久99精品国产自在现线| 亚洲在线中文字幕| 亚洲精品免费在线播放| 欧美成人日韩| 久久理论片午夜琪琪电影网| 亚洲一区二区欧美| 一本久道久久综合狠狠爱| 亚洲国产日韩一区二区| 欧美成人精品一区二区| 一本不卡影院| 欧美激情一区在线| 免费看av成人| 久久综合网hezyo| 久久久999精品视频| 先锋亚洲精品| 午夜视频一区在线观看| 亚洲香蕉视频| 亚洲私人影院在线观看| 亚洲卡通欧美制服中文| 亚洲人成免费| 亚洲黄色精品| 亚洲精品少妇| 亚洲精品偷拍| 一区二区三区 在线观看视| 99精品国产在热久久下载| 亚洲级视频在线观看免费1级| 亚洲第一在线综合在线| 在线不卡a资源高清| 亚洲黑丝一区二区| 亚洲精品国产精品国自产观看浪潮| 亚洲国产精品va在线看黑人| 亚洲国产成人精品久久| 亚洲精品一区久久久久久| 夜夜嗨av色综合久久久综合网 | 老巨人导航500精品| 久久夜色精品| 欧美成人69av| 亚洲国产日韩欧美在线图片| 亚洲福利视频免费观看| 亚洲精选91| 亚洲男人影院| 久久精品国产亚洲一区二区| 久久色在线观看| 欧美巨乳在线| 国产精品美女久久久| 国内精品写真在线观看|