色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何理解線程安全?

Linux大陸 ? 來源:Linux大陸 ? 2023-05-08 15:03 ? 次閱讀

大家好,我是LinuxZn。

本次分享線程安全的基礎知識。

線程安全

在多線程編程中,線程安全是必須要考慮的因素。

什么是線程安全?

在多線程環境中,多個線程在同一時刻對同一份資源進行寫操作時,不會出現數據不一致。反之,則是線程非安全的。

線程安全是程序設計中的術語,指某個函數、函數庫在多線程環境中被調用時,能夠正確地處理多個線程之間的公用變量,使程序功能正確完成。

為了確保在多線程環境中的線程安全,就要確保數據的一致性。確保線程安全的幾種方法:

使用互斥鎖

一個線程,如果需要訪問公共資源,需要獲得互斥鎖并對其加鎖,資源在在鎖定過程中,如果其它線程對其進行訪問,也需要獲得互斥鎖,如果獲取不到,線程只能進行阻塞,直到獲得該鎖的線程解鎖。關于互斥鎖的使用:Hello系列 | 多線程編程基礎!

例子(來源:維基百科):

#include

intincrement_counter(void)
{
staticintcounter=0;
staticpthread_mutex_tmutex=PTHREAD_MUTEX_INITIALIZER;

pthread_mutex_lock(&mutex);

//onlyallowonethreadtoincrementatatime
++counter;
//storevaluebeforeanyotherthreadsincrementitfurther
intresult=counter;

pthread_mutex_unlock(&mutex);

returnresult;
}

這個函數是線程安全的,可以在多個線程中被調用。

使用原子操作

上面的例子中,使用一個 互斥鎖來保護一次簡單的增量操作顯然過于昂貴,我們可以使用一些專門的原子操作API函數來替代。如上述例子,c++11中的原子變量提供了一個可使此函數既線程安全又可重入(而且還更簡潔)的替代方案:

#include

intincrement_counter(void)
{
staticstd::atomiccounter(0);

//incrementisguaranteedtobedoneatomically
intresult=++counter;

returnresult;
}

Linux內核中原子整形操作:

#include

intincrement_counter(void)
{
atomic_tcounter=ATOMIC_INIT(0);

//incrementisguaranteedtobedoneatomically
atomic_inc(&counter);
intresult=counter;

returnresult;
}

什么是原子操作?

從字面上簡單理解,原子是一種很微小的粒子;原子操作是不能再進一步細分的操作。

從上面互斥鎖的例子來看,在線程層面,線程1和線程2同時調用了increment_counter函數,被 mutex 保護的操作是原子操作,lock、unlock及保護部分要整體順序運行,不可再進一步細分,作為一個原子存在 。

如果確定某個操作是原子的,并且有原子操作API函數可以使用,就不用為了去保護這個操作而加上會耗費昂貴性能開銷的鎖。

如,Linux內核原子整形操作 API 函數表(來源:正點原子) :

95134a9a-ecf0-11ed-90ce-dac502259ad0.png

防止過度優化

線程安全的函數應該為每個調用它的線程分配專門的空間,把多個線程共享的變量正確對待(如,通知編譯器該變量為“易失(volatile)”型,阻止其進行一些不恰當的優化)。

線程安全函數與可重入函數?

先明確概念:

線程安全函數:能夠正確地處理多個線程之間的公用變量的函數。、

可重入函數:在任意時刻被中斷然后操作系統調度執行另一段代碼,這段代碼又使用了該副程序不會出錯。

可重入函數應當滿足條件:

不能含有靜態(全局)非常量數據。

不能返回靜態(全局)非常量數據的地址。

只能處理由調用者提供的數據。

不能依賴于單例模式資源的鎖。

調用(call)的函數也必需是可重入的。

可重入函數未必是線程安全的;線程安全函數未必是可重入的。

