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

隨筆 - 42  文章 - 3  trackbacks - 0
<2025年12月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

常用鏈接

留言簿(2)

隨筆檔案

文章檔案

網(wǎng)頁(yè)收藏

搜索

  •  

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

例子是一個(gè)mfc的對(duì)話框,用vc調(diào)試器查看了一個(gè)程序從生成初始化到接受消息的流程。從產(chǎn)生到結(jié)束的基本流程是這樣的:
KERNEL32->WinMainCRTStartup()->_tWinMain(開(kāi)始)->AfxWinMain(開(kāi)始)->AfxGetThread()->AfxWinInit()->InitApplication()->InitInstance()->DoModal()->RunModalLoop()->ExitInstance()->AfxWinMain(結(jié)束)->_tWinMain(結(jié)束)

1、KERNEL32
kernel32.dll是Windows9x/Me中非常重要的32位動(dòng)態(tài)鏈接庫(kù)文件,屬于內(nèi)核級(jí)文件。它控制著系統(tǒng)的內(nèi)存管理、數(shù)據(jù)的輸入輸出操作和中斷處理,當(dāng)Windows啟動(dòng)時(shí),kernel32.dll就駐留在內(nèi)存中特定的寫保護(hù)區(qū)域,使別的程序無(wú)法占用這個(gè)內(nèi)存區(qū)域。

2、WinMainCRTStartup()函數(shù)
  程序默認(rèn)的基地址(EXE文件默認(rèn)為0x400000,DLL默認(rèn)為x10000000),操作系統(tǒng)裝載一個(gè)程序時(shí)總是試著先從這個(gè)基地址開(kāi)始。一般Win32的程序,EXE的入口為WinMain,DLL的入口為DllEntryPoint。默認(rèn)情況下,通過(guò)一個(gè)C的運(yùn)行時(shí)庫(kù)函數(shù)來(lái)實(shí)現(xiàn):控制臺(tái)程序采用mainCRTStartup (或wmainCRTStartup)去調(diào)用程序的main (或wmain)函數(shù);Windows程序采用WinMainCRTStartup (或 wWinMainCRTStartup)調(diào)用程序的WinMain (或 wWinMain,必須采用__stdcall調(diào)用約定);DLL采用_DllMainCRTStartup調(diào)用DllMain函數(shù)(必須采用__stdcall調(diào)用約定)。
它負(fù)責(zé):
  * 檢索指向新進(jìn)程的完整命令行指針;
  * 檢索指向新進(jìn)程的環(huán)境變量的指針;
  * 對(duì)c/c++運(yùn)行時(shí)的全局變量進(jìn)行初始化;
  * 對(duì)c運(yùn)行期的內(nèi)存單元分配函數(shù)(比如malloc,calloc)和其他低層I/O例程使用的內(nèi)存棧     進(jìn)行初始化。
  * 為C++的全局和靜態(tài)類調(diào)用構(gòu)造函數(shù)。
  當(dāng)這些初始化工作完成后,該啟動(dòng)函數(shù)就調(diào)用wWinMain函數(shù)進(jìn)入應(yīng)用程序的執(zhí)行。
當(dāng)wWinMain函數(shù)執(zhí)行完畢返回時(shí),wWinMainCRTStartup啟動(dòng)函數(shù)就調(diào)用c運(yùn)行期的exit()函
數(shù),將返回值(nMainRetVal)傳遞給它。
  之后exit()便開(kāi)始收尾工作:
  * 調(diào)用由_onexit()函數(shù)調(diào)用和注冊(cè)的任何函數(shù)。
  * 為C++的全局和靜態(tài)類調(diào)用析構(gòu)函數(shù);
  * 調(diào)用操作系統(tǒng)的ExitProcess函數(shù),將nMainRetVal傳遞給它,這使得操作系統(tǒng)能夠撤銷     進(jìn)程并設(shè)置它的exit  代碼。
最小體積的win32程序:(不要編譯缺省庫(kù))
#pragma comment (linker, "/SUBSYSTEM:WINDOWS")
#pragma comment (linker, "/NODEFAULTLIB")
int WinMainCRTStartup()
{
 return 0;
}

