天天看點

使用pthread後,界面假死現象問題

最近用QT做界面,通過點選按鈕開啟多個線程,但由于多個子線程運作時間較長,導緻了界面出現假死現象

原因:多線程建立後直接使用了pthread_join進而導緻了程式一直停在這裡

解決方法:在使用pthread_join之前,使用pthread_detach操作即可

具體原因請看一下解釋(從網上找的,但真的起作用了):

  在任何一個時間點上,線程是可結合的(joinable)或者是分離的(detached)。一個可結合的線程能夠被其他線程收回其資源和殺死。在被其他線程回收之前,它的存儲器資源(例如棧)是不釋放的。相反,一個分離的線程是不能被其他線程回收或殺死的,它的存儲器資源在它終止時由系統自動釋放。

    預設情況下,線程被建立成可結合的。為了避免存儲器洩漏,每個可結合線程都應該要麼被顯示地回收,即調用pthread_join;要麼通過調用pthread_detach函數被分離。

[cpp]

int pthread_join(pthread_t tid, void**thread_return); 

                                 若成功則傳回0,若出錯則為非零。 

int pthread_join(pthread_t tid, void**thread_return);

                                 若成功則傳回0,若出錯則為非零。    線程通過調用pthread_join函數等待其他線程終止。pthread_join函數分阻塞,直到線程tid終止,将線程例程傳回的(void*)指針指派為thread_return指向的位置,然後回收已終止線程占用的所有存儲器資源。[cpp] view plaincopyprint?int pthread_detach(pthread_t tid); 

                                 若成功則傳回0,若出錯則為非零。 

int pthread_detach(pthread_t tid);

                                 若成功則傳回0,若出錯則為非零。

    pthread_detach用于分離可結合線程tid。線程能夠通過以pthread_self()為參數的pthread_detach調用來分離它們自己。

    如果一個可結合線程結束運作但沒有被join,則它的狀态類似于程序中的Zombie Process,即還有一部分資源沒有被回收,是以建立線程者應該調用pthread_join來等待線程運作結束,并可得到線程的退出代碼,回收其資源。

    由于調用pthread_join後,如果該線程沒有運作結束,調用者會被阻塞,在有些情況下我們并不希望如此。例如,在Web伺服器中當主線程為每個新來的連接配接請求建立一個子線程進行處理的時候,主線程并不希望因為調用pthread_join而阻塞(因為還要繼續處理之後到來的連接配接請求),這時可以在子線程中加入代碼

    pthread_detach(pthread_self())

或者父線程調用

    pthread_detach(thread_id)(非阻塞,可立即傳回)

這将該子線程的狀态設定為分離的(detached),如此一來,該線程運作結束後會自動釋放所有資源。

繼續閱讀