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

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

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

代碼中藏幾個bug,讓自己無法替代?

嵌入式情報局 ? 來源:最后一個bug ? 2023-06-07 10:34 ? 次閱讀

正文

在進行嵌入式軟件開發(fā)過程中,產(chǎn)生一些bug是難免的,工作年限比較長的朋友應(yīng)該都會有這樣的感受:"有一定規(guī)模的軟件工程幾乎不可能沒有bug",軟件邏輯不可能那么天衣無縫,軟件測試也不會百密沒有一疏,代碼和bug就是一個此消彼長、相互依賴的過程。

經(jīng)常聽一些朋友說道:"你寫的代碼沒有bug,那你離丟飯碗不遠了",又或者代碼中故意保留一些bug來增強自己在團隊中的存在感,這樣就變得無可替代了,怎么說呢,雖然這些觀點有些不道德,但也從側(cè)面透露出打工人的辛酸與無奈。

據(jù)觀察,大部分的工程師都是“七分寫,三分調(diào)”,當(dāng)然有些人該反駁了,"我怎么感覺是三分寫,七分調(diào)嗎?",如果你是這樣的狀態(tài)去編寫和調(diào)試你的代碼,我至少會認為你不專業(yè)或者編碼能力不夠,思維邏輯能力不行~ 一個經(jīng)驗老道的軟件工程師調(diào)試代碼的時間都是非常短的,甚至可以一把搞定。

這樣看來對于一般工程師們,調(diào)試所占據(jù)的比例還是比較高的,當(dāng)然調(diào)試過程并不一定全是解決bug,特別是在嵌入式領(lǐng)域,一方面要適配硬件平臺,甚至還要協(xié)助硬件排查硬件相關(guān)的問題;另一方面才是前期編碼所導(dǎo)致的一些程序bug。

然而調(diào)試結(jié)束后,與bug之間的斗爭遠遠沒有結(jié)束,當(dāng)把第一個版本提交給測試,就意味著后面會有N個版本,測試過程中、用戶使用中、增加新需求時、修護原有bug時等等都可能引入新的bug。

所以bug基本上伴隨著你整個產(chǎn)品的迭代過程,這或許也是你作為一個程序員存在的理由。

這樣看來,bug一直有,那產(chǎn)品是不是么辦法做好了?其實隨著bug的消滅,產(chǎn)品的“相對穩(wěn)定性”是不斷增強的,也就意味著以后的bug沒那么致命、沒那么容易出現(xiàn)、客戶的使用也并不會觸發(fā)等等。

如果這個時候你說這個軟件沒有bug了,至少我不會相信。 既然大家都一直與bug糾纏,是不是應(yīng)該有一些經(jīng)驗了呢?知己知彼才能百戰(zhàn)百勝。

所以bug菌這里把最近所想到的、非常有意義的部分記錄了一下分享給諸位:

1

else不處理

工作這么多年,我算是看過很多人寫代碼了,經(jīng)常有同事寫if容易丟掉else,其實這是一個非常不好的習(xí)慣。

如果在編碼的時候else部分不需要處理,倒無傷大雅,但else部分存在一些相關(guān)變量需要置位或者釋放等,而你沒有else處理,便會引入bug。

7eef0a6a-04d8-11ee-90ce-dac502259ad0.png

所以我的習(xí)慣就是即使else不需要處理也會保留下來,并且在其中進行相關(guān)注釋,以提醒自己這一塊是有邏輯處理的。

2

可視化日志

相信很多朋友都有看到過類似的文章。比如什么串口打印日志技巧、easylog等開源日志庫、離線日志記錄工具等等,這些東西都是圍繞著一個主題為程序員提供一個可視化的日志信息展示。

因為大部分人的暫態(tài)大容量記憶能力是較弱的,這樣會導(dǎo)致我們對于一些邏輯中狀態(tài)的梳理處于劣勢,特別是一些復(fù)雜的邏輯處理和梳理,使得最終編寫的代碼容易引入邏輯問題。

所以通過可視化日志的方式輔助程序員進行程序相關(guān)狀態(tài)的記錄,從而便捷的定位問題,解決bug。

7efaccba-04d8-11ee-90ce-dac502259ad0.png

3

bug與代碼要匹配

經(jīng)??蛻艋蛘邷y試反饋一些bug,有些朋友收到就立馬一頭扎進最新的代碼中進行查證,其實這個問題的出現(xiàn)是老版本上,導(dǎo)致自己忙前忙后還找不到問題的根源,所以軟件的版本管控是非常重要的,這樣才能對癥下藥。

