如何在面試時寫出高質量的代碼

摘要:有些程序員由于平時沒有養成良好的編程習慣,在面試時寫出的代碼質量不高,最終遺憾地與心儀的公司和職位失之交臂。如何在面試時能寫出高質量的代碼,是很多程序員關心的問題。

程序員在職業生涯中難免要接受編程面試。有些程序員由于平時沒有養成良好的編程習慣,在面試時寫出的代碼質量不高,最終遺憾地與心儀的公司和職位失之交臂。因此,如何在面試時能寫出高質量的代碼,是很多程序員關心的問題。作者總結自己多年面試他人以及被他人面試的經驗,發現應聘者可以從代碼的規范性、完整性和魯棒性三個方面提高代碼的質量。

代碼的規范性

面試官是根據應聘者寫出的代碼來決定是否錄用一個應聘者的。應聘者首先要把代碼寫得規范,才可以避免很多低級錯誤。如果代碼寫得不夠規范,會影響面試官閱讀代碼的興致,至少印象分會打折扣。書寫、布局和命名都決定著代碼的規范性。

規范的代碼書寫清晰。絕大部分面試都要求應聘者在白紙或者白板上書寫。由于現代人已經習慣了敲鍵盤打字,手寫變得越發不習慣,因此寫出來的字潦草難辨。雖然應聘者沒有必要為了面試特意去練字,但在面試過程中減慢寫字速度、盡量把每個字母寫清楚還是很有必要的。不用擔心沒有時間去寫代碼。通常編程面試的代碼量都不會超過50行,書寫不用花多少時間,關鍵是在寫代碼之前形成清晰的思路并能把思路用編程語言清楚地書寫出來。

規范的代碼布局清晰。平時程序員在集成開發環境如Visual Studio里面寫代碼,依靠專業工具調整代碼的布局,加入合理的縮進并讓括號對齊成對呈現。離開這些工具,應聘者就要格外注意布局問題。當循環、判斷較多邏輯較復雜時,縮進的層次可能比較多。如果布局不夠清晰,縮進也不能體現體現代碼的邏輯,這樣的代碼將會讓人頭暈腦脹。

規范的代碼命名合理。很多初學編程的人在寫代碼時總是習慣用最簡單的名字來命名,變量名是i、j、k,函數名是f、g、h。由于這樣的名字不能告訴讀者對應的變量或者函數的意義,代碼一長就會變得非常晦澀難懂。強烈建議應聘者在寫代碼時,用完整的英文單詞組合命名變量和函數,比如函數需要傳入一個二叉樹的根結點作為參數,則可以把該參數命名為BinaryTreeNode* pRoot。不要因為這樣會多寫幾個字母而覺得麻煩。如果一眼能看出變量、函數的用途,應聘者就能避免自己搞混淆而犯一些低級的錯誤。同時合理的命名也能讓面試官一眼就能讀懂代碼的意圖,而不是讓他去猜變量到底是數組中的最大值還是最小值。

代碼的完整性

在面試的過程中,面試官會非常關注應聘者考慮問題是否周全。面試官通過檢查代碼是否完整來考查應聘者的思維是否全面。通常面試官會檢查應聘者的代碼是否完成了基本功能、輸入邊界值是否能得到正確的輸出、是否對各種不合規范的非法輸入做出了合理的錯誤處理。

三種測試用例確保代碼的完整性

應聘者在寫代碼之前,首先要把可能的輸入都想清楚,從而避免在程序中出現各種各樣的質量漏洞。也就是說在編碼之前要考慮單元測試。如果能夠設計全面的單元測試用例并在代碼中體現出來,那么寫出的代碼自然也就是完整正確的了。通常程序員可以從功能測試、邊界測試和負面測試三方面設計測試用例,以確保代碼的完整性。

