一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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

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

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

講解一下容易導(dǎo)致軟件問題的5種情況以及應(yīng)對措施

工程師鄧生 ? 來源:玩轉(zhuǎn)單片機與嵌入式 ? 作者:風(fēng)雨無阻 ? 2022-09-05 17:05 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

在進行產(chǎn)品開發(fā)或者軟件設(shè)計時,有沒有遇到過下面的這種情況:

程序本來運行的好好的,莫名其妙的就出現(xiàn)了bug,但是還找不到出現(xiàn)bug的規(guī)律?

已經(jīng)驗證好的產(chǎn)品,到客戶那里突然出現(xiàn)了問題?

出現(xiàn)的bug總是莫名其妙,找不到規(guī)律,感覺像“幽靈”一般的存在?

增加了一行無關(guān)的代碼,程序就不能運行了?

其實,有的時候,問題原因會以一種微妙的方式影響代碼的存在,今天我們重點講解一下難以發(fā)現(xiàn)的、容易導(dǎo)致軟件問的5種情況,以及所對應(yīng)的應(yīng)對措施。

01

堆棧溢出

肯定很多程序員都非常了解“堆棧溢出”這種情況。堆棧溢出可能會對數(shù)據(jù)或者指令造成破壞,從而影響程序的正確運行。 并且,發(fā)生堆棧溢出這種錯誤,在嵌入式設(shè)備程序中造成的影響比計算機中更大。通常有以下幾種原因:

1、嵌入式系統(tǒng)通常使用較少的RAM

2、通常沒有可依賴的虛擬內(nèi)存(因為沒有磁盤)

3、基于RTOS任務(wù)的固件設(shè)計使用多個堆棧(每個任務(wù)一個),每個堆棧的大小必須足夠大,以確保不受唯一最壞情況堆棧深度的影響

4、中斷處理程序可能會嘗試使用這些堆棧 在進行相關(guān)測試的時候,有的時候堆棧溢出這種錯誤我們并不能測試出來,這就造成了:經(jīng)過測試驗證的程序,到客戶處突然運行異常了。

為了避免發(fā)生堆棧溢出這種錯誤,我們可以通過自上而下的代碼控制流分析方法,來證明代碼是否會出現(xiàn)堆棧溢出錯誤。

避免措施:

1、確定好自己程序定義的堆棧的全部空間地址;

2、在臨近堆棧的位置,定義固定地址的數(shù)組或者數(shù)據(jù);

3、在程序中實時檢查數(shù)組或者數(shù)據(jù)的值,若發(fā)現(xiàn)數(shù)據(jù)改變,證明發(fā)生了堆棧溢出,增加特殊的處理姿勢:如讓設(shè)備進入到特定的安全模式,或者輸出當(dāng)前的PC地址等。

02

競爭條件

在程序運行過程中,大量的、無序的任務(wù)一直在運行,但是資源是有限的,兩個不同的任務(wù)之間可能就存在競爭資源的情況,由于兩個或者多個進程競爭使用不能被同時訪問的資源,使得這些進程有可能因為時間上推進的先后原因而出現(xiàn)問題,這叫做競爭條件。

條件競爭就是兩個或者多個進程或者線程同時處理一個資源(如全局變量、文件等)產(chǎn)生非預(yù)想的執(zhí)行效果,從而產(chǎn)生程序執(zhí)行流的改變,從而達到攻擊的目的。

防止條件競爭的方法如下:

1、采用某種保護機制來保護數(shù)據(jù)(如互斥體),確保只有進行修改的線程才能看到不變量被破壞時的中間狀態(tài);

2、使用無鎖編程;

3、使用事務(wù)來處理更新,將數(shù)據(jù)和讀取都存儲到事務(wù)日志中,然后將之前的操作合并為一步,再進行提交。當(dāng)數(shù)據(jù)被另一個線程修改后,或處理已經(jīng)重啟的情況下,提交就會無法進行。

03

不可重入函數(shù)

首先需要區(qū)分什么是可重入什么是不可重入函數(shù)?

