可重入函式

2021-09-19 16:35:41 字數 471 閱讀 3608

在實時系統的設計中,經常會出現多個任務呼叫同乙個函式的情況,例如我們經常使用的執行緒經常要關心它是否為執行緒安全的函式。如果它不是乙個可重入函式的話,如果多方呼叫,可能會更改其他呼叫這個函式的值,從而導致不可預料的後果。而可重入函式可以同時被乙個以上的函式呼叫而不會擔心資料被破壞。

滿足下列情況的是不可重入:

1、使用了全域性變數或者靜態區域性變數;

2、部分系統庫呼叫由於是不可重入的,呼叫了也是不可重入,比如malloc()、free();

3、函式體內呼叫了標準i/o函式;

在函式體內不訪問那些全域性變數,不使用靜態區域性變數,堅持只使用區域性變數,寫出的函式就將是可重入的。如果必須訪問全域性變數,記住利用互斥鎖來保護全域性變數。或者呼叫該函式前關中斷,呼叫後再開中斷

乙個簡單的不可重入例子:

void swapchar2(char *lpcx,char *lpcy) 

可重入函式 可重入核心

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

可重入核心 可重入函式

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

可重入函式

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