91在线观看视频-91在线观看视频-91在线观看免费视频-91在线观看免费-欧美第二页-欧美第1页

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

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

3天內不再提示

利用靜態分析工具構建模型實現多核處理器的高質量軟件

星星科技指導員 ? 來源:嵌入式計算設計 ? 作者:Paul Anderson ? 2022-06-19 07:52 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

對多核處理器進行編程以利用其強大功能意味著編寫多線程代碼。C 和 C++ 不是為并發而設計的,因此開發人員必須為這些語言使用諸如 pthreads 之類的庫。由于全新類別的編程缺陷帶來的風險,多線程代碼比單線程代碼更難正確處理。

在流氓的并發錯誤庫中,競爭條件是臭名昭著的屢犯者。競爭條件發生在程序檢查資源屬性并假設該屬性沒有更改的情況下執行操作,即使外部參與者已經介入并更改了該屬性。

數據競爭是一種特殊類型的競爭條件,它涉及對多線程程序中內存位置的并發訪問。當有兩個或多個執行線程訪問共享內存位置,至少一個線程正在更改該位置的數據,并且沒有明確的協調訪問機制時,就會出現此缺陷。如果發生數據競爭,它會使程序處于不一致的狀態。

數據競爭的陰險本質

人們普遍認為,一些數據競爭是無害的,可以安全地忽略。不幸的是,這僅在極少數情況下是正確的。最好通過舉例說明原因。

單例模式是一種常見的習慣用法,其中程序維護對單個底層對象的引用,如果已初始化,則布爾變量對其進行編碼。這種模式也稱為延遲初始化。以下代碼是該模式的示例:

if (!initialized) {

object = create();

initialized = true;

}

。。. 目的 。。.

這段代碼完全適合單線程程序,但它不是線程安全的,因為它在名為initialized的變量上存在數據競爭。如果由兩個不同的線程調用,則存在兩個線程幾乎同時觀察到初始化為 false 的風險,并且都將調用create(),從而違反了單例屬性。

為了使這個線程安全,自然的方法是用鎖保護整個if語句。然而,獲取和釋放鎖的成本可能很高,因此程序員試圖通過使用雙重檢查鎖定習慣用法來避免這種成本——在鎖范圍之外進行檢查,在鎖范圍內進行檢查。內部檢查用于確認在獲得鎖后第一個檢查仍然有效:

if (!initialized) {

lock();

if (!initialized) {

object = create();

initialized = true;

}

unlock();

}

。。. 目的 。。.

從表面上看,這看起來就足夠了,實際上,只要保證語句按該順序執行就足夠了。但是,優化編譯器可能會生成實質上切換object = create()和initialized = true順序的代碼。畢竟,這兩個語句之間沒有明確的依賴關系。在這種情況下,如果第二個線程在分配給initialized之后的任何時間進入此代碼,則該線程將在object被初始化之前使用它的值。

優化編譯器是不可思議的野獸。那些優化速度的人會考慮許多深奧的考慮,其中很少有對程序員來說是顯而易見的。他們通常會生成明顯無序的指令,因為這樣做可能會導致更少的高速緩存未命中,或者因為需要更少的指令。

假設因為重新排序在前面的示例中引入了競爭條件,所以認為編譯器有問題是錯誤的。編譯器正在做它被允許做的事情。語言規范對此非常清楚和明確:允許編譯器假設程序中沒有數據競爭。

實際上,規范更廣泛:允許編譯器在存在未定義行為的情況下做任何事情。這有時被開玩笑地稱為著火語義;如果程序具有未定義的行為,該規范允許編譯器將計算機置于火上。除了數據競爭之外,緩沖區溢出、無效地址的取消引用等許多傳統錯誤也構成了未定義的行為。因為編譯器可以自由地做任何事情,而不是燒毀建筑物,他們通常會做明智的事情,即假設未定義的行為永遠不會發生并相應地進行優化。

即使對于并發和編譯器方面的專家來說,這樣做的后果有時也會令人驚訝。很難讓程序員相信看起來完全正確的代碼可以編譯成有嚴重錯誤的代碼。

