簡單寫一下android
對線程
的c++封裝~~~其實API已經寫得很清楚了~~
封裝
的檔案
:/frameworks/base/include/utils/threads.h
這裡不討論具體實現,具體實現是和系統
相關聯的~~首先Anroid提供了幾個與直接建立線程的函數:
inline bool createThread(thread_func_t f, void *a)
inline bool createThreadEtc(thread_func_t entryFunction,
void *userData,
const char* threadName = "android:unnamed_thread",
int32_t threadPriority = PRIORITY_DEFAULT,
size_t threadStackSize = 0,
thread_id_t *threadId = 0)
inline thread_id_t getThreadId()
下面看看Android的mutex,基本和posix的mutex很像,唯一增加了一個Mutex::Autolock,這個自動鎖用得是比較多的,在範圍裡加鎖,脫離範圍就會自動解鎖。
class Autolock {
public:
inline Autolock(Mutex& mutex) : mpMutex(&mutex) { mutex.lock(); }
inline Autolock(Mutex* mutex) : mpMutex(mutex) { mutex->lock(); }
inline ~Autolock() { mpMutex->unlock(); }
private:
Mutex* mpMutex;
};
再看看Andorid的Condition,用法基本和posix差不多,因為本身是條件變數所以只有一個mutex參數~~
最後看看android的thread類,在實際使用的過程中都是繼承這個thread類來建立自己的thread類,並定義線程的執行內容,下面主要圍繞建立自己的線程類需要實現的幾個函數說說:
class Thread : virtual public RefBase
首先它繼承自RefBase類,一般在使用的時候要實現onFirstRef()這個父類函數,一般經典
的用法是在裡面運行Thread的run函數,這樣在建立thread的執行個體
的時候就開始運行這個線程了。當然也可以不在這裡執行run()函數,在其他地方執行run()函數啟動這個線程。
virtual status_t run( const char* name = 0,
int32_t priority = PRIORITY_DEFAULT,
size_t stack = 0);
建立一個thread執行個體的時候,線程並沒有運行,只有在執行run()函數的時候,線程才開始真正的開始運行。
virtual status_t readyToRun();
這個函數定義thread執行前的初始化工作
virtual bool threadLoop() = 0;
這個函數是每個線程類都要實現的,在這裡定義thread的執行內容,這個函數如果返回true,則函數會不停地執行threadloop中的內容,如果這個函數返回false,則threadloop中的內容僅僅執行一次線程就會退出。