精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

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

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

3天內不再提示

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

GReq_mcu168 ? 來源:硬件攻城獅 ? 作者:硬件攻城獅 ? 2022-03-11 10:01 ? 次閱讀

在進行嵌入式軟件開發過程中,產生一些bug是難免的,工作年限比較長的朋友應該都會有這樣的感受:"有一定規模的軟件工程幾乎不可能沒有bug",軟件邏輯不可能那么天衣無縫,軟件測試也不會百密沒有一疏,代碼和bug就是一個此消彼長、相互依賴的過程。 經常聽一些朋友說道:"你寫的代碼沒有bug,那你離丟飯碗不遠了",又或者代碼中故意保留一些bug來增強自己在團隊中的存在感,這樣就變得無可替代了,怎么說呢,雖然這些觀點有些不道德,但也從側面透露出打工人的辛酸與無奈。 據觀察,大部分的工程師都是“七分寫,三分調”,當然有些人該反駁了,"我怎么感覺是三分寫,七分調嗎?",如果你是這樣的狀態去編寫和調試你的代碼,我至少會認為你不專業或者編碼能力不夠,思維邏輯能力不行~ 一個經驗老道的軟件工程師調試代碼的時間都是非常短的,甚至可以一把搞定。 這樣看來對于一般工程師們,調試所占據的比例還是比較高的,當然調試過程并不一定全是解決bug,特別是在嵌入式領域,一方面要適配硬件平臺,甚至還要協助硬件排查硬件相關的問題;另一方面才是前期編碼所導致的一些程序bug。 然而調試結束后,與bug之間的斗爭遠遠沒有結束,當把第一個版本提交給測試,就意味著后面會有N個版本,測試過程中、用戶使用中、增加新需求時、修護原有bug時等等都可能引入新的bug。 所以bug基本上伴隨著你整個產品的迭代過程,這或許也是你作為一個程序員存在的理由。 這樣看來,bug一直有,那產品是不是么辦法做好了?其實隨著bug的消滅,產品的“相對穩定性”是不斷增強的,也就意味著以后的bug沒那么致命、沒那么容易出現、客戶的使用也并不會觸發等等。 如果這個時候你說這個軟件沒有bug了,至少我不會相信。 既然大家都一直與bug糾纏,是不是應該有一些經驗了呢?知己知彼才能百戰百勝。 所以bug菌這里把最近所想到的、非常有意義的部分記錄了一下分享給諸位:

1

else不處理

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

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

ab333482-9398-11ec-952b-dac502259ad0.png

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

2

可視化日志

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

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

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

ab466728-9398-11ec-952b-dac502259ad0.png

3

bug與代碼要匹配

經常客戶或者測試反饋一些bug,有些朋友收到就立馬一頭扎進最新的代碼中進行查證,其實這個問題的出現是老版本上,導致自己忙前忙后還找不到問題的根源,所以軟件的版本管控是非常重要的,這樣才能對癥下藥。

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

4

常回頭看看

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

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

ab5ae11c-9398-11ec-952b-dac502259ad0.png

5

不要你認為

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

經常有朋友在解決bug的過程中抱著猜一猜的心態,這樣是非常不專業的。

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

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

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

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

ab717544-9398-11ec-952b-dac502259ad0.png

6

假如XXX會怎樣

寫軟件的朋友,腦袋瓜子相對比較靈活,這都是多年訓練的結果。

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

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

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

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

審核編輯 :李倩

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

    關注

    30

    文章

    4750

    瀏覽量

    68357
  • BUG
    BUG
    +關注

    關注

    0

    文章

    155

    瀏覽量

    15653

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