3、WinMain()函數(shù)
_tWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance,
 LPTSTR lpCmdLine, int nCmdShow)
{
 // call shared/exported WinMain
 return AfxWinMain(hInstance, hPrevInstance, lpCmdLine, nCmdShow);
}

4、AfxWinMain()函數(shù)
int AFXAPI AfxWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance,
 LPTSTR lpCmdLine, int nCmdShow)
{
 ASSERT(hPrevInstance == NULL);

 int nReturnCode = -1;
 CWinThread* pThread = AfxGetThread();
 CWinApp* pApp = AfxGetApp();

 // AFX internal initialization
 if (!AfxWinInit(hInstance, hPrevInstance, lpCmdLine, nCmdShow))
  goto InitFailure;

 // App global initializations (rare)
 if (pApp != NULL && !pApp->InitApplication())
  goto InitFailure;

 // Perform specific initializations
 if (!pThread->InitInstance())
 {
  if (pThread->m_pMainWnd != NULL)
  {
   TRACE0("Warning: Destroying non-NULL m_pMainWnd\n");
   pThread->m_pMainWnd->DestroyWindow();
  }
  nReturnCode = pThread->ExitInstance();
  goto InitFailure;
 }
 nReturnCode = pThread->Run();

InitFailure:
#ifdef _DEBUG
 // Check for missing AfxLockTempMap calls
 if (AfxGetModuleThreadState()->m_nTempMapLock != 0)
 {
  TRACE1("Warning: Temp map lock count non-zero (%ld).\n",
   AfxGetModuleThreadState()->m_nTempMapLock);
 }
 AfxLockTempMaps();
 AfxUnlockTempMaps(-1);
#endif

 AfxWinTerm();
 return nReturnCode;
}

5、AfxGetThread()函數(shù)
CWinThread* AFXAPI AfxGetThread()
{
 // check for current thread in module thread state
 AFX_MODULE_THREAD_STATE* pState = AfxGetModuleThreadState();
 CWinThread* pThread = pState->m_pCurrentWinThread;

 // if no CWinThread for the module, then use the global app
 if (pThread == NULL)
  pThread = AfxGetApp();

 return pThread;
}

6、AfxWinInit()函數(shù)
BOOL AFXAPI AfxWinInit(HINSTANCE hInstance, HINSTANCE hPrevInstance,
 LPTSTR lpCmdLine, int nCmdShow)
{
 ASSERT(hPrevInstance == NULL);

 // handle critical errors and avoid Windows message boxes
 SetErrorMode(SetErrorMode(0) |
  SEM_FAILCRITICALERRORS|SEM_NOOPENFILEERRORBOX);

 // set resource handles
 AFX_MODULE_STATE* pModuleState = AfxGetModuleState();
 pModuleState->m_hCurrentInstanceHandle = hInstance;
 pModuleState->m_hCurrentResourceHandle = hInstance;

 // fill in the initial state for the application
 CWinApp* pApp = AfxGetApp();
 if (pApp != NULL)
 {
  // Windows specific initialization (not done if no CWinApp)
  pApp->m_hInstance = hInstance;
  pApp->m_hPrevInstance = hPrevInstance;
  pApp->m_lpCmdLine = lpCmdLine;
  pApp->m_nCmdShow = nCmdShow;
  pApp->SetCurrentHandles();
 }

 // initialize thread specific data (for main thread)
 if (!afxContextIsDLL)
  AfxInitThread();

 return TRUE;
}

7、InitApplication() 函數(shù)
BOOL CMy1App::InitApplication()
{
 // TODO: Add your specialized code here and/or call the base class
 AfxMessageBox("InitApplication");
 return CWinApp::InitApplication();
}
BOOL CWinApp::InitApplication()
{
 if (CDocManager::pStaticDocManager != NULL)
 {
  if (m_pDocManager == NULL)
   m_pDocManager = CDocManager::pStaticDocManager;
  CDocManager::pStaticDocManager = NULL;
 }

 if (m_pDocManager != NULL)
  m_pDocManager->AddDocTemplate(NULL);
 else
  CDocManager::bStaticInit = FALSE;

 return TRUE;
}