例子1:上述例子中的increment_counter函數是線程安全的,但是并不是可重入的。因為使用了互斥鎖,如果這個函數用在可重入的中斷處理程序中,如果在pthread_mutex_lock(&mutex)和pthread_mutex_unlock(&mutex)之間產生另一個調用函數increment_counter的中斷,則會第二次執行此函數,此時由于mutex已被lock,函數會在pthread_mutex_lock(&mutex)處阻塞,并且由于mutex沒有機會被unlock,阻塞會永遠持續下去。

例子2:一個函數打開某個文件并讀入數據。這個函數是可重入的,因為它的多個實例同時執行不會造成沖突;但它不是線程安全的,因為在它讀入文件時可能有別的線程正在修改該文件,為了線程安全必須對文件加“同步鎖”。

審核編輯:湯梓紅
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 編程
    +關注

    關注

    88

    文章

    3614

    瀏覽量

    93686
  • 中斷
    +關注

    關注

    5

    文章

    898

    瀏覽量

    41471
  • 函數
    +關注

    關注

    3

    文章

    4327

    瀏覽量

    62573
  • C++
    C++
    +關注

    關注

    22

    文章

    2108

    瀏覽量

    73622
  • 線程安全
    +關注

    關注

    0

    文章

    13

    瀏覽量

    2458

原文標題:如何理解線程安全?