可重入函數(shù):可重入函數(shù)可以由多個任務(wù)并發(fā)使用,而不必擔(dān)心數(shù)據(jù)錯誤

不可重入函數(shù):不能由超過一個任務(wù)所共享,除非能確保函數(shù)的互斥(或者使用信號量,或者在代碼的關(guān)鍵部分禁用中斷)

一些常見的不可重入函數(shù)的情形:

函數(shù)中使用了靜態(tài)變量,無論是全局變量還是局部靜態(tài)變量

函數(shù)返回靜態(tài)變量

函數(shù)中調(diào)用了不可重入函數(shù)

函數(shù)體內(nèi)使用了靜態(tài)的數(shù)據(jù)結(jié)構(gòu)

函數(shù)體內(nèi)調(diào)用了malloc()或者free()函數(shù)

函數(shù)體內(nèi)調(diào)用了其他標準I/O函數(shù)

函數(shù)是singleton中的成員函數(shù)而且使用了不使用線程獨立存儲的成員變量

總得來說,如果一個函數(shù)在重入條件下使用了未受保護的共享資源,那么他就是不可重入的。

例如兩個函數(shù)func1和func2都是不可重入函數(shù):對多線程條件下,操作系統(tǒng)會在func1還沒有執(zhí)行完的情況下,切換到另一個線程中,那個線程可能再次調(diào)用func1,這樣狀態(tài)就錯了。

避免措施:

在每個庫或驅(qū)動程序模塊中創(chuàng)建并隱藏一個本質(zhì)上不可重入的互斥鎖。將此互斥鎖的獲取作為操作整個模塊中使用的任何持久數(shù)據(jù)或共享寄存器的先決條件。

04

優(yōu)先級翻轉(zhuǎn)

優(yōu)先級翻轉(zhuǎn)是當(dāng)一個高優(yōu)先級任務(wù)通過信號量機制訪問共享資源時,該信號量已被一低優(yōu)先級任務(wù)占有,因此造成高優(yōu)先級任務(wù)被許多具有較低優(yōu)先級任務(wù)阻塞,實時性難以得到保證。

比較經(jīng)典的由于優(yōu)先級翻轉(zhuǎn)造成的事故就是當(dāng)年的火星探路者號,就由于,此處所說的,優(yōu)先級反轉(zhuǎn),而導(dǎo)致了內(nèi)部執(zhí)行邏輯出錯的bug。

在1997年7月4號發(fā)射后,在開始搜集氣象數(shù)據(jù)之后沒幾天,系統(tǒng)(無故)重啟了。后來,當(dāng)然,被相關(guān)技術(shù)人員找到問題根源,就是,這個優(yōu)先級反轉(zhuǎn)所導(dǎo)致的,然后修復(fù)了此bug。

解決措施:

1、優(yōu)先級天花板

優(yōu)先級天花板是當(dāng)線程申請某資源時,把該線程的優(yōu)先級提升到可訪問這個資源的所有線程中的最高優(yōu)先級,這個優(yōu)先級稱為該資源的優(yōu)先級天花板。這種方法簡單易行,不必進行復(fù)雜的判斷,不管線程是否阻塞了高優(yōu)先級線程的運行, 只要線程訪問共享資源都會提升線程的優(yōu)先級。

2、優(yōu)先級繼承

優(yōu)先級繼承是當(dāng)線程A申請共享資源Source時,如果共享資源Source正在被線程C使用,通過比較線程C與自身的優(yōu)先級,如發(fā)現(xiàn)線程C的優(yōu)先級小于自身的優(yōu)先級, 則將線程C的優(yōu)先級提升到自身的優(yōu)先級,線程C釋放資源Source后,再恢復(fù)線程C的原優(yōu)先級。這種方法只在占有資源的低優(yōu)先級線程阻塞了高優(yōu)先級線程時才動態(tài)的改變線程的優(yōu)先級。

05

內(nèi)存泄漏

內(nèi)存泄漏(Memory Leak)是指程序中已動態(tài)分配的堆內(nèi)存由于某種原因程序未釋放或無法釋放,造成系統(tǒng)內(nèi)存的浪費,導(dǎo)致程序運行速度減慢甚至系統(tǒng)崩潰等嚴重后果。

