0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

"可重入"和"線程安全"是兩個概念 千萬不要搞混了

Q4MP_gh_c472c21 ? 來源:嵌入式ARM ? 作者:bug菌 ? 2021-02-10 17:38 ? 次閱讀

大伙估計(jì)在多任務(wù)程序中使用printf打印一些信息是非常歡樂的一件事,運(yùn)氣不錯的話偶爾錯幾個數(shù)據(jù)、亂幾個碼也不是什么大問題,倒霉點(diǎn)的可能就直接掛機(jī)、卡死了,那這些到底是什么原因?qū)е碌哪兀? 今天的這篇文章應(yīng)該可以幫助你解決一大部分問題。

01

兩個概念

1、可重入函數(shù) 多任務(wù)系統(tǒng)中每個進(jìn)程或線程都是由多種執(zhí)行流并發(fā)運(yùn)行的,當(dāng)執(zhí)行流同時進(jìn)入同一個函數(shù)(大部分是由于中斷),而不會導(dǎo)致函數(shù)結(jié)果不確定或者錯誤,就可認(rèn)為該函數(shù)是可重入的。

a2100dc0-5f65-11eb-8b86-12bb97331649.png

上圖中的signal一般都是因?yàn)橹袛嗟仍虍a(chǎn)生的,在我們多任務(wù)系統(tǒng)中中斷更是無時無刻的在隨機(jī)發(fā)生著,一旦線程或者進(jìn)程被中斷轉(zhuǎn)而去執(zhí)行消息處理,而恰巧的是此時線程所執(zhí)行的操作與信號處理相同,比如malloc,他們都共享同一個資源(全局堆空間)。 當(dāng)信號處理返回到原來的執(zhí)行流中卻由于信號處理的改寫而受影響,比如重入的問題導(dǎo)致malloc會分配相同的內(nèi)存區(qū)域,或者其他的數(shù)據(jù)篡改,鎖死等,這樣該函數(shù)就是不可重入的。 2、線程安全 多個線程并發(fā)運(yùn)行且執(zhí)行相同的代碼,而不會導(dǎo)致運(yùn)行結(jié)果受影響,我們就認(rèn)為是線程安全。

a2b2c6e6-5f65-11eb-8b86-12bb97331649.png

對于線程安全往往加個互斥鎖就可以解決戰(zhàn)斗,當(dāng)然你如果沒有使用全局變量、靜態(tài)變量等等共享資源,那他們基本上是線程安全的。 其實(shí)從表面上看這兩個概念并沒有太大的差異,無非就是運(yùn)行同一塊代碼,會不會導(dǎo)致不確定的結(jié)果。 3、VS 再仔細(xì)想想,其實(shí)這兩個概念所關(guān)注的層面是不同的,可重入函數(shù)要求相同執(zhí)行流執(zhí)行不會受影響,而線程安全僅僅只是在線程這個層面上進(jìn)行的要求。 所以可重入的要求比線程安全要更加嚴(yán)苛,可重入必定線程安全,而線程安全并不一定可重入,如下圖是他們的關(guān)系:

a64389d0-5f65-11eb-8b86-12bb97331649.png

02

不可重入死鎖

下面我們來簡單分析一下不可重入死鎖的問題 :

a9f66ade-5f65-11eb-8b86-12bb97331649.png

上圖我們?yōu)楹瘮?shù)加了互斥lock(不考慮遞歸鎖),那么它就是線程安全的,然而剛把共享資源部分上鎖,隨機(jī)的中斷信號處理發(fā)生了,轉(zhuǎn)而執(zhí)行信號處理函數(shù),而在信號處理中也同樣執(zhí)行相同的Fuction代碼,此時資源已經(jīng)鎖住,必須等待前面調(diào)用Fuction函數(shù)的線程釋放,但此線程又在等待信號處理訪問,最終死鎖,涼涼! 當(dāng)然你可以使用遞歸鎖來進(jìn)行處理,這在正常設(shè)計(jì)中是需要避免的,當(dāng)時對于一些需要調(diào)用外部庫的設(shè)計(jì),只能選擇遞歸鎖等。

03

可重入的識別

說實(shí)在對于很多玩RTOS的伙計(jì),直接關(guān)中斷、開中斷的臨界資源保護(hù)就基本告別了一部分不可重入問題,而這樣的操作會影響多任務(wù)的并發(fā)執(zhí)行,但是如果你只是加了幾把鎖,可能在程序中不重入的問題還是要注意一下。 這里不可重入問題不完全總結(jié)了幾點(diǎn):

1、標(biāo)準(zhǔn)IO函數(shù)都會使用到全局的數(shù)據(jù)結(jié)構(gòu),比如printf函數(shù) : 由于使用了全局標(biāo)準(zhǔn)輸出stdout,所以線程不安全也就更不能重入了。

2、malloc和free : 這兩個函數(shù)都是在全局的堆空間上進(jìn)行操作,如果有加鎖那就是線程安全的,但是不可重入。