文章出處:【微信號:Linux大陸,微信公眾號:Linux大陸】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    不同創建線程安全Set的方式

    線程安全的問題,真的算是老生常談了。這幾天看到一個 HashSet 線程安全的騷操作,在這里分享給大家。 在本文中,我們將分享如何構造線程
    的頭像 發表于 09-25 14:20 ?652次閱讀

    調用非安全線程的dll的問題

    在調用非線程安全的dll時,是不是要選擇在UI線程中運行?是不是還必須用不可重入的子VI封裝一下?上述的兩步是不是都要做?這些問題不是很清楚,還請各位大神指點一下
    發表于 03-14 21:13

    Linux下的線程安全是什么

    Linux下的線程安全原文結構有點亂線程安全:多個執行流對臨界資源進行爭搶訪問,而不會造成數據二義性和邏輯混亂,成這段代碼的過程是線程
    發表于 07-01 13:34

    什么是線程安全?如何去實現線程安全

    什么是線程安全?如何去實現線程安全?互斥實現的技術是什么?有哪些注意事項?同步實現的技術是什么?其操作流程有哪些?
    發表于 07-23 09:57

    請教大神rtthread中的ringbuff是線程安全的嗎

    最近想用輕量級的ringbuff,請教大神rtthread中的ringbuff是線程安全的嗎?
    發表于 07-29 10:44

    什么是線程安全

    線程安全的鏈表-隊列-棧,就是多線程同時操作(包括查找、添加、刪除等)鏈表、隊列或棧,無論如何操作,就是多線程同時操作(包括查找、添加、刪除等)鏈表、隊列或棧,無論如何操作,都不會產生
    發表于 11-17 11:16 ?1次下載

    解決線程安全問題技巧匯總

    線程,有時被稱為輕量級進程,是程序執行流的最小單元。一個標準的線程線程ID,當前指令指針(PC),寄存器集合和堆棧組成。另外,線程是進程中的一個實體,是被系統獨立調度和分派的基本單位
    發表于 12-01 13:42 ?1580次閱讀

    java的線程安全、單例模式、JVM內存結構

    線程安全就是多線程訪問時,采用了加鎖機制,當一個線程訪問類的某個數據時,進行保護,其他線程不能進行訪問直到該
    發表于 03-12 10:30 ?0次下載

    什么是線程安全 如何實現線程安全代碼

    相信有很多同學在面對多線程代碼時都會望而生畏,認為多線程代碼就像一頭難以馴服的怪獸,你制服不了這頭怪獸它就會反過來吞噬你。
    的頭像 發表于 05-17 12:45 ?1617次閱讀

    理解析:線程池中多余的線程是如何回收的?

    最近閱讀了JDK線程池ThreadPoolExecutor的源碼,對線程池執行任務的流程有了大體了解,實際上這個流程也十分通俗易懂,就不再贅述了,別人寫的比我好多了。
    的頭像 發表于 11-11 09:57 ?953次閱讀

    什么是線程安全?如何理解線程安全

    在多線程編程中,線程安全是必須要考慮的因素。
    的頭像 發表于 05-30 14:33 ?2066次閱讀
    什么是<b class='flag-5'>線程</b><b class='flag-5'>安全</b>?如何<b class='flag-5'>理解</b><b class='flag-5'>線程</b><b class='flag-5'>安全</b>?

    線程安全怎么辦

    線程安全一直是多線程開發中需要注意的地方,可以說,并發安全保證了所有的數據都安全。 1 線程
    的頭像 發表于 10-10 15:00 ?364次閱讀
    <b class='flag-5'>線程</b><b class='flag-5'>安全</b>怎么辦

    如何知道你的代碼是否線程安全

    在并發編程時,如果多個線程訪問同一資源,我們需要保證訪問的時候不會產生沖突,數據修改不會發生錯誤,這就是我們常說的 線程安全 。 那什么情況下,訪問數據時是安全的?什么情況下,訪問數據
    的頭像 發表于 11-01 11:42 ?703次閱讀
    如何知道你的代碼是否<b class='flag-5'>線程</b><b class='flag-5'>安全</b>

    redis多線程還能保證線程安全

    Redis是一種使用C語言編寫的高性能鍵值存儲系統,它是單線程的,因為使用了多路復用的方式來處理并發請求。這樣的實現方式帶來了很好的性能,但同時也引發了一些線程安全方面的問題。 在Redis中,由于
    的頭像 發表于 12-05 10:28 ?1797次閱讀

    摩爾線程正式開源音頻理解大模型MooER

    近日,國內領先的GPU創新企業摩爾線程宣布了一項重大技術突破——正式開源其自主研發的音頻理解大模型MooER(摩耳)。這一舉動標志著我國在音頻處理與理解領域邁出了堅實的一步,特別是在基于國產硬件的AI模型研發上取得了顯著成就。
    的頭像 發表于 08-27 15:24 ?495次閱讀
    主站蜘蛛池模板: 91popny蜜桃臀| 含羞草在线| 欧洲最强rapper潮水喷视频| 伊人精品久久久大香线蕉99| 国产乱码免费卡1卡二卡3卡四卡| 日本污ww视频网站| 99热久久视频只有精品6| 辣文肉高h粗暴| 孕妇泬出白浆18P| 久久国产精品萌白酱免费| 亚洲精品无码一区二区三区四虎| 国产精品久久久久久久久无码| 色噜噜狠狠色综合欧洲| 成视频高清| 青青草原影视| 北条麻妃のレズナンパ| 欧美性色xo影院69| 扒开美女下面粉嫩粉嫩冒白浆| 强奷表妺好紧2| xxx在线播放| 人人干人人看| 成人亚洲视频在线观看| 日日踫夜夜爽无码久久| 国产99久久久国产精品成人 | 久久视频精品3线视频在线观看 | 成人精品视频在线观看播放| 欧美亚洲日韩一道免费观看| chinese耄耋70老太性| 欧美一道本一区二区三区| xxx免费观看| 色悠久久久久综合欧美99| 国产成人a一在线观看| 午夜国产福利| 国内精品视频一区二区在线观看 | 羞羞漫画免费漫画页面在线看漫画秋蝉 | 国产精品人妻无码久久久蜜桃臀| 桃花在线观看播放| 国产精品无码久久av| 亚洲精品AV无码喷奶水糖心| 精品一区二区三区免费毛片| 中文日韩亚洲欧美字幕|