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

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

3天內不再提示

老IT工程師眼中的十大編程禁忌

工程師人生 ? 來源:網絡整理 ? 作者:工程師吳畏 ? 2018-07-19 14:39 ? 次閱讀

程序員編程的時候難免會犯錯誤,但如果不從錯誤中吸取教訓,那么習慣成自然,你會經常犯錯的。從錯誤中不斷的學習,鍛煉好的行為習慣有助于事業(yè)上的穩(wěn)定。這就是我們如何將小麥從糟糠中區(qū)別出來以及如何避免編程禁忌的絕佳經驗。此外,最重要的就是可以為客戶帶來更好的用戶體驗。

1. 不提升非技術技能

我們認為非技術技能是項目成功的主要因素。這些非技術技能也可以稱之為“軟技能”,總體上來說,它已經被公司證明為能夠駕馭企業(yè)和客戶之間的長期商業(yè)關系,因此也能決定公司的成長發(fā)展路徑。一些關鍵的軟技能指標包括:

a.紀律——這是最重要的特征之一,缺乏紀律,最終會讓這個開發(fā)團隊在開發(fā)能力上“缺乏自信”。解決這一問題的矯正方法就是每天制定詳細的to-do清單:兌現(xiàn)你的承諾、完成你開始做的事情、避免多重任務,因為這些往往會讓你的生活產生混亂。

b.顧客的聲音——不把客戶置于決策的核心地位只會跟你們業(yè)務的原始目的相沖突。如果客戶不高興,即使你擁有世界上一流的專業(yè)知識和資源也不會起什么作用。保持符合客戶期望的解決方案、及時交付才能體現(xiàn)出項目的真正價值。

c.溝通——尤其是當客戶和供應商并不在同一地點的時候,明確而及時的溝通是填補服務空白的極好措施。主要集中在這三個方面你就能克服問題——進行主題討論、清晰表達、干脆簡潔。

d.了解需求——在整個開發(fā)生命周期過程中,決定成功和失敗的之間的一個至關重要的區(qū)別將會給人留下深刻的印象。通過最初的頭腦風暴法了解問題狀態(tài),以及后續(xù)的交貨程序,這其中都要和客戶完美配合。只有這樣,客戶才會贊賞你的工作,給你好評。

2. 對編碼不理智

古人云:善泅者溺,善騎者墮。但估計絕大多數(shù)的程序員都認為自己的編程技術絕對的牛。而同樣真實的是,每一個代碼,讓不同的程序員去實現(xiàn)的話都會不可避免地發(fā)現(xiàn)它所存在的缺陷。所以說,只有通過在一個項目上的合作,程序員之間必然有的摩擦才能證明誰是最好的。健康的競爭是好事,但它不應該成為一個本來可以成功的項目的負擔。

另一個創(chuàng)意阻礙是無法將預定義的模板使用在對你有利的開發(fā)項目里。幾乎所有的編程語言有一個很好的在線/內置的代碼片段存儲庫,可以修補代碼,防止重新編程。然而,如果因為不理解需求或缺乏接觸各種可用庫/模板的話,這就意味著程序員最終會無意間將一開始就創(chuàng)建的代碼付之東流。這不僅增加了開發(fā)時間,也提高了總體成本。另外一點就是,發(fā)布了的代碼已經經過了質量檢測,所以只有將它用作模板才能發(fā)揮它更大的價值。

3. 不一定什么都要被理解

如果你是剛調到這個團隊來的編程人員,對于手頭的工作并不是很熟悉,那該怎么辦?肯定是先看一些前任留下來的工作計劃,要是他寫的詳細倒也沒什么,如果寫的不詳細,估計會讓你更加的撓頭。

因此,推己及人,在需要交代的工作上,最好是把任務寫的盡可能的詳細。這么做也是非?,F(xiàn)實的原因:能夠把編程問題解決掉,最好是保證使用解釋性的語言和英語發(fā)音來表示變量。一些基本的指針可以讓你的程序更容易被理解,包括:

a. 把所有參數(shù)、引用、方法和變量名稱盡可能接近英語表達。保持文件名簡短但有助于理解的功能。

b. 使用++包裝文字是一個好辦法,能讓代碼和注釋更加清晰。

c. 將編寫的程序保持在一個連續(xù)的流程上,尤其是在使用OOP基礎上的語言:C#、C 和 C++。

