您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“Linux中可重入函數與不可重入函數的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Linux中可重入函數與不可重入函數的示例分析”這篇文章吧。
Linux 中可重入函數與不可重入函數詳解
可重入函數和不可重入函數說起來有點拗口,其實寫過多進程(線程)程序的人肯定很快就能明白這兩種函數是個神馬東西。下面是我對這兩個函數的理解:
可重入函數可以理解為是能被中斷的函數,并且它被中斷返回后也不會出現什么錯誤。
不可重入函數可以理解為如果函數被中斷的話,就會出現不可預料的錯誤。這是因為函數中使用了一些系統資源,比如全局變量區,中斷向量表之類的。比如多個進程同時對一個文件進行寫操作,如果沒有同步機制的話,對文件的寫入就會變得難以控制。
在多進程(線程)環境中一定要考慮到函數的可重入性。
例如下面的例子:
int sum( int count) { static int sum = 0; int i = 0; for (i= 1; index <= count; i++) sum += i; return sum; }
這段代碼中使用了static關鍵字,如果多個進程同時執行這一段代碼的話就會出現不可預測的結果。在可重入函數中,一定要避免使用static變量。或者需要使用一定的同步原則才可以。
要想將上面的代碼改為可重入函數,只要將static變量改為非static的變量就可以了。
在編寫可重入函數時,如果函數中使用到了全局變量,則應通過關中斷、信號量(即P、V操作)等手段對其加以保護,在函數體中盡量使用局部變量。
以上是“Linux中可重入函數與不可重入函數的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。