8、InitInstance()函數(shù)
AfxWinMain函數(shù)里面的if (!pThread->InitInstance())會(huì)調(diào)用程序CMy1App的InitInstance函數(shù):
BOOL CMy1App::InitInstance()
{
 AfxEnableControlContainer();
AfxMessageBox("InitInstance");
 // Standard initialization
 // If you are not using these features and wish to reduce the size
 //  of your final executable, you should remove from the following
 //  the specific initialization routines you do not need.

#ifdef _AFXDLL
 Enable3dControls();   // Call this when using MFC in a shared DLL
#else
 Enable3dControlsStatic(); // Call this when linking to MFC statically
#endif

 CMy1Dlg dlg;//調(diào)用CMy1Dlg的構(gòu)造函數(shù)
 m_pMainWnd = &dlg;
 int nResponse = dlg.DoModal();
 if (nResponse == IDOK)
 {
  // TODO: Place code here to handle when the dialog is
  //  dismissed with OK
 }
 else if (nResponse == IDCANCEL)
 {
  // TODO: Place code here to handle when the dialog is
  //  dismissed with Cancel
 }

 // Since the dialog has been closed, return FALSE so that we exit the
 //  application, rather than start the application's message pump.
 return FALSE;
}

9、AfxWinMain()函數(shù)里面的主要的循環(huán)體,在這里:
        if (!pThread->InitInstance())//主要是模式對(duì)話框調(diào)用,對(duì)話框關(guān)閉以后InitInstance函數(shù)才會(huì)結(jié)束
 {
  if (pThread->m_pMainWnd != NULL)
  {
   TRACE0("Warning: Destroying non-NULL m_pMainWnd\n");
   pThread->m_pMainWnd->DestroyWindow();
  }
  nReturnCode = pThread->ExitInstance();
  goto InitFailure;
 }
 nReturnCode = pThread->Run();//非模式對(duì)話框和一般程序調(diào)用這個(gè)循環(huán)

InitInstance函數(shù)調(diào)用了dlg.DoModal()函數(shù),以下是DoModal()函數(shù):
int CDialog::DoModal()
{
 // can be constructed with a resource template or InitModalIndirect
 ASSERT(m_lpszTemplateName != NULL || m_hDialogTemplate != NULL ||
  m_lpDialogTemplate != NULL);

 // load resource as necessary
 LPCDLGTEMPLATE lpDialogTemplate = m_lpDialogTemplate;
 HGLOBAL hDialogTemplate = m_hDialogTemplate;
 HINSTANCE hInst = AfxGetResourceHandle();
 if (m_lpszTemplateName != NULL)
 {
  hInst = AfxFindResourceHandle(m_lpszTemplateName, RT_DIALOG);
  HRSRC hResource = ::FindResource(hInst, m_lpszTemplateName, RT_DIALOG);
  hDialogTemplate = LoadResource(hInst, hResource);
 }
 if (hDialogTemplate != NULL)
  lpDialogTemplate = (LPCDLGTEMPLATE)LockResource(hDialogTemplate);

 // return -1 in case of failure to load the dialog template resource
 if (lpDialogTemplate == NULL)
  return -1;

 // disable parent (before creating dialog)
 HWND hWndParent = PreModal();
 AfxUnhookWindowCreate();
 BOOL bEnableParent = FALSE;
 if (hWndParent != NULL && ::IsWindowEnabled(hWndParent))
 {
  ::EnableWindow(hWndParent, FALSE);
  bEnableParent = TRUE;
 }

 TRY
 {
  // create modeless dialog
  AfxHookWindowCreate(this);
  if (CreateDlgIndirect(lpDialogTemplate,
      CWnd::FromHandle(hWndParent), hInst))//創(chuàng)建對(duì)話框的窗口
  {
   if (m_nFlags & WF_CONTINUEMODAL)
   {
    // enter modal loop
    DWORD dwFlags = MLF_SHOWONIDLE;
    if (GetStyle() & DS_NOIDLEMSG)
     dwFlags |= MLF_NOIDLEMSG;
    VERIFY(RunModalLoop(dwFlags) == m_nModalResult);//這里是真正的循環(huán)RunModalLoop
   }

   // hide the window before enabling the parent, etc.
   if (m_hWnd != NULL)
    SetWindowPos(NULL, 0, 0, 0, 0, SWP_HIDEWINDOW|
     SWP_NOSIZE|SWP_NOMOVE|SWP_NOACTIVATE|SWP_NOZORDER);
  }
 }
 CATCH_ALL(e)
 {
  DELETE_EXCEPTION(e);
  m_nModalResult = -1;
 }
 END_CATCH_ALL

 if (bEnableParent)
  ::EnableWindow(hWndParent, TRUE);
 if (hWndParent != NULL && ::GetActiveWindow() == m_hWnd)
  ::SetActiveWindow(hWndParent);

 // destroy modal window
 DestroyWindow();
 PostModal();

 // unlock/free resources as necessary
 if (m_lpszTemplateName != NULL || m_hDialogTemplate != NULL)
  UnlockResource(hDialogTemplate);
 if (m_lpszTemplateName != NULL)
  FreeResource(hDialogTemplate);

 return m_nModalResult;
}