文章出處:【微信號:mcu168,微信公眾號:硬件攻城獅】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    隱秘的串口中斷BUG案例分享

    本文分享STM32L4平臺串口驅動比較隱秘的BUG,分享的目的不在結論本身,而在于問題的分析過程,和如何形成標準,形成checklist,避免類似問題,以及在嵌入式開發中的思想。
    的頭像 發表于 09-19 14:05 ?2076次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>個</b>隱秘的串口中斷<b class='flag-5'>BUG</b>案例分享

    開發者應該知道的代碼查詢工具,杜絕代碼bug

    組件。接下來是Review Board,“開源的、基于web的代碼和文檔審查工具,用于幫助公司、開源項目和其他組織保持代碼的高質量,而且bug
    發表于 07-25 15:04

    FPGA如何避免代碼混亂

    。這些混亂的根源是什么?又該如何解決呢?好的FPGA項目的設計作品,不僅依賴于架構設計,優秀的代碼也是必不可少的關鍵因素。而好的代碼最基
    發表于 08-30 14:40

    怎樣導入相互依賴的.vhd文件(CLIP)到 Labview FPGA?

    各位大佬,我想導入CLIP進Labview FPGA的項目中。CLIP由組.vhd文件(VHDL代碼)組成,其中些文件
    發表于 04-03 21:50

    STM32的BUG代碼的錯誤嗎

    2010-4-8 1: 45 下面的函數中有BUG, 也就是SR2不能用WHILE來輪詢,而應直接讀出.如下面代碼段, 因此,在這里說的
    發表于 08-11 07:42

    如何解決JVM中極小概率發生的bug

    編者按:筆者遇到非常典型 JVM 架構相關問題,在 x86 正常運行的應用,在 aarch64 環境上低概率偶現 JVM 崩潰。這是典型的 JVM 內部
    的頭像 發表于 08-23 17:35 ?3359次閱讀

    Bug定位的過程

    身為測試工程師,總有道繞不過去的坎就是定位bug,這其實是非常花費時間的。
    的頭像 發表于 08-08 16:11 ?850次閱讀

    使用podman-compose部署wordpress的示例

    我們對于docker-compose并不陌生,它是用于編排多個可能相互依賴的容器的工具。
    的頭像 發表于 10-17 10:59 ?2688次閱讀

    數字隔離器三關鍵元件的性質和相互依賴性的重要性

    多年來,工業、醫療和其他隔離系統的設計人員在實施安全隔離時選擇有限:唯合理的選擇是光耦合器。如今,數字隔離器在性能、尺寸、成本、能效和集成度方面具有優勢。了解數字隔離器三關鍵元件的性質和相互依賴性對于選擇合適的數字隔離器非常
    的頭像 發表于 01-29 10:53 ?950次閱讀
    數字隔離器三<b class='flag-5'>個</b>關鍵元件的性質和<b class='flag-5'>相互依賴</b>性的重要性

    量子糾纏與愛情的類比分析

    在量子力學中,如果兩粒子之間有相互作用,它們就會產生種稱為“糾纏”的狀態,即它們的狀態變得相互依賴。同樣地,在愛情中,兩個人之間也可能存在這種
    的頭像 發表于 02-27 17:57 ?3607次閱讀

    冗余電路導致的BUG

      昨天解了BUG低級錯誤導致的BUG
    的頭像 發表于 05-14 15:28 ?866次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>個</b>冗余電路導致的<b class='flag-5'>BUG</b>

    Research和Develop相互依賴過程

    ? "Research"(研究)和"Develop"(開發)是兩緊密相關的概念,它們在創新、知識產出和產品/服務的生命周期中扮演不同的角色。以下是它們之間的關系: Research(研究
    的頭像 發表于 06-19 14:49 ?658次閱讀

    req-ack接口引發的問題分析

    最近定位了bug代碼是以前的同事留下的,沒有經過太多充分的測試,且沒有仿真平臺,定位的過程是相當的痛苦,前后花了差不多
    的頭像 發表于 09-06 17:36 ?681次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>個</b>req-ack接口引發的問題分析

    半導體行業的創新案例

    當技術優化的整體方法包括芯片設計、封裝和產品級相互依賴性時,產品、設計、封裝、工藝和器件相互依賴性的整體方法,以提高研發效率和價值創造
    的頭像 發表于 10-07 10:57 ?731次閱讀
    半導體行業的創新案例

    具有相互依賴的雙熱插拔電源控制器TPS2310和TPS2311數據表

    電子發燒友網站提供《具有相互依賴的雙熱插拔電源控制器TPS2310和TPS2311數據表.pdf》資料免費下載
    發表于 03-15 10:44 ?0次下載
    具有<b class='flag-5'>相互依賴</b>的雙熱插拔電源控制器TPS2310和TPS2311數據表