首先要考慮的普通功能測試的測試用例。應聘者首先要保證寫出的代碼能夠完成面試官要求的基本功能。比如面試題要求完成的功能是把字符串轉換成整數,應聘者就可以考慮輸入字符串“123”來測試自己寫的代碼。這里要把零、正數(比如123)和負數(比如-123)都考慮進去。

考慮功能測試時,應聘者要盡量突破常規思維的限制,避免忽視某些隱含的功能需求。比如“打印從1到最大的n位數”,很多人覺得很簡單。最大的3位數是999、最大的4位數是9999。這些數字很容易就能算出來。但最大的n位數都能用int型表示嗎?如果超出int的范圍可以考慮long long類型。超出long long能夠表示的范圍呢?面試官是不是要求考慮任意大的數字?如果面試官確認題目要求的是任意大的數字,那么這個題目就是一個大數問題。此時需要特殊的數據結構來表示數字,比如用字符串或者數組來表示大的數字,才能確保不會溢出。

其次需要考慮各種邊界值的測試用例。很多代碼都包含有循環或者遞歸。如果代碼是基于循環,那么結束循環的邊界條件是否正確?基于循環的代碼要特別注意開區間和閉區間的使用(也就是區分<與<=、>與>=)。如果代碼是基于遞歸,遞歸終止的邊界值是否正確?這些都是邊界測試時要考慮的用例。還是以字符串轉換成整數的問題為例,應聘者寫出的代碼應該確保能夠正確轉換最大的正整數和最小的負整數。

再次還需要考慮各種可能的錯誤的輸入,也就是負面測試的測試用例。應聘者寫出的函數除了要順利地完成要求的功能之外,當輸入不符合要求時,面試官還希望他能做出合理的錯誤處理。在設計把字符串轉換成整數的函數時,應聘者就要考慮當輸入的字符串不是一個數字,比如“1a2b3c”,怎么告訴函數的調用者這個輸入是非法的。

前面討論的都是要全面考慮當前需求對應的各種可能輸入。在軟件開發過程中,永遠不變的就是需求會一直改變。如果應聘者在面試時寫出的代碼能夠把將來需求可能的變化都考慮進去,在需求發生變化時能夠盡量減少代碼改動的風險,那他就向面試官展示了自己對程序可擴展性和可維護性的理解,必定能得到面試官的青睞。如果應聘者在解答面試題“調整數組順序使奇數位于偶數前面”時能夠考慮可擴展性,他寫出的代碼不僅僅只是解決調整奇數和偶數的問題,還能考慮到把調整數字順序的功能和判斷一個數字是奇數還是偶數的功能解耦。這樣當今后需求功能擴展要求解決類似的問題,比如調整負數和非負數的順序、調整能被3整除的數字和不能被3整除的數字的順序,只需要添加很少的代碼都能做到,于是提高了代碼的可擴展性和可維護性。

三種錯誤處理的方法

通常有三種方式把錯誤信息傳遞給函數調用者。

函數用返回值來告知調用者是否出錯。比如很多Windows的API就是這個類型。Windows中很多API的返回值為0表示API調用成功,而返回值不為0表示在API調用的過程中出錯了。微軟為不同的非零返回值定義了不同的意義,調用者可以根據這些返回值判斷出錯的原因。這種方式最大的問題是使用不便,因為函數不能直接把計算結果通過返回值直接賦值給其他變量,同時也不能把這個函數計算的結果直接作為參數傳遞給其他函數。

當發生錯誤時設置一個全局變量。此時可以在返回值中傳遞計算結果了。這種方法比第一種方法使用起來更加方便,因為調用者可以直接把返回值賦值給其他變量或者作為參數傳遞給其他函數。Windows的很多API運行出錯之后,也會設置一個全局變量。函數調用者可以通過調用函數GetLastError分析這個表示錯誤的全局變量從而得知出錯的原因。但這個方法有個問題:調用者很容易就會忘記去檢查全局變量,因此在調用出錯時忘記做相應的錯誤處理,從而留下安全隱患。

