【轉】MFC OnIdle的詳細說明

來源:互聯網
上載者:User

標籤:基類   預設   detail   使用者輸入   重要   後台   附加   需要   .net   

轉載出處:http://blog.csdn.net/tsing_best/article/details/25055707

CWinApp::OnIdle
virtual BOOL OnIdle( LONG lCount );
傳回值
  如果要接收更多的空閑處理時間,則返回非零值;如果不需要更多的空閑時間則返回0。
參數
  lCount該參數是一個計數值,當應用程式的訊息佇列為空白,OnIdle函數被調用時,該計數值就增加1。
  每當一條新訊息被處理時,該計數值就被複位為0。你可以使用lCount參數來確定應用程式不處理訊息時空閑時間的相對長度。
說明
  如果要執行空閑時處理,則重載這個成員函數。當應用程式的訊息佇列為空白時,OnIdle就在預設的訊息迴圈中被調用。
  你可以用重載函數來調用自己的後台空閑處理任務。
  OnIdle應返回0以表明不需要更多的空閑處理時間。
  當訊息佇列為空白時,OnIdle每被調用一次lCount參數就增加,而每處理一條新訊息lCount就被複位為0。
  你可以根據這個計數值調用不同的空閑處理常式。

  下面總結了空閑迴圈處理:
  1、如果微軟基礎類庫中的訊息迴圈檢查訊息佇列並發現沒有未被處理的訊息,它就為應用程式物件調用OnIdle函數,並將lCount參數設為0。
  2、OnIdle執行一些處理,然後返回一個非零值,表示它還需要被調用,以進行進一步處理。
  3、訊息迴圈再次檢查訊息佇列。如果沒有未處理的訊息,則再次調用OnIdle,增加lCount參數。
  4、最後,OnIdle結束所有的空閑任務並返回0。
  這就告訴訊息迴圈停止調用OnIdle直到在訊息佇列中接收到下一條訊息為止,在那時,空閑迴圈將重新啟動,而參數被設為0。
因為只有在OnIdle返回之後應用程式才能處理使用者輸入,因此在OnIdle中不應進行較長的任務。

注意
  OnIdle的預設實現更新命令使用者介面對象,如功能表項目和工具條等,還實現了內部資料結構的清理。
  因此,如果你重載了OnIdle,你必須用重載版本中使用的lCount值來調用CWinApp::OnIdle。
  首先調用所有基類的空閑處理(即直到基類的OnIdle返回0)。
  如果你需要在基類處理完成之前進行一些工作,則應回顧基類的實現以在自己的工作期間選擇一個合適的lCount值。

樣本
  下面的兩個例子示範了OnIdle的用法。

  第一個例子處理兩個空閑任務,用lCount參數來排列這些任務的優先權。
  第一個任務優先權較高,一旦可能你就應當執行此任務。第二個任務不十分重要,只有當使用者輸入有一個較長時間的間歇的時候才應執行此任務。
  注意其中對基類的OnIdle的調用。
  第二個例子管理著一組具有不同優先權的空閑任務。

BOOL CMyApp::OnIdle(LONG lCount){  BOOL bMore = CWinApp::OnIdle(lCount);  if (lCount == 0)  {    TRACE("App idle for short period of time/n");    bMore = TRUE;  }  else if (lCount == 10)  {  TRACE("App idle for longer amount of time/n");  bMore = TRUE;  }  else if (lCount == 100)  {    TRACE("App idle for even longer amount of time/n");    bMore = TRUE;  }  else if (lCount == 1000)  {    TRACE("App idle for quite a long period of time/n");    // bMore 沒有被設為TRUE, 不在需要空閑    // 重要:bMore 沒有被設為 FALSE,因為 CWinApp::OnIdle可能還有其它空閑任務要完成。  }  return bMore; // 返回TRUE,只要還有其它空閑任務}

第二個樣本:
// 在這個例子中,有四個空閑迴圈任務,它們被賦予
// 不同的優先權,啟動並執行機會不同:
// Task1在空閑時總能運行,要求在架構處理它自己的空閑迴圈任務時沒有訊息在等候。(lCount為0或1)
// Task2 僅當Task1以及運行時才能運行,要求當Task1運行時沒有訊息在等候。
// Task3和Task4僅當Task1和Task2都運行之後才能運行,
// 並且在此期間沒有訊息在等候。如果Task3能夠運行,
// 則Task4總是在Task3之後立即運行。
BOOL CMyApp::OnIdle(LONG lCount)
{
// 在這個例子中,像多數應用程式一樣,你應該讓基類
// 的CWinApp::OnIdle在你試圖進行任何附加的空閑迴圈
// 過程之前完成它的處理。
if (CWinApp::OnIdle(lCount)) return TRUE;
// 基類的CWinApp::OnIdle為lCount保留0和1給架構自己的
// 空閑處理使用。如果你希望與架構平等地共用空閑處理
// 時間,則應替換上面的if語句,直接調用CWinApp::OnIdle,
// 然後為lCount的值0和/或1加入一個case語句。首先應當研
// 究基類的實現以理解你的空閑迴圈任務將會如何與架構的
// 空閑迴圈處理競爭。
switch (lCount)
{
  case 2:
    Task1();
    return TRUE; // 下一次給 Task2 一個機會
  case 3:
    Task2();
    return TRUE; // 下一次給Task3和Task4一個機會
  case 4:
    Task3();
    Task4();
    return FALSE; // 再次回到空閑迴圈任務
  }
  return FALSE;
}
///注意
在VC基於對話方塊程式中,似乎不能使用OnIdle。從網上查了一下,可以用WM_KICKIDLE訊息實現相同功能。WM_KICKIDLE訊息響應需要自己手動添加代碼。下面是步驟:
1.MyDlg.cpp檔案添加包含:
#include <afxpriv.h>
2.MyDlg.h檔案添加聲明
afx_msg LRESULT OnKickIdle(WPARAM wParam, LPARAM lParam);
3.MyDlg.cpp檔案添加訊息映射:
ON_MESSAGE(WM_KICKIDLE,OnKickIdle)
4.MyDlg.cpp添加函數的實現:
LRESULT CMyDlg::OnKickIdle(WPARAM wParam, LPARAM lParam)
{
  //------TODO--------------------------------

  return 0;
}

【轉】MFC OnIdle的詳細說明

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.