模式對(duì)話框調(diào)用的循環(huán)函數(shù)RunModalLoop()函數(shù)如下:
int CWnd::RunModalLoop(DWORD dwFlags)
{
 ASSERT(::IsWindow(m_hWnd)); // window must be created
 ASSERT(!(m_nFlags & WF_MODALLOOP)); // window must not already be in modal state

 // for tracking the idle time state
 BOOL bIdle = TRUE;
 LONG lIdleCount = 0;
 BOOL bShowIdle = (dwFlags & MLF_SHOWONIDLE) && !(GetStyle() & WS_VISIBLE);
 HWND hWndParent = ::GetParent(m_hWnd);
 m_nFlags |= (WF_MODALLOOP|WF_CONTINUEMODAL);
 MSG* pMsg = &AfxGetThread()->m_msgCur;

 // acquire and dispatch messages until the modal state is done
 for (;;)
 {
  ASSERT(ContinueModal());

  // phase1: check to see if we can do idle work
  while (bIdle &&
   !::PeekMessage(pMsg, NULL, NULL, NULL, PM_NOREMOVE))
  {
   ASSERT(ContinueModal());

   // show the dialog when the message queue goes idle
   if (bShowIdle)
   {
    ShowWindow(SW_SHOWNORMAL);
    UpdateWindow();
    bShowIdle = FALSE;
   }

   // call OnIdle while in bIdle state
   if (!(dwFlags & MLF_NOIDLEMSG) && hWndParent != NULL && lIdleCount == 0)
   {
    // send WM_ENTERIDLE to the parent
    ::SendMessage(hWndParent, WM_ENTERIDLE, MSGF_DIALOGBOX, (LPARAM)m_hWnd);
   }
   if ((dwFlags & MLF_NOKICKIDLE) ||
    !SendMessage(WM_KICKIDLE, MSGF_DIALOGBOX, lIdleCount++))
   {
    // stop idle processing next time
    bIdle = FALSE;
   }
  }

  // phase2: pump messages while available
  do
  {
   ASSERT(ContinueModal());

   // pump message, but quit on WM_QUIT
   if (!AfxGetThread()->PumpMessage())//主要在這里循環(huán)
   {
    AfxPostQuitMessage(0);
    return -1;
   }

   // show the window when certain special messages rec'd
   if (bShowIdle &&
    (pMsg->message == 0x118 || pMsg->message == WM_SYSKEYDOWN))
   {
    ShowWindow(SW_SHOWNORMAL);
    UpdateWindow();
    bShowIdle = FALSE;
   }

   if (!ContinueModal())
    goto ExitModal;

   // reset "no idle" state after pumping "normal" message
   if (AfxGetThread()->IsIdleMessage(pMsg))
   {
    bIdle = TRUE;
    lIdleCount = 0;
   }

  } while (::PeekMessage(pMsg, NULL, NULL, NULL, PM_NOREMOVE));
 }

ExitModal:
 m_nFlags &= ~(WF_MODALLOOP|WF_CONTINUEMODAL);
 return m_nModalResult;
}