異常。當函數運行出錯時,程序就拋出一個異常。程序員可以根據不同的出錯原因定義不同的異常類型。因此函數的調用者可以根據異常的類型就能知道出錯的原因,從而可以做相應的處理。另外,由于顯式劃分了程序正常運行的代碼塊(try模塊)和處理異常的代碼塊(catch模塊),代碼的邏輯比較清晰。異常在高級語言如C#中是強烈推薦的錯誤處理方式,但有些早期的語言比如C語言還不支持異常。另外,當拋出異常時,程序的執行會打亂正常的順序,對程序的性能有很大的影響。

上述三種錯誤處理的方式各有優缺點。那么面試時應聘者該采用哪種方式呢?這要看面試官的需求。在聽到面試官的題目之后,應聘者要盡快分析出可能存在哪些非法輸入,并和面試官討論該如何處理這些非法輸入。和面試官進行這樣的討論對應聘者是有益的,因為面試官會覺得他對錯誤處理有著全面的了解,并且還會覺得他有很好的溝通能力。

代碼的魯棒性

魯棒性是指程序能夠判斷輸入是否合乎規范要求,并對不合要求的輸入予以合理的處理。容錯性是魯棒性的一個重要體現。不魯棒的軟件在發生異常事件時,比如用戶輸入錯誤的用戶名、試圖打開的文件不存在或者網絡不能連接,就會出現不可預見的詭異行為,或者干脆整個軟件崩潰。這樣的軟件對于用戶而言,不亞于一場災難。

由于魯棒性對軟件開發非常重要,面試官在招聘時對應聘者寫出的代碼是否魯棒也非常關注。提高代碼的魯棒性的有效途徑是進行防御性編程。防御性編程是一種編程習慣,是指預見在什么地方可能會出現問題,并為這些可能出現的問題制定處理方式。

在面試時,最簡單也最實用的防御性編程就是在函數入口添加代碼以驗證用戶輸入是否符合要求。通常面試要求的是寫一兩個函數,應聘者需要格外關注這些函數的輸入參數。如果輸入的是一個指針,那指針是空指針怎么辦?如果輸入的是一個字符串,那么字符串的內容為空怎么辦?如果應聘者能把這些問題都提前考慮到,并作相應的處理,那么面試官就會覺得他有防御性編程的習慣,能夠寫出魯棒的軟件。

當然并不是所有與魯棒性相關的問題都只是檢查輸入的參數這么簡單。應聘者看到問題時,要多問幾個“如果不……那么……”這樣的問題。比如面試題“鏈表中倒數第k個結點”,這里隱含著一個條件就是鏈表中結點的個數大于k。應聘者就要問自己如果鏈表中的結點不是大于k個,那么代碼會出什么問題?這樣的思考方式,能夠幫助發現潛在的問題并提前解決問題。這比事后讓面試官發現問題之后應聘者再去慌忙分析代碼查找問題的根源要好很多。

小結

本文從規范性、完整性和魯棒性三方面介紹了應聘者如何在面試時寫出高質量代碼(如下圖所示)。

第一,應聘者在白紙或者白板上手寫代碼時要注意規范性,盡量清晰地書寫每個字母,通過縮進和對齊括號讓代碼布局合理,同時還要合理命名代碼中的變量和函數。第二,應聘者最好在編碼之前全面考慮所有可能的輸入,確保寫出的代碼在完成了基本功能之外,還考慮了邊界條件,并做好了錯誤處理。只有全面考慮到這三方面的代碼才是完整的代碼。第三,應聘者要重視代碼的魯棒性,確保自己寫出的程序不會輕易崩潰。平時在寫代碼時,應聘者最好養成防御式編程的習慣,在函數入口判斷輸入是否有效并對各種無效輸入做好相應的處理。應聘者如果能夠做到這三點,自然就能寫出高質量的代碼,最終通過面試拿到Offer也將是水到渠成的事情。