解決措施: 當(dāng)申請了動態(tài)區(qū)域,用完的時候一定要記得釋放(free),如果沒有釋放,那么這塊內(nèi)存區(qū)域就將處于不可用狀態(tài)(就像占著茅坑不拉屎一樣),程序大了或運行久了就極有可能會導(dǎo)致內(nèi)存的泄露(重啟一下就能解決90%的問題根源),同時我們在釋放的時候也要注意釋放的內(nèi)存只能釋放一次,不要重復(fù)的釋放,有的時候代碼量會比較大,所以有可能會在不止一處地方進行了代碼的釋放操作。因為我們內(nèi)存釋放了一次后,該內(nèi)存區(qū)域就有可能用來做別的事了,如果這時候我們又再釋放一遍就很有可能會出現(xiàn)問題了。釋放完之后最好把指針指向空地址,避免下次再使用指針的時候出現(xiàn)地址的錯誤。



審核編輯:劉清

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

    關(guān)注

    8

    文章

    1392

    瀏覽量

    117403
  • 中斷處理
    +關(guān)注

    關(guān)注

    0

    文章

    94

    瀏覽量

    11249
  • RTOS
    +關(guān)注

    關(guān)注

    24

    文章

    849

    瀏覽量

    121109
  • 堆棧溢出
    +關(guān)注

    關(guān)注

    0

    文章

    9

    瀏覽量

    8032

