可重入函式

2021-07-22 07:23:33 字數 450 閱讀 5184

可重入函式:能夠被多個執行緒『同時』呼叫的函式,並且能夠保證函式結果正確性的函式。

在c語言中編寫可重入函式時,盡量不要使用全域性變數或靜態變數,如果使用了全特別注意局變數或靜態變數,就需要注意對這類變數訪問的互斥。

一般採用以下幾種措施來保證函式的可重入性:訊號量機制,關排程機制,關中斷機制。

不可呼叫不可重入的函式,當呼叫了不可重入的函式時,會使該函式也變為不可重入的函式。一般驅動程式都是不可重入的函式。

保證函式可重入性的方法:

1) 在寫函式時盡量使用區域性變數。

2)對於要使用的全域性變數要加以保護(如採取關中斷、訊號量等方法),這樣構成的函式就一定是乙個可重入的函式。

滿足下列的函式多數是不可重入的:

1)函式體內使用了靜態的資料結構。

2)函式體內呼叫了malloc()或者free()函式。

3)函式體內呼叫了標準i/o函式。

可重入函式 可重入核心

可重入函式這一概念早有接觸,但一直未有系統的理解,最近閱讀 apue 訊號一章時,其中講解很到位,故總結如下。訊號作為一種軟中斷,能夠被程序給捕獲,因而也就中斷程序的正常執行,轉而去執行訊號處理程式,最後再返回到原程序繼續正常執行。然而,當程序正在執行 malloc 動態記憶體分配時,訊號產生從而轉...

可重入核心 可重入函式

可重入核心在ulk 深入理解linux核心 中的定義是指若干個程序可以同時在核心態下執行,也就是說多個程序可以在核心態下併發執行核心 在單處理器上,只能實現 微觀上的序列,巨集觀上的並行,即任意時刻,只有乙個進 正執行,其他程序處於阻塞或者等待狀態。這裡的可重入,是指可以多個程序進入核心,並不是重複...

可重入函式

在實時系統的設計中,經常會出現多個任務呼叫同乙個函式的情況。如果這個函式不幸被設計成為不可重入的函式的話,那麼不同任務呼叫這個函式時可能修改其他任務呼叫這個函式的資料,從而導致不可預料的後果。那麼什麼是可重入函式呢?所謂可重入函式是指乙個可以被多個任務呼叫的過程,任務在呼叫時不必擔心資料是否會出錯。...