一般程序調(diào)用的循環(huán)函數(shù)Run函數(shù)如下:
int CWinThread::Run()
{
 ASSERT_VALID(this);

 // for tracking the idle time state
 BOOL bIdle = TRUE;
 LONG lIdleCount = 0;

 // acquire and dispatch messages until a WM_QUIT message is received.
 for (;;)
 {
  // phase1: check to see if we can do idle work
  while (bIdle &&
   !::PeekMessage(&m_msgCur, NULL, NULL, NULL, PM_NOREMOVE))
  {
   // call OnIdle while in bIdle state
   if (!OnIdle(lIdleCount++))
    bIdle = FALSE; // assume "no idle" state
  }

  // phase2: pump messages while available
  do
  {
   // pump message, but quit on WM_QUIT
   if (!PumpMessage())
    return ExitInstance();

   // reset "no idle" state after pumping "normal" message
   if (IsIdleMessage(&m_msgCur))
   {
    bIdle = TRUE;
    lIdleCount = 0;
   }

  } while (::PeekMessage(&m_msgCur, NULL, NULL, NULL, PM_NOREMOVE));
 }

 ASSERT(FALSE);  // not reachable
}

==========
我認(rèn)為是更加完整的應(yīng)該是_DllMainCRTStartup-> WinMainCRTStartup(void)->()->_tWinMain(開(kāi)始)->AfxWinMain(開(kāi)始)->AfxGetThread()->AfxWinInit()->InitApplication()->InitInstance()->DoModal()->RunModalLoop()->ExitInstance()->AfxWinMain(結(jié)束)->_tWinMain(結(jié)束)

