類成員函數做爲線程函數

-------------------類成員函數不能做爲線程函數---------------------------
    通常來講,C++的類成員函數不能做爲線程函數。這是由於在類中定義的成員函數,編譯器會給其加
上this指針。請看下列程序:
windows

#include "windows.h" 
#include <process.h>
函數

class ExampleTask   
 
  public:  
   void taskmain(LPVOID param);
   void StartTask();   
};  
void ExampleTask::taskmain(LPVOID param)
{}  
 
void ExampleTask::StartTask()   
 
  _beginthread(taskmain,0,NULL);
 
 
int main(int argc, char* argv[]) 
{ 
  ExampleTask realTimeTask; 
  realTimeTask.StartTask(); 
  return 0; 
}
this

出現編譯錯誤:
error C3867: 'ExampleTask::taskmain': function call missing argument list; use '&ExampleTask::taskmain' to create a pointer to membe
下面Code會出現與此一樣的編譯錯誤。
#include "windows.h" 
#include <process.h> 
class ExampleTask   
{   
public:  
   void taskmain(LPVOID param);   
};  
 
void ExampleTask::taskmain(LPVOID param)   
{}  
 
int main(int argc, char* argv[]) 
{ 
  ExampleTask realTimeTask; 
  _beginthread(ExampleTask::taskmain,0,NULL); 
  return 0; 
}
spa

若是必定要以類成員函數做爲線程函數,一般有以下解決方案: 線程

(1)將該成員函數聲明爲static類型,去掉this指針;
    即將類定義改成:
#include "windows.h" 
#include <process.h> 
class ExampleTask   
 
  public:  
   void static taskmain(LPVOID param);   
   void StartTask();   
};
指針

可是將成員函數聲明爲靜態雖然能夠解決做爲線程函數的問題,可是它帶來了新的問題,那就是static成
員函數只能訪問static成員。解決此問題的一種途徑是能夠在調用類靜態成員函數(線程函數)時將this
指針做爲參數傳入,並在改線程函數中用強制類型轉換將this轉換成指向該類的指針,經過該指針訪問非
靜態成員。
 
(2)不定義類成員函數爲線程函數,而將線程函數定義爲類的友元函數。這樣,線程函數也能夠有類
成員函數同等的權限;  
咱們將程序修改成:
#include "windows.h" 
#include <process.h>
編譯器

class ExampleTask   
 
  public:  
   friend void taskmain(LPVOID param);   
   void StartTask(); 
   int value;
};
io

void taskmain(LPVOID param)   
 
  ExampleTask * pTaskMain = (ExampleTask *) param;   
  //經過pTaskMain指針引用 
 
 
void ExampleTask::StartTask()   
 
  _beginthread(taskmain,0,this); 
} 
int main(int argc, char* argv[]) 
{ 
  ExampleTask realTimeTask; 
  realTimeTask.StartTask();
編譯

  return 0; 
}
function

相關文章
相關標籤/搜索