3、對于全局、靜態(tài)的資源的訪問都會導(dǎo)致線程不安全,比如一些函數(shù)使用的是靜態(tài)緩存區(qū)等,你可以使用本地copy加臨界區(qū)來進(jìn)行保護(hù),盡量使用局部變量。

4、調(diào)用不可重入或者線程不安全的函數(shù)也會繼承對應(yīng)特點(diǎn)。

責(zé)任編輯:xj

原文標(biāo)題:同事"可重入"與"線程安全"老分不清,導(dǎo)致一堆bug!

文章出處:【微信公眾號:嵌入式ARM】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4238

    瀏覽量

    61976
  • BUG
    BUG
    +關(guān)注

    關(guān)注

    0

    文章

    155

    瀏覽量

    15628
  • 線程安全
    +關(guān)注

    關(guān)注

    0

    文章

    13

    瀏覽量

    2452

原文標(biāo)題:同事"可重入"與"線程安全"老分不清,導(dǎo)致一堆bug!

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    軟通動力攜手華為啟動"智鏈險界"計(jì)劃,強(qiáng)化生態(tài)鏈接共啟保險AI新時代

    軟通動力攜子品牌軟通金科受邀參加此次大會,發(fā)表"智馭未來 ? 探索保險AI新業(yè)態(tài)"主旨演講,并攜手華為正式啟動"智鏈險界——保險生態(tài)場景鏈接計(jì)劃&quot
    的頭像 發(fā)表于 09-23 19:22 ?56次閱讀
    軟通動力攜手華為啟動&<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;智鏈險界&<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;計(jì)劃,強(qiáng)化生態(tài)鏈接共啟保險AI新時代

    全方位精準(zhǔn)測量技術(shù)助力:中國經(jīng)濟(jì)加力發(fā)展向前&amp;amp;quot;進(jìn)&amp;amp;quot;

    全方位精準(zhǔn)測量技術(shù)助力:中國經(jīng)濟(jì)加力發(fā)展向前&quot;進(jìn)&quot;
    的頭像 發(fā)表于 07-15 09:53 ?231次閱讀
    全方位精準(zhǔn)測量技術(shù)助力:中國經(jīng)濟(jì)加力發(fā)展向前&<b class='flag-5'>amp</b>;<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;進(jìn)&<b class='flag-5'>amp</b>;<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;

    晶科能源榮獲EUPD Research授予的六項(xiàng)&amp;quot;頂級光伏品牌&amp;quot;稱號

    近日,由權(quán)威調(diào)研機(jī)構(gòu)EUPD Research頒發(fā),晶科能源在巴西、哥倫比亞、墨西哥、智利等拉美主要國家六地區(qū)榮獲 &quot;頂級光伏品牌 &quot;稱號。憑借先進(jìn)的技術(shù)、完善的流程和對卓越的不懈追求,晶科能源將繼續(xù)提升行
    的頭像 發(fā)表于 05-10 09:17 ?365次閱讀
    晶科能源榮獲EUPD Research授予的六項(xiàng)&<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;頂級光伏品牌&<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;稱號

    九聯(lián)科技推出一款&amp;quot;射手座&amp;quot;UMA502-T7物聯(lián)網(wǎng)模組

    在物聯(lián)網(wǎng)技術(shù)飛速發(fā)展的時代背景下,九聯(lián)科技憑借深厚的研發(fā)底蘊(yùn)與創(chuàng)新精神,精心打造出象征著自由探索與勇敢進(jìn)取精神的&quot;射手座&quot;UMA502-T7模組,以昂揚(yáng)之姿挺進(jìn)海外市場,宣告了九聯(lián)科技物聯(lián)網(wǎng)模組國際化進(jìn)程的盛大起航。
    的頭像 發(fā)表于 04-14 09:38 ?756次閱讀

    科沃斯掃地機(jī)器人通過TüV萊茵&amp;quot;防纏繞&amp;quot;和&amp;quot;高效邊角清潔&amp;quot;認(rèn)證

    3月15日,在2024中國家電及消費(fèi)電子博覽會(AWE)上,國際獨(dú)立第三方檢測、檢驗(yàn)和認(rèn)證機(jī)構(gòu)德國萊茵TüV大中華區(qū)(簡稱&quot;TüV萊茵&quot;)為科沃斯款掃地機(jī)器人(型號:DDX14、DDX11)
    的頭像 發(fā)表于 03-17 10:49 ?733次閱讀

    Quanterix宣布Tau217血液檢測被美國FDA授予 &amp;quot;突破性器械 &amp;quot;認(rèn)證

    3月4日,Quanterix宣布其Simoa磷酸化Tau217(p-Tau 217)血液檢測已被美國FDA授予 &quot;突破性器械 &quot;認(rèn)證,可用于阿爾茨海默病 (AD) 的輔助診斷評估。
    的頭像 發(fā)表于 03-12 17:23 ?2020次閱讀

    電池&amp;quot;無&amp;quot;隔膜?SEI新&amp;quot;膜&amp;quot;法!

    枝晶是阻礙鋅基水系電池發(fā)展的一亟待解決的問題。電沉積過程主要包含離子遷移、電還原和電結(jié)晶三步驟。
    的頭像 發(fā)表于 03-11 10:03 ?666次閱讀
    電池&<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;無&<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;隔膜?SEI新&<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;膜&<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;法!

    中創(chuàng)新航榮獲逸動科技2023年度&amp;quot;優(yōu)秀戰(zhàn)略合作伙伴獎&amp;quot;

    近日,中創(chuàng)新航憑借電動船舶領(lǐng)域領(lǐng)先的技術(shù)實(shí)力、卓越的產(chǎn)品質(zhì)量、持續(xù)穩(wěn)定的交付能力以及優(yōu)質(zhì)高效的服務(wù),榮獲逸動科技2023年度&quot;優(yōu)秀戰(zhàn)略合作伙伴獎&quot;。
    的頭像 發(fā)表于 02-29 13:51 ?369次閱讀

    第二代配網(wǎng)行波故障預(yù)警與定位裝置YT/XJ-001:守護(hù)電力線路的超能&amp;amp;quot;哨兵&amp;amp;quot;

    第二代配網(wǎng)行波故障預(yù)警與定位裝置YT/XJ-001:守護(hù)電力線路的超能&quot;哨兵&quot; 電力,如同現(xiàn)代社會的血脈,支撐著我們的生活和工作正常運(yùn)行。然而,一旦這條血脈出現(xiàn)故障,生活和工作
    的頭像 發(fā)表于 01-22 15:11 ?417次閱讀
    第二代配網(wǎng)行波故障預(yù)警與定位裝置YT/XJ-001:守護(hù)電力線路的超能&<b class='flag-5'>amp</b>;<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;哨兵&<b class='flag-5'>amp</b>;<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;

    電流互感器帶&amp;quot;S&amp;quot;和不帶S所表示的含義及區(qū)別

    電流互感器帶&quot;S&quot;和不帶S都是表示測量電流互感器精度等級。在規(guī)定使用條件下,互感器的誤差在該等級規(guī)定的限值之內(nèi)。電力工程中計(jì)量常用的等級有0.2、0.5、0.2S、0.5S等。
    的頭像 發(fā)表于 01-14 10:32 ?1284次閱讀
    電流互感器帶&<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;S&<b class='flag-5'>amp</b>;<b class='flag-5'>quot</b>;和不帶S所表示的含義及區(qū)別

    智慧光迅榮獲2023年&amp;quot;智能物聯(lián)成長力企業(yè)&amp;quot;獎項(xiàng)

    深圳智慧光迅信息技術(shù)有限公司榮獲2023年中國物聯(lián)網(wǎng)產(chǎn)業(yè)大會的&quot;智能物聯(lián)成長力企業(yè)&quot;獎項(xiàng)。
    的頭像 發(fā)表于 12-09 10:21 ?812次閱讀

    程控交流電源開機(jī)顯示&amp;quot;ERR&amp;quot;的原因及解決方法分析

    程控交流電源是一種常見的電源設(shè)備,用于為各種電子設(shè)備提供穩(wěn)定的交流電源。然而,有時候在開機(jī)時,程控交流電源可能會顯示&quot;ERR&quot;的錯誤信息,使得設(shè)備無法正常工作。
    的頭像 發(fā)表于 11-07 11:14 ?1289次閱讀

    R&amp;amp;S攜手Skylo Technologies增強(qiáng)非地面網(wǎng)絡(luò)(NTN)測試服務(wù)

    羅德與施瓦茨(以下簡稱&quot;R&amp;S公司&quot;)攜手Skylo Technologies打造用于Skylo非地面網(wǎng)絡(luò)(NTN)的設(shè)備驗(yàn)收方案。
    的頭像 發(fā)表于 10-20 09:50 ?600次閱讀

    R&amp;amp;S針對FMCW雷達(dá)推出超短距離模擬功能

    羅德與施瓦茨(以下簡稱&quot;R&amp;S公司&quot;)的雷達(dá)測試系統(tǒng)通過模擬真實(shí)的駕駛場景,從而測試基于雷達(dá)的高級駕駛輔助系統(tǒng)(ADAS)和自動駕駛汽車(AD)中使用的毫米波雷達(dá)傳感器。
    的頭像 發(fā)表于 10-20 09:48 ?1077次閱讀

    R&amp;amp;S推出新的W和D頻段射頻專用測試解決方案

    為支持毫米波和亞太赫茲前沿研究,羅德與施瓦茨(以下簡稱&quot;R&amp;S公司&quot;)繼續(xù)推出先進(jìn)的射頻測試測量解決方案。
    的頭像 發(fā)表于 10-11 12:31 ?747次閱讀