android的線程封裝

封裝文件:/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類,並定義線程的執行內容,下面主要圍繞創建自己的線程類需要實現的幾個函數說說:


/frameworks/base/include/utils/threads.h

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中的內容僅僅執行一次線程就會退出。
發佈了3 篇原創文章 · 獲贊 3 · 訪問量 6萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章