d. 對于不同的代碼塊使用不同的描述名稱。

4. 不使用經過驗證的工具和技術

程序員的好壞從他使用的編程工具和調試工具上就能看出。在異常情況的跟蹤上,下面就是程序員經常會出現(xiàn)的常見錯誤。

對一些可能會對其它代碼有影響的常見案例進行捕捉,處理這些比較常見的異常情況(而不是特殊的異常)意味著無意中除除掉了會抑制整個程序的殘留部分,因此并不會影響他人的代碼。

也許程序員可能帶有惡意的意圖來捕捉所有的異常情況,但即使是捕捉到了也不實施采取措施,這就是常說的“虛假安全閥”,這種異常處理手段是對整個軟件的穩(wěn)定和安全的一種妥協(xié)方式。

5. 較差的控制版本

在任何涉及多個團隊的項目里,當談到版本控制的時候不去介紹使用最佳實踐都是一個十足的罪過。版本控制的目的是確保由一個人執(zhí)行的編輯或修訂不去影響另一個人的工作。

版本控制不僅有助于將由兩個或兩個以上的程序員的編輯工作合并到一起,還有助于跟蹤程序的更改歷史。所以說,任何開發(fā)團隊都應該做一些好的改進措施以確保強大的版本控制,這其中就包括:

為每個解決方案創(chuàng)建一個“邏輯單元”

給解決方案制定描述性的名稱

確保你所使用的都是最先進的文件

頻繁的向團隊分享你所做的各種改變

6. 擁有最新信息的個人代表不了團隊

這是相對有趣的一點,所有的商業(yè)產品都想要以自身的敏捷技術和產品文化來給客戶留下深刻的印象,但是現(xiàn)實中很少有廠商會花時間去磨練他們員工在介紹產品特點上的技能。許多公司只是簡單地提供了一些基本的培訓,并且抱希望與員工在真實的日常項目里學到更多的技能。所以部門經理和項目的直接領導可以通過以下兩個辦法來提高員工的業(yè)績:

一旦有新員工加入,就立刻強制安排他參加專業(yè)培訓,讓他知道他的角色是用來干什么的,盡早產生創(chuàng)造力。例如一個測試人與加入之后,就應該向他介紹編程的理念,之后將培訓重點放到測試實踐上,而不是繼續(xù)闡述編程的重要性。

現(xiàn)階段的技術的進化程度比以往任何時候都要快,,所以要記住,定期培訓是必不可少的,這是在給團隊創(chuàng)造價值。例如一個Web 設計師需要知道響應式設計,提供給設計師大量的用戶日常使用的移動設備的不斷擴張的樣品,希望他們能獲得靈感。

7. 不恰當?shù)臏y試

測試作為整個系統(tǒng)開發(fā)生命周期(Systems Development Life Cycle,簡稱SDLC)的重要一個要素,通常不需要開發(fā)團隊給出太驚人的結果。但是如果在測試環(huán)節(jié)沒有付出恰當?shù)?、相應的努力的話,這是說不過去的。下面的一些方法或許對你的測試團隊有用,至少在你們交付產品的時候能夠給用戶一個好的交代。

單元測試

實物模型

綜合測試

8. 注意安全漏洞

有的時候在軟件開發(fā)過程中,就會遇見如下這樣的安全漏洞:

A、不同組件之間意想不到的交互作用:a、輸入不正確的驗證信息;b、SQL資料隱碼攻擊;c、跨網站指令碼;d、命令植入攻擊;e、跨站請求偽造(CSRF);

B、難以實施的資源管理,包括:a、不尊重可用內存緩沖區(qū);b、對外控制;c、使用有潛在危險的功能;

9. 和客戶交流

最初的合同簽訂后,開發(fā)公司通常會忘記每天與客戶進行產品上的信息交互,以至于在交貨的時候還需要進行升級。兩大關鍵的交流點可以讓你和客戶保持更好的、更長的關系:

在客戶開問之前,開發(fā)方應該和客戶進行交流溝通。

和客戶保持周期性的交流。

10. 避免標準實踐面臨的迫在眉睫的最后期限