以前去過一家公司,軟件方面沒人管控,代碼隨便改,其中一個代碼改了10幾遍,版本號什么的一直不變,這樣的話一旦有問題,這個真的是一件頭疼的事情。

4

?;仡^看看

這種方式主要是應(yīng)對一些新增需求導(dǎo)致的軟件bug,以前版本運行好幾個月都沒有問題,而更新到新版本沒多久就產(chǎn)生了故障,此時需要做的就是對比之前的代碼來進行修改點的查驗和評估。

在軟件中比較模棱兩可的位置,多看看歷史版本對其的設(shè)計和所考慮的問題,防止修改以后引入新的問題。

7f03e0de-04d8-11ee-90ce-dac502259ad0.png

5

不要你認為

以前非常有意思的一句話:"我不要你認為,我要我認為",這句話確實有點狂妄自大之感,但是在"標(biāo)準(zhǔn)"面前就是這么現(xiàn)實。

經(jīng)常有朋友在解決bug的過程中抱著猜一猜的心態(tài),這樣是非常不專業(yè)的。

對于軟件運行本身是沒有bug這一說法的,程序都是按照你寫的代碼序列在運行著,之所以稱軟件有bug,無非就是它沒有按照你想要的邏輯運行罷了。

那這個問題并不是在軟件本身而是你自身的編碼能力,如果對于你所寫的代碼問題都還是猜一猜的方式去解決問題,那這個bug估計會越滾越大。

所以怎么算解決bug呢?一定要分析bug產(chǎn)生的前因后果,而不是“我把下面這行代碼屏蔽了問題就不出現(xiàn)”等等不負責(zé)任的方式。

當(dāng)然有時候你有這樣的做法,我也能理解,畢竟有時候客戶可耗不起你分析的時間,設(shè)備停機1個小時10來w,你看著賠償就好了~

7f0cd4be-04d8-11ee-90ce-dac502259ad0.png

6

假如XXX會怎樣

寫軟件的朋友,腦袋瓜子相對比較靈活,這都是多年訓(xùn)練的結(jié)果。

在設(shè)計軟件的時候應(yīng)該多做一些假設(shè),比如程序中等待兩個信號到來便會進行相應(yīng)的處理,此時此刻你就需要考慮其中有一個信號遲遲沒有到來超時了程序會怎么樣?

或者兩個信號接收的順序是否會對程序造成影響之類的問題?

解析一些通信數(shù)據(jù),不可能每次都那么穩(wěn)定的傳輸,如果存在粘包、斷包、錯誤包該如何處理等等?

當(dāng)你在寫代碼的過程中面面俱到,這樣寫出來的程序才會相對更加穩(wěn)定,當(dāng)然要做到這種境界也得一日之寒,需要不斷的積累和理解。




審核編輯:劉清

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

    關(guān)注

    45

    文章

    3663

    瀏覽量

    135024
  • 嵌入式軟件
    +關(guān)注

    關(guān)注

    4

    文章

    240

    瀏覽量

    26688

原文標(biāo)題:代碼中藏幾個bug,讓自己無法替代?

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

