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搭建sftp出現Write failed:Broken pipe的問題
- linux c++模擬簡易網絡爬蟲實例
- Linux系統下實現遠程連接MySQL數據庫的方法教程
- Python實現Linux的find命令實例分享
- Linux下MySQL5.7.18 yum方式從卸載到安裝過程圖解
- Linux下卸載MySQL數據庫
- linux 網卡配置詳解及實例