原文標題:不要以為莫名其妙的bug是玄學(xué)!介紹5個引起程序隱藏bug的原因以及預(yù)防措施。

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

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    rtthread_studio使用lwip軟件包變異報錯是什么原因導(dǎo)致的?

    最近學(xué)習(xí)使用rtthread_studio 開發(fā)stm32f407網(wǎng)絡(luò)通信,打開lwip軟件包,結(jié)果變異報錯,網(wǎng)上查了一下,沒人遇到過這個情況,好像簡單設(shè)置一下就能編譯通過,怎么我這就
    發(fā)表于 03-05 09:09

    請問一下DLPC3439的控制器,軟件編寫工具是什么?以及下載地址是什么?

    請問一下DLPC3439的控制器,軟件編寫工具是什么?以及下載地址是什么? 非常感謝
    發(fā)表于 02-24 07:10

    “碰一下”支付背后的4G技術(shù)

    不知道你是否有留意,近期,在線下支付場景中,多了個支付寶“碰一下”支付的設(shè)備,只需要“解鎖手機—碰一下—確認”即可完成支付,對比打開付款碼支付,步驟確實更加簡潔。
    的頭像 發(fā)表于 01-03 16:27 ?1805次閱讀

    支付寶發(fā)布新代AI視覺搜索“探一下

    輕松實現(xiàn)對感興趣事物的快速識別與搜索。只需打開支付寶,利用攝像頭對準目標,無論是花草寵物、潮玩收藏,還是旅游景點的隨身講解,甚至是商品藥品的詳細信息,都能迅速獲取。此外,“探一下”還具備趣味解讀功能,能夠為用戶解讀萌
    的頭像 發(fā)表于 12-31 10:49 ?555次閱讀

    智多晶EDA工具HqFpga軟件實用小功能

    智多晶EDA工具HqFpga軟件實用小功能增加啦,支持生成可調(diào)用網(wǎng)表的功能和ballmap功能。下面來給大家講解一下如何通過HqFpga軟件生成可調(diào)用的網(wǎng)表文件
    的頭像 發(fā)表于 12-05 10:23 ?1094次閱讀
    智多晶EDA工具HqFpga<b class='flag-5'>軟件</b>實用小功能

    什么情況下無功補償電容器會出現(xiàn)損壞

    在低壓配電系統(tǒng)的無功補償中,無功補償電容器已經(jīng)被廣泛應(yīng)用,但是出現(xiàn)故障甚至損壞的情況也相對較多。在今天的文章中,為大家總結(jié)了可能會造成無功補償電容器損壞的幾種情況應(yīng)對方法,快來了解一下
    的頭像 發(fā)表于 11-05 14:14 ?721次閱讀
    什么<b class='flag-5'>情況下</b>無功補償電容器會出現(xiàn)損壞

    OPA2132容易自激是什么原因導(dǎo)致的?

    萬用表測量第5定會自激,就算放開表筆依然自激,如果再用表筆碰一下第7腳自激就沒了,碰第5腳又自激。就是這種
    發(fā)表于 11-01 06:57

    電子元件在哪些情況下容易遭受靜電破壞

    在當(dāng)今的電子技術(shù)時代,電子元件和產(chǎn)品的可靠性至關(guān)重要。然而,靜電放電(ESD)對電子產(chǎn)品構(gòu)成了嚴重威脅,從生產(chǎn)到使用的全過程,電子產(chǎn)品都處于靜電破壞的風(fēng)險之中。本文將深入探討電子元件在哪些情況下容易
    的頭像 發(fā)表于 10-04 16:39 ?1995次閱讀

    什么情況下OPA541容易損壞?

    我打算用OPA541做個交流程控電壓源,輸出功率50W。OPA541采用開關(guān)電源供電±24V,OPA541采用數(shù)據(jù)手冊上的接法,限流保護電阻為0.5歐。在5歐負載的情況下,輸出電壓有效值15V
    發(fā)表于 09-11 07:49

    內(nèi)存條接觸不良會導(dǎo)致哪些情況

    內(nèi)存條接觸不良是一種常見的計算機故障,它可能會導(dǎo)致多種問題,影響計算機的正常運行。本文將詳細介紹內(nèi)存條接觸不良可能導(dǎo)致的各種情況,以及如何診
    的頭像 發(fā)表于 09-02 14:36 ?4537次閱讀

    請問一下INA333這個芯片很容易壞嗎?

    大家好,請問一下INA333這個芯片很容易壞嗎, 我的單電源3.3V供電。輸入是正向1.0v,反向0.5v,ref接地,放大2倍,結(jié)果輸出0.3V左右,是不是芯片壞了
    發(fā)表于 08-30 07:16

    環(huán)境因素對晶振失效的影響及建議措施

    。 、高溫環(huán)境的影響 在高溫環(huán)境,晶振內(nèi)部的晶體會變得不穩(wěn)定,從而導(dǎo)致振蕩頻率失真。例如,在些高溫的工業(yè)生產(chǎn)環(huán)境中,晶振可能會因為無法承受過高的溫度而出現(xiàn)頻率偏差,影響設(shè)備的精準
    發(fā)表于 08-19 17:36

    plc什么情況下導(dǎo)致程序丟失

    PLC(Programmable Logic Controller,可編程邏輯控制器)是一種廣泛應(yīng)用于工業(yè)自動化領(lǐng)域的設(shè)備。它通過執(zhí)行用戶編寫的程序來實現(xiàn)對機械設(shè)備的控制。然而,在某些情況下,PLC
    的頭像 發(fā)表于 08-19 09:14 ?2865次閱讀

    極限失控的大模型使電力系統(tǒng)面臨的跨域攻擊風(fēng)險及應(yīng)對措施

    分析大規(guī)模生成式預(yù)訓(xùn)練模型(以下簡稱為大模型)發(fā)生極限失控、使電力系統(tǒng)面臨的跨域攻擊風(fēng)險及相關(guān)的應(yīng)對措施,以期引起業(yè)內(nèi)對這風(fēng)險的重視、討論與行動。基于大模型的現(xiàn)狀、發(fā)展趨勢以及它與人
    發(fā)表于 07-22 12:09 ?0次下載

    MOS管什么情況下會短路

    MOS管(Metal-Oxide-Semiconductor Field-Effect Transistor,金屬-氧化物半導(dǎo)體場效應(yīng)晶體管)在多種情況下可能會發(fā)生短路,這些情況主要涉及其工作環(huán)境、操作條件、物理特性以及制造工藝
    的頭像 發(fā)表于 07-16 11:39 ?5956次閱讀