另一個例子是值得描述的。假設有兩個線程,一個讀取共享變量,另一個寫入共享變量。讓我們假設讀者在寫入者更改之前或之后看到該值并不重要(這不是一種不常見的模式)。如果這些訪問不受鎖保護,那么顯然存在數據競爭。然而,盡管著火規則,大多數程序員會得出結論,這是完全良性的。

事實證明,至少有兩種合理的方式可以編譯這段代碼,讀者會看到錯誤的值。第一種方法很容易解釋:假設該值是一個只能讀取 32 位字的架構上的 64 位數量。那么讀者和作者都需要兩條指令,不幸的交錯可能意味著讀者看到舊值的前 32 位和新值的后 32 位,當它們組合時可能不是舊值也不是新的。

生成錯誤代碼的第二種方式更為微妙。假設讀者做了以下事情,其中??數據競爭在名為global的變量上:

int local = global; // Take a copy of

// the global

if (local == something) {

。..

}

。.. // Some non-trivial code that does

// not change global or local

if (local == something) {

。..

}

在這里,讀者正在制作 racy 變量的本地副本并引用該值兩次??梢院侠淼仄谕麅蓚€地方的值相同,但同樣,優化編譯器可以生成未滿足期望的代碼。如果將local分配給一個寄存器,那么它將有一個值用于第一次比較,但如果兩個條件之間的代碼足夠重要,那么該寄存器可能會溢出——換句話說,為了不同的目的而重用。在這種情況下,在第二個條件下,local的值將從全局變量重新加載到寄存器中,此時編寫器可能已將其更改為不同的值。

程序員應該非常懷疑某些數據競爭是可以接受的,并且應該努力從他們的代碼中找到并刪除它們。

發現風險缺陷的技術

在發現并發缺陷時,傳統的動態測試技術可能不夠用。一個通過一百次測試的程序并不能保證下一次通過,即使是相同的輸入和相同的環境。這些錯誤是否出現對時間非常敏感,線程中的操作交錯的順序本質上是不確定的。

用于發現數據競爭的新動態測試技術正在出現。這些技術通過在應用程序執行時監視它們并觀察每個線程持有的鎖以及這些線程正在訪問的內存位置來工作。如果發現異常,則發出診斷。其他工具有助于診斷可能導致故障的數據競爭。一些公司現在提供工具來促進數據競爭的診斷,從而允許重播導致異常的事件。

靜態分析工具也可用于查找數據競爭和其他并發錯誤。動態測試工具會發現針對具有固定輸入集的程序的特定執行出現的缺陷,而靜態分析工具會檢查所有可能的執行和所有可能的輸入。出于性能原因,工具可能會限制進行多少探索,因此可能并不完全詳盡;即便如此,它們可以涵蓋的范圍遠遠超過動態測試所能實現的范圍。靜態分析的優點是不需要測試用例,因為程序從未真正執行過。

相反,這些工具通過創建程序模型然后以各種方式探索模型以發現異常來工作。GrammaTech 的 CodeSonar 通過創建表示每個線程持有的鎖集的模型并通過執行探索執行路徑的程序的符號執行來發現數據競爭。它記錄受鎖保護的變量集,并使用此信息來查找可能導致共享變量在沒有適當同步的情況下使用的交錯。類似的技術可用于發現其他并發缺陷,例如死鎖和鎖管理不善。

一旦發現,數據競爭通常很容易修復,盡管這樣做會導致性能損失。在某些情況下,可能會嘗試使用 C 中的 volatile 關鍵字來糾正數據爭用,但不建議這樣做,因為 volatile 并非旨在解決并發問題,并且在任何情況下都是一個難以理解的構造,經常被錯誤編譯。最新版本的 C 和 C++ 包含并發并支持原子操作。對這些操作的編譯器支持正在慢慢出現,在它變得可用之前,最好的方法是使用鎖。