注:作者何海濤,思科高級軟件工程師,之前先后任職于Autodesk和微軟。主要關注C++/C#的開發技術,并對設計模式和項目管理也很感興趣。


本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/450724.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/450724.shtml
英文地址,請注明出處:http://en.pswp.cn/news/450724.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

IntelliJ IDEA添加jar包

見&#xff1a;http://blog.csdn.net/a153375250/article/details/50851049 以JDBC-MySQL驅動包為例 1、在IntelliJ IDEA中打開要添加jar包的Project 2、File – Project Structure如下圖 3、選擇Moudules – 再選擇Dependencies如下圖 4、選中Moudule source – 然后點擊2處號…

Python3 與 C# 并發編程之~ 進程篇

上次說了很多Linux下進程相關知識&#xff0c;這邊不再復述&#xff0c;下面來說說Python的并發編程&#xff0c;如有錯誤歡迎提出&#xff5e; 如果遇到聽不懂的可以看上一次的文章&#xff1a;https://www.cnblogs.com/dotnetcrazy/p/9363810.html 官方文檔&#xff1a;https…

11月12號 用戶登錄輸入密碼錯誤達到指定次數后,鎖定賬戶 004

用戶表里添加兩個屬性 連續密碼輸錯次數private Integer loginFailCount;/** 登錄失敗禁用時間 */ private Date missDate; / 如果登錄錯誤次數大于5次 規定時間內禁止登錄if(dbUser.getLoginFailCount() ! null && dbUser.getLoginFailCount() > 3){if(DateUtils.…

Goobuntu:谷歌的內部桌面系統

摘要&#xff1a;大多數Linux用戶都知道Google用Linux作為它們的桌面和服務器端操作系統&#xff0c;有的人可能還知道Google選擇的是定制的Ubuntu——Goobuntu&#xff0c;但在此之前幾乎沒有Google外部人員了解他們究竟是如何使用Ubuntu的&#xff0c;8月29日&#xff0c;Tho…

Springboot 之 Hibernate自動建表(Mysql)

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 引入Maven依賴包 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-…

Spring全家桶面試真題

文章目錄1. Spring Boot1.1 說說你對Spring Boot的理解1.2 Spring Boot Starter有什么用&#xff1f;1.3 介紹Spring Boot的啟動流程1.4 Spring Boot項目是如何導入包的&#xff1f;1.5 請描述Spring Boot自動裝配的過程1.6 說說你對Spring Boot注解的了解2. Spring2.1 請你說說…

WSDL測試webservice接口記錄

收到一個事情&#xff0c;需要對接第三方API&#xff0c;對方給了個service&#xff0c;看了一下&#xff0c;原來是webservices的。 上一次測試webervice的接口&#xff0c;還是至少八九年前的時候了&#xff0c;這種相對比較老舊的也好久不在使用。 于是&#xff0c;簡單搞了…

idea窗口下方滾動條不明顯設置

在使用idea時&#xff0c;下方的滾動條老是顯示不明顯&#xff0c;每次點擊拖拽都很費勁&#xff0c;在網上找了很多相關設置&#xff0c;最后確定了一個最好的辦法解決問題&#xff1a; Shift &#xff08;上檔&#xff09; 鼠標滾動&#xff0c;這樣就可以橫向翻滾了&#…

把握本質規律——《數學之美》作者吳軍

無論是互聯網&#xff0c;還是手機、電視&#xff0c;現代通信都遵循信息論的規律&#xff0c;整個信息論的基礎都是數學。搜索引擎、語音識別、機器翻譯也都是我們生活中離不開的技術&#xff0c;數學也是解決這些問題的最好工具。在《浪潮之巔》出版后&#xff0c;吳軍將蘊含…

Hibernate4 注解方法說明

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 1.類級別注解 Entity 映射實體類 Table 映射數句庫表 Entity(name"tableName") - 必須&#xff0c;注解將一個類聲明…

消息隊列常見面試題

文章目錄2. 消息隊列2.1 MQ有什么用&#xff1f;2.2 說一說生產者與消費者模式2.3 消息隊列如何保證順序消費&#xff1f;2.4 消息隊列如何保證消息不丟&#xff1f;2.5 消息隊列如何保證不重復消費&#xff1f;2.6 MQ處理消息失敗了怎么辦&#xff1f;2.7 請介紹消息隊列推和拉…

Mybatis 詳解--- 一級緩存、二級緩存

2019獨角獸企業重金招聘Python工程師標準>>> Mybatis 為我們提供了一級緩存和二級緩存&#xff0c;可以通過下圖來理解&#xff1a; ①、一級緩存是SqlSession級別的緩存。在操作數據庫時需要構造sqlSession對象&#xff0c;在對象中有一個數據結構&#xff08;Hash…

我的nabcd

我們組要做的軟件是一款MP3播放軟件&#xff0c;名字叫TDG音樂 N&#xff08;need需求&#xff09;&#xff0c;由于現在版權越來越被重視&#xff0c;許多播放軟件里面的大部分歌曲都是收費的&#xff0c;不想花錢又想聽可怎么辦呢&#xff0c;只能在網上找免費資源&#xff0…

【C/C++和指針】深度解析---指針與數組 【精華】

一&#xff0c;引例子 二維數組可以使用指向數組的指針代替&#xff0c;而指針數組才可以用指向指針的指針代替。 [html] view plaincopy#include<iostream> using namespace std; void main() { char *a[]{"Hello","the","World&q…

Redis常見面試題詳解

文章目錄1. Redis1.1 Redis可以用來做什么&#xff1f;1.2 Redis和傳統的關系型數據庫有什么不同&#xff1f;1.3 Redis有哪些數據類型&#xff1f;1.4 Redis是單線程的&#xff0c;為什么還能這么快&#xff1f;1.5 Redis在持久化時fork出一個子進程&#xff0c;這時已經有兩個…

IntelliJ 創建main函數、for循環、輸出語句快捷鍵

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。 今天偶然發現了IntelliJ中 創建main函數的快捷鍵&#xff0c;依次還有for循環&#xff0c;System.out.println(); 在編寫代碼的時候直接…

CentOS新增用戶并授予sudo權限

2019獨角獸企業重金招聘Python工程師標準>>> 新增用戶 添加用戶useradd demo設置用戶密碼passwd demo授予sudo權限 輸入以下命令&#xff0c;編輯sudoers配置&#xff1a;visudo找到以下行root ALL(ALL) ALL增加以下內容&#xff1a;demo ALL(ALL) ALL保存后登錄dem…

跨站腳本功攻擊,xss,一個簡單的例子讓你知道什么是xss攻擊

跨站腳本功攻擊&#xff0c;xss&#xff0c;一個簡單的例子讓你知道什么是xss攻擊 一、總結 一句話總結&#xff1a;比如用戶留言功能&#xff0c;用戶留言中寫的是網頁可執行代碼&#xff0c;例如js代碼&#xff0c;然后這段代碼在可看到這段留言的不同一戶的顯示上就會執行。…

用業績建立信任

當年從香港到美國&#xff0c;對于中學畢業的郭尊華來說&#xff0c;算是一個失敗。他盡管家境普通&#xff0c;但因為成績不佳進不了香港的大學&#xff0c;不得不遠赴美國讀書。在課余做過挖地、當侍者等多份工作的他&#xff0c;在大三的時候終于得到一份初級工程師的工作。…

idea 快捷鍵 小結

前些天發現了一個巨牛的人工智能學習網站&#xff0c;通俗易懂&#xff0c;風趣幽默&#xff0c;忍不住分享一下給大家。點擊跳轉到教程。1.setting 打開快捷鍵&#xff1a;ctrl alt s 在 file - setting 中。 2.回到默認設置&#xff1a;刪除如下路徑的文件夾 C:\Users…