通常情況下項目都會遇到進度延誤的現(xiàn)象。然而,這不是說你有理由去偷工減料或者是在開發(fā)或測試階段?;ㄕ校唇洔y試的模塊絕對是一個隱患,會讓你的開發(fā)團隊名譽受損的。一個更好的方法來管理延遲是提前告知客戶并且積極執(zhí)行延遲計劃。只要延期的理由是有效的,客戶應該會理解,也會給你額外的時間來解決這個問題。

顯然,在項目的最后期限內,急急忙忙完成編程的質量肯定不是特比保險,所以在交付之后開發(fā)團隊整體上會花更多的時間和努力來進行跟蹤維護,這樣的成本也是很巨大的,最好的辦法就在一開始就制定完美的執(zhí)行計劃。項目再造所耗費的資源或許是項目本身的成本的好幾倍,任何一個公司寧愿花更多的時間在初始開發(fā)上,這樣最終的產品一定會符合SDLC標準,并在缺陷和不良問題上有足夠的話語權。對于顧客來說,時效性不能以犧牲質量為代價,永遠都不能。

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

    關注

    59

    文章

    1561

    瀏覽量

    68313
  • 編程
    +關注

    關注

    88

    文章

    3521

    瀏覽量

    93268
收藏 人收藏

    評論

    相關推薦

    正是拼的年紀|65歲電子工程師上班VLOG #65歲退休 #電子工程師 #搞笑 #上班vlog

    電子工程師
    安泰小課堂
    發(fā)布于 :2024年07月25日 11:31:02

    用二創(chuàng),1:1復刻工程師的職場現(xiàn)狀

    工程師
    揚興科技
    發(fā)布于 :2024年07月19日 18:30:07

    嵌入式軟件工程師和硬件工程師的區(qū)別?

    和通信協(xié)議,以及熟練掌握一種或多種編程語言和開發(fā)工具。 主要負責的任務和領域 嵌入式軟件工程師的工作涉及到各種任務,主要包括: * 系統(tǒng)設計:包括確定系統(tǒng)功能、分配資源、優(yōu)化性能等。 * 軟件編程:包括
    發(fā)表于 05-16 11:00

    大廠電子工程師常見面試題#電子工程師 #硬件工程師 #電路知識 #面試題

    電子工程師電路
    安泰小課堂
    發(fā)布于 :2024年04月30日 17:33:15

    fpga工程師就業(yè)趨勢

    FPGA工程師的就業(yè)趨勢呈現(xiàn)出積極的態(tài)勢。隨著科技的發(fā)展,F(xiàn)PGA(現(xiàn)場可編程門陣列)在通信、汽車、醫(yī)療、航空航天等領域的應用越來越廣泛,對FPGA工程師的需求也在不斷增加。
    的頭像 發(fā)表于 03-14 15:47 ?1208次閱讀

    一位硬件工程師的歷練之路:從入門學習理論到... #搞笑 #硬件工程師 #電子工程師 #揚興科技

    硬件工程師揚興科技
    揚興科技
    發(fā)布于 :2024年03月13日 17:50:21

    企業(yè)工程師和高校老師有啥區(qū)別

    電子工程師硬件
    電子發(fā)燒友網官方
    發(fā)布于 :2024年02月28日 17:50:00

    FPGA工程師需要具備哪些技能?

    ,工程師需要能夠產生正確的測試數(shù)據(jù)集,以確保設計的準確性和性能。 在綜合方面,F(xiàn)PGA工程師需要使用工具將HDL語言轉化為更低級別的代碼。這樣,他們就能夠順利地將代碼映射到可編程邏輯設備中
    發(fā)表于 11-09 11:03

    寫給初級硬件工程師點忠告

    1 前言 最近有感而發(fā),想對電子信息類畢業(yè)生和準備從事硬件行業(yè)的初學者、初級硬件工程師分享點忠告。 都說硬件工程師越吃香,到底是不是這樣呢?我們不妨從這
    的頭像 發(fā)表于 10-18 08:36 ?1724次閱讀
    寫給初級硬件<b class='flag-5'>工程師</b>的<b class='flag-5'>十</b>點忠告

    寫給初級硬件工程師點忠告

    1 前言 最近有感而發(fā),想對電子信息類畢業(yè)生和準備從事硬件行業(yè)的初學者、初級硬件工程師分享點忠告。 都說硬件工程師越吃香,到底是不是這樣呢?我們不妨從這
    的頭像 發(fā)表于 09-25 09:05 ?1441次閱讀