為了實現多核處理器的高質量軟件,建議對數據競爭采取零容忍政策。使用靜態和動態技術的組合來查找它們,并注意不要過度依賴深奧的編譯器技術來修復它們。這些缺陷是如此危險和不可預測,因此系統地消除它們是確保它們不會造成傷害的唯一安全方法。

審核編輯:郭婷

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

    關注

    68

    文章

    19896

    瀏覽量

    235222
  • C++
    C++
    +關注

    關注

    22

    文章

    2119

    瀏覽量

    75315
  • 編譯器
    +關注

    關注

    1

    文章

    1662

    瀏覽量

    50222
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    新能源變革之路,要建在“高質量”的路基上

    高質量”是能源革命的前提與基座
    的頭像 發表于 06-24 11:42 ?1714次閱讀
    新能源變革之路,要建在“<b class='flag-5'>高質量</b>”的路基上

    MBSE工具+架構建模:從效率提升到質量賦能

    MBSE解決方案,以架構建模為紐帶,工具鏈集成為支撐,幫助客戶有效應對汽車電子系統日益增長的復雜性挑戰。通過打破信息孤島、實現變更協同、提升工具鏈流暢度,加速開發進程、降低返工成本、提
    的頭像 發表于 06-20 10:57 ?180次閱讀
    MBSE<b class='flag-5'>工具</b>+架<b class='flag-5'>構建模</b>:從效率提升到<b class='flag-5'>質量</b>賦能

    您的模型診斷專家MI:助力把好模型質量

    Model Inspector是一款專門針對汽車、航空、軌交等行業的靜態模型檢查工具,可以對模型進行自動化、批量化建模規范和復雜度量的檢查,
    的頭像 發表于 06-11 16:57 ?878次閱讀
    您的<b class='flag-5'>模型</b>診斷專家MI:助力把好<b class='flag-5'>模型</b><b class='flag-5'>質量</b>關

    CADENAS 數字產品配置輕松實現Ascendor電梯規劃

    的客戶提供了符合國際標準的高質量數據。電梯制造商的經銷商在為客戶提供咨詢和處理訂單時,也因這款工具而得到了大力支持。 數字產品配置有助于推動業務擴張 對于 Ascendor 公司
    發表于 04-28 14:22

    異形拼接處理器可以實現的效果

    異形拼接處理器可以實現的效果非常多樣化和創新,以下是對其可實現效果的進一步補充: 一、創意拼接顯示 1、任意角度拼接:異形拼接處理器支持0~360度任意角度的拼接顯示,使得顯示屏可以以
    的頭像 發表于 03-21 12:39 ?253次閱讀
    異形拼接<b class='flag-5'>處理器</b>可以<b class='flag-5'>實現</b>的效果

    電動工具EMC測試整改:邁向高質量生產的必由之路

    深圳南柯電子|電動工具EMC測試整改:邁向高質量生產的必由之路
    的頭像 發表于 02-27 09:37 ?401次閱讀
    電動<b class='flag-5'>工具</b>EMC測試整改:邁向<b class='flag-5'>高質量</b>生產的必由之路

    廣汽集團召開高質量發展大會

    春回大地,萬象更新。近兩日廣東省、廣州市聚焦“建設現代化產業體系”主題,相繼召開“新春第一會”——高質量發展大會,吹響奮進號角。廣汽集團黨委書記、董事長馮興亞作為省市重點產業高質量發展代表參加會議,與產學研各界代表共聚一堂,共繪廣東、廣州
    的頭像 發表于 02-07 10:18 ?602次閱讀

    電動工具EMC測試整改:邁向高質量生產的必經之路

    深圳南柯電子|電動工具EMC測試整改:邁向高質量生產的必經之路
    的頭像 發表于 01-14 14:29 ?518次閱讀
    電動<b class='flag-5'>工具</b>EMC測試整改:邁向<b class='flag-5'>高質量</b>生產的必經之路

    QorIQ?T1042多核處理器

    QorIQ?T1042多核處理器T1042 QorIQ高級多核處理器綜合了數據網絡、電信/數據通訊、無線網絡基礎設施和國防軍事/航天工程應用所需要的性能卓越數據線路加速及網絡和外圍總線
    發表于 01-10 08:48

    借助谷歌Gemini和Imagen模型生成高質量圖像

    在快速發展的生成式 AI 領域,結合不同模型的優勢可以帶來顯著的成果。通過利用谷歌的 Gemini 模型來制作詳細且富有創意的提示,然后使用 Imagen 3 模型根據這些提示生成
    的頭像 發表于 01-03 10:38 ?899次閱讀
    借助谷歌Gemini和Imagen<b class='flag-5'>模型</b>生成<b class='flag-5'>高質量</b>圖像

    旋智多核處理器助力電機控制應用

    電機控制應用軟件通常需要實時處理,以確保精確控制和快速響應。高性能、多核嵌入式處理器能夠實時處理多項復雜計算,是保持電機控制系統穩定性和準確
    的頭像 發表于 10-24 16:17 ?841次閱讀
    旋智<b class='flag-5'>多核</b>心<b class='flag-5'>處理器</b>助力電機控制應用

    信雅達入選2024年度中國軟件高質量發展前百家企業

    近日,中國軟件行業協會首次發布《中國軟件產業高質量發展報告(2024)》(以下簡稱“報告”),深入分析了我國軟件產業的發展現狀、特點與問題,
    的頭像 發表于 10-22 11:08 ?465次閱讀

    中國算力大會召開,業界首個算力高質量評估體系發布

    首次完整地構建了人工智能時代高質量算力的理論體系,并探索性提出業界首個 "五位一體"的高質量算力評估體系。 發布現場 在當前由大模型和AIGC驅動的AI時代,算力需求暴增,同時還面臨供
    的頭像 發表于 09-28 16:50 ?491次閱讀
    中國算力大會召開,業界首個算力<b class='flag-5'>高質量</b>評估體系發布

    知識分享 | 輕松實現優質建模

    知識分享在知識分享欄目中,我們會定期與讀者分享來自MES模賽思的基于模型軟件開發相關Know-How干貨,關注公眾號,隨時掌握基于模型軟件設計的技術知識。輕松
    的頭像 發表于 09-12 08:08 ?734次閱讀
    知識分享 | 輕松<b class='flag-5'>實現</b>優質<b class='flag-5'>建模</b>

    DevOps中的質量門工作原理,以及靜態代碼分析Klocwork和Perforce Helix QAC在質量門中的實踐應用

    如何使用靜態代碼分析工具(如Klocwork 和 Helix QAC)實現質量門。 什么是質量
    的頭像 發表于 07-29 15:12 ?882次閱讀
    主站蜘蛛池模板: 午夜久久久 | 爱看精品福利视频观看 | 中文字幕一区2区3区 | 中文在线天堂网www 中文在线资源链接天堂 | 成人区精品一区二区毛片不卡 | 永久免费精品影视网站 | 丝袜紧身裙国产在线播放 | 永井玛丽亚中文在线观看视频 | 国产精品视频第一区二区三区 | 午夜一级成人 | 美女大黄三级视频在线观看 | 34pao强力打造免费永久视频 | 四虎8848精品永久在线观看 | 成人国产精品高清在线观看 | 韩国理论三级在线观看视频 | 久久男女 | 久久综合九色综合98一99久久99久 | 色五阁| 手机在线黄色 | 夜夜操夜夜骑 | 夜夜爽影院| 狠狠狠| 久久精品亚洲青青草原 | 激情六月丁香婷婷 | 丁香激情小说 | 黄色大全片 | www.天天射.com| 亚洲国产色图 | 二级特黄绝大片免费视频大片 | 久久伊人操 | 手机在线看片你懂的 | 免费中国jlzzjlzz在线播放 | 六月丁香深爱六月综合激情 | 亚洲欧洲一区二区三区在线 | 久久五月女厕所一区二区 | 精品国产第一国产综合精品gif | 精品久久久久久国产免费了 | 免费人成a大片在线观看动漫 | 影音先锋色偷偷米奇四色 | 五月天亚洲婷婷 | 亚洲码欧美码一区二区三区 |