收藏 人收藏

    評論

    相關(guān)推薦

    與單片機Bug戰(zhàn)斗的那些經(jīng)歷

    ,以編程規(guī)范來打造程序的外觀。Bug已經(jīng)在高手面前無所遁形。所以Bug只是高手們用來愉悅的玩物。用來享受那一刻的征服感。為了菜鳥也能享受其中的快樂,我分享一下自己的經(jīng)驗,
    發(fā)表于 11-05 17:09

    labview 前面板全屏后按鍵不能正常, 是labview的BUG還是代碼有問題?

    用選項卡裝一個chart 圖,Chart圖自己適應(yīng)屏幕后,在同一選項卡里的按鍵按下后就不顯示。不知道是Labview本身的BUG,還是自己編寫的程序有問題,現(xiàn)符上圖片和
    發(fā)表于 11-27 10:00

    與單片機Bug戰(zhàn)斗的那些經(jīng)歷

    編程規(guī)范來打造程序的外觀。Bug已經(jīng)在高手面前無所遁形。所以Bug只是高手們用來愉悅的玩物。用來享受那一刻的征服感。為了菜鳥也能享受其中的快樂,我分享一下自己的經(jīng)驗,
    發(fā)表于 12-20 17:15

    程序員最難忘的Bug調(diào)試經(jīng)歷

    無計可施的時候,唯一能做的是對代碼進行分而治之,不斷地去排查錯誤,消滅錯誤,直到最后剩下非常小的一塊,再去慢慢研究問題所在,可不幸往往就這樣,在排除了許多錯誤以后,該Bug還是會出現(xiàn)。在這個過程
    發(fā)表于 01-21 15:08

    開發(fā)者應(yīng)該知道的代碼查詢工具,杜絕代碼bug

    就得你的老板付費了。他們也有一些知名的客戶,如Adobe、甲骨文、惠普、美國銀行等等。IDE的重量級作品JetBrains推出了Upsource,這是一種多語言代碼審查工具。為什么通曉多國語言?下面
    發(fā)表于 07-25 15:04

    單片機開發(fā)應(yīng)掌握的幾個基本技巧

    在單片機應(yīng)用開發(fā),代碼的使用效率問題、單片機抗干擾性和可靠性等問題仍困擾著。現(xiàn)歸納出單片機開發(fā)應(yīng)掌握的幾個基本技巧。如何減少程序
    發(fā)表于 11-19 08:25

    單片機開發(fā)應(yīng)掌握的幾個基本技巧

    在單片機應(yīng)用開發(fā),代碼的使用效率問題、單片機抗干擾性和可靠性等問題仍困擾著?,F(xiàn)歸納出單片機開發(fā)應(yīng)掌握的幾個基本技巧。1、如何減少程序
    發(fā)表于 11-22 07:16

    人工智能自己代碼實現(xiàn)自我編程的顛覆性變革

    使用人工智能,計算機能夠理解一個軟件開發(fā)項目從無到有的發(fā)展歷史過程的所有代碼,并立即改進或者刪除單獨一行代碼bug,不管是用什么編程語
    發(fā)表于 07-11 09:57 ?2.7w次閱讀

    如何編寫無法維護的代碼你的代碼沒有重構(gòu)的風(fēng)險

    自己弄個鐵飯碗,因為除了你之外,沒人能維護你寫的代碼。再而且,如果你能練就秘籍的全部招式,那么連你自己無法維護你的
    的頭像 發(fā)表于 04-29 19:11 ?2629次閱讀

    iPhone、iPad崩潰的字符bug

    今天,EverythingApplePro 又發(fā)現(xiàn)了一個字符 bug,這個 bug 被稱為“黑點”,最初與 Android 平臺的 WhatsApp 有關(guān)系。社交網(wǎng)絡(luò)上開始廣泛的傳播開來,在 iOS 平臺上,主要是黑點起作用,可以直接
    的頭像 發(fā)表于 05-22 08:39 ?4482次閱讀

    如何解決智能合約Bug

    智能合約在運行過程中發(fā)現(xiàn)Bug或者代碼需要改進,這會影響整個系統(tǒng)的健壯性,如果發(fā)現(xiàn)無法解決的Bug,那就可能會造成嚴重的經(jīng)濟損失。
    發(fā)表于 10-25 10:55 ?1775次閱讀

    STM32F4系列芯片幾個無法啟動的原因

    最近一年多開始使用STM32F4系列芯片,在使用開發(fā)板、評估板的時候一切正常,但當(dāng)自己做板子的時候事故頻發(fā),最典型的就是無法啟動、無法刷機,現(xiàn)將遇到的幾個
    的頭像 發(fā)表于 02-16 14:08 ?8455次閱讀
    STM32F4系列芯片<b class='flag-5'>幾個</b><b class='flag-5'>無法</b>啟動的原因

    如何提高代碼性能、使代碼遠離Bug、令代碼更優(yōu)雅

    背景:如何更規(guī)范化編寫Java代碼的重要性想必毋需多言,其中最重要的幾點當(dāng)屬提高代碼性能、使代碼遠離Bug、令代碼更優(yōu)雅。 一、MyBati
    的頭像 發(fā)表于 08-17 09:42 ?1458次閱讀

    代碼bug就是一個此消彼長、相互依賴的過程

    經(jīng)常聽一些朋友說道:"你寫的代碼沒有bug,那你離丟飯碗不遠了",又或者代碼故意保留一些bug來增強
    的頭像 發(fā)表于 03-11 10:01 ?1147次閱讀

    自己編寫函數(shù)示例代碼很難嗎?分享幾個示例!

    Q A 問: Arduino Uno的函數(shù)示例 我決定自己編寫函數(shù)示例代碼,因為這應(yīng)該是Arduino的基本示例。網(wǎng)絡(luò)上確實有關(guān)于使用函數(shù)的文檔,但是,如果要嘗試使用代碼環(huán)境,則必須
    的頭像 發(fā)表于 11-16 16:05 ?551次閱讀
    <b class='flag-5'>自己</b>編寫函數(shù)示例<b class='flag-5'>代碼</b>很難嗎?分享<b class='flag-5'>幾個</b>示例!