參考http://www.shnenglu.com/citywanderer/articles/8716.html
posted on 2009-10-01 22:51 鷹擊長(zhǎng)空 閱讀(1629) 評(píng)論(0)  編輯 收藏 引用

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   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>
            国产精品综合色区在线观看| 亚洲欧洲日产国产网站| 国产伦精品一区二区三区高清版| 一本久久知道综合久久| 香蕉av777xxx色综合一区| 国产女精品视频网站免费| 久久久久久久高潮| 91久久久久久国产精品| 亚洲无限av看| 国产一区二区黄| 欧美jizzhd精品欧美巨大免费| 亚洲韩国青草视频| 亚洲欧美偷拍卡通变态| 韩国成人福利片在线播放| 免费在线看一区| 夜夜嗨av一区二区三区网站四季av| 欧美在线观看一区二区| 亚洲激情国产| 国产精品天美传媒入口| 久久一区亚洲| 亚洲图片在区色| 噜噜噜91成人网| 亚洲午夜一二三区视频| 一区二区视频免费在线观看| 欧美日韩a区| 久久精品综合一区| 99国产精品99久久久久久| 久久久久一区| 亚洲视频免费观看| 亚洲国产精品ⅴa在线观看| 欧美视频第二页| 久久在线免费观看视频| 亚洲综合色婷婷| 亚洲激情另类| 久久午夜电影网| 亚洲校园激情| 91久久久国产精品| 韩国视频理论视频久久| 国产精品久久久久av| 欧美国产日本韩| 久久精品国产精品| 亚洲一区二区三区在线看| 亚洲国产另类精品专区 | 久久久久久久精| 夜夜嗨av色综合久久久综合网| 免费在线成人| 久久久噜噜噜久久狠狠50岁| 亚洲午夜伦理| 日韩一级精品| 亚洲黄网站在线观看| 精品88久久久久88久久久| 国产精品免费小视频| 欧美日韩视频专区在线播放| 麻豆av一区二区三区久久| 欧美一区二区视频97| 亚洲一区二区久久| 一区二区三区黄色| 99re热精品| 亚洲九九爱视频| 亚洲精品久久久久久久久久久久| 欧美成在线观看| 男女视频一区二区| 欧美h视频在线| 免费一级欧美在线大片| 免费亚洲电影| 久久全国免费视频| 久久久爽爽爽美女图片| 久久久久高清| 久久久美女艺术照精彩视频福利播放 | 欧美高清视频一区| 两个人的视频www国产精品| 久久久久久久国产| 久久天堂国产精品| 麻豆精品在线观看| 欧美成人综合一区| 亚洲人午夜精品免费| 亚洲精品一品区二品区三品区| 亚洲电影观看| 91久久久一线二线三线品牌| 亚洲欧洲日本mm| 99re66热这里只有精品3直播| 亚洲另类在线视频| 在线亚洲成人| 新狼窝色av性久久久久久| 欧美一区二区精美| 久久久久在线观看| 欧美激情精品久久久久| 欧美日韩国产小视频| 国产精品伦子伦免费视频| 国产日韩视频一区二区三区| 激情五月***国产精品| 91久久精品日日躁夜夜躁国产| 亚洲精品国产精品国自产在线| 99re6热只有精品免费观看| 亚洲专区一区| 久久爱www.| 欧美激情 亚洲a∨综合| 99av国产精品欲麻豆| 午夜精品一区二区在线观看 | 亚洲精品一区二区网址| 一区二区三区波多野结衣在线观看| 亚洲天堂成人| 久久精品系列| 最新成人av在线| 亚洲影视在线| 欧美freesex8一10精品| 欧美日韩另类综合| 韩国v欧美v日本v亚洲v| 一区二区三区高清视频在线观看| 香蕉久久a毛片| 欧美黄色视屏| 亚洲欧美日韩中文视频| 免费91麻豆精品国产自产在线观看| 欧美日韩国产不卡| 伊人久久av导航| 国产精品99久久久久久久久| 久久综合久久久久88| 一区二区av在线| 久久一区二区三区av| 国产精品高清在线| 亚洲精品一品区二品区三品区| 欧美在线播放视频| 亚洲理伦电影| 老司机久久99久久精品播放免费| 国产精品va在线播放| 亚洲国产欧美日韩另类综合| 亚洲尤物在线| 亚洲经典视频在线观看| 久久av一区二区三区亚洲| 欧美色欧美亚洲高清在线视频| 尤物yw午夜国产精品视频| 午夜精品视频| 日韩午夜在线播放| 免费亚洲电影| 精品99一区二区| 久久精品久久综合| 亚洲一区二区在线视频| 欧美日韩国产综合在线| 亚洲人成在线免费观看| 久久亚洲高清| 香蕉久久国产| 国产精品天天摸av网| 亚洲视频香蕉人妖| 亚洲黄色成人久久久| 免费日韩av片| 亚洲第一页自拍| 美国十次了思思久久精品导航| 亚洲一区日本| 国产精品久久久免费| 亚洲一区二区不卡免费| 亚洲人成欧美中文字幕| 欧美成人午夜影院| 亚洲欧洲日本专区| 美日韩丰满少妇在线观看| 欧美一区不卡| 国产亚洲一区在线播放| 欧美在线视频在线播放完整版免费观看| 在线视频欧美精品| 欧美网站在线| 午夜精品电影| 亚洲欧美日韩精品久久久久| 国产乱码精品一区二区三区五月婷 | 国产精品美女久久| 亚洲亚洲精品三区日韩精品在线视频| 欧美激情亚洲| 欧美好吊妞视频| 夜夜嗨av一区二区三区网页| 亚洲国产欧美在线人成| 欧美福利一区二区三区| aⅴ色国产欧美| 一本大道av伊人久久综合| 国产精品福利av| 欧美一区二区国产| 欧美中文字幕视频| 亚洲成人在线视频网站| 欧美激情在线免费观看| 欧美精品手机在线| 亚洲视频在线一区| 亚洲一区二区三区在线看 | 久久资源在线| 亚洲片在线观看| 一区二区高清在线观看| 国产精品久久久久毛片大屁完整版| 欧美一区二区成人6969| 久久国产福利国产秒拍| 亚洲国产人成综合网站| 亚洲裸体在线观看| 国产精品久久影院| 久久中文字幕导航| 欧美韩日一区二区| 欧美亚洲网站| 久久五月天婷婷| 一区二区91| 欧美一二三视频| 最近中文字幕日韩精品| 中文在线不卡| 在线日韩中文| 亚洲无玛一区| 最新高清无码专区| 亚洲综合欧美日韩|