歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Unix知識 >> Unix資訊

靈活運用Unix 線程知識

今天我們來學習用Unix 線程的知識來解決問題。在 UNIX 編程中,我們會經常使用系統調用來完成期望的功能;而與此同時,我們也需要付出大段的代碼來檢測、輸出錯誤和其他意外情況。

Unix 線程安全是為了避免數據競爭或者數據設置的正確性依賴於多個Unix 線程修改數據的順序。假設你的代碼所在的進程中有多個Unix 線程在同時運行,而這些線程可能會同時運行這段代碼。如果每次運行結果和單線程運行的結果是一樣的,而且其他的變量的值也和預期的是一樣的,就是Unix 線程安全的。

Unix 線程的使用中以下是系統調用失敗的可能原因:

系統可能出現資源短缺或者程序使用的資源可能超過系統為單個程序規定的上限。常見的情況有:程序可能嘗試分配大量內存,或者同時打開很多文件等。
程序執行操作時,可能會由於權限不足而被系統阻止。例如,程序可能會試圖寫一個只讀的文件,或者企圖訪問其他進程的內存空間。 傳入系統調用的參數可能無效,原因可能是用戶提供無效輸入或者程序本身的 bug。例如,程序可能會傳入一個無效的內存地址或者無效的文件描述符。

系統調用還有可能因為程序之外的原因出錯。系統調用訪問硬件的時候經常會有這種情況發生。設備可能會出現異常錯誤或者不支持特定的操作,或者可能會出現磁盤沒有插入驅動器中的情況出現。 系統調用有的時候會被外部事件 ( 如信號等 ) 中斷。這可能不代表真正的調用失敗,但是如果有必要,程序應當重新嘗試執行系統調用。

對於函數來說,在多Unix 線程或有異常控制流的情況下 , 當某個函數運行到中途時 , 控制流 ( 也就是當前指令序列 ) 就有可能被打斷而去執行另一個函數。而這個函數很有可能是它本身。如果在這種情況下不會出現問題 , 比如說數據或狀態不會被破壞,行為確定。那麼這個函數就被稱做 " 可重入 " 的。

在多Unix 線程編程中,有兩種方法使庫函數可以保證其安全。一個是簡單的將合適的代碼使用互斥鎖包起來,這樣可以保證同時只有一個線程執行這一段例程。雖然這種方法大部分情況下都能奏效,但是它的性能卻非常糟糕。而且對於諸如 strtok 函數,該方法就完全不能工作了,因此很多 UNIX 系統都存在 _r 的接口函數。

另一個更好的辦法是確保庫函數可以同時在多個Unix 線程情況下安全的執行。這裡指的不僅僅是帶有後綴 _r 的可重入對等函數;畢竟可重入和線程安全(Thread-Safe)是兩個不同的概念:可重入函數一定是Unix 線程安全的;線程安全的函數可能是重入的,也可能是不重入的;Unix 線程不安全的函數一定是不可重入的。所以諸如 malloc,free 等函數也在此列,屬於Unix 線程安全的庫函數。

當然,如果你在單線程應用程序中使用Unix 線程安全函數會在一定程度上降低性能,所以盡量避免在單線程應用程序中使用它們。

Copyright © Linux教程網 All Rights Reserved