白板與編程面試:為什么不在電腦上編程更有幫助

jopen 10年前發布 | 6K 次閱讀 面試

        英文原文:Whiteboard and the Coding Interview

        在技術評估中的檢查方法

        白板編程可以檢查出兩方面的技能:

  1. 從一開始就可以寫簡潔的代碼,以及
  2. 知其代碼之所以然。

        這兩大技能對于一個出色的軟件開發人員是至關重要的。通過進行白板編程,這兩種技能都能被準確地檢驗出來。

        從一開始就寫簡潔的代碼。

        不管我們是否喜歡,現代軟件工程主要在于知道足夠的模式,并在正確的規則中使用正確的模式。

        幾天甚至幾周后的工作的結果,通常只是修改幾百行的代碼。

        表面上看,原來的開發人員在寫代碼時需要多少協助并不重要。他們可能在寫代碼之前,在腦子里就已經想好所有細節了。或者也有可能他們寫每一行代碼的時候都查閱了 API 文檔、實例、或者語法指導。

        但是當我們深入探究的時候,就會發現這其中有很大差異。

        理解概念要比理解現象更重要。

        一段代碼變得越復雜,僅僅依靠一些開發模式的知識去開發就會變得更難,甚至理解代碼都會很艱難。

        好的白板編程練習,可以檢查出一個人到底是理解概念,還是通過記住大量模式來掩蓋其基礎知識的匱乏。

        當我們問到“你最擅長哪種編程語言?”我們其實并不是想要簡潔的代碼。我們只是在尋找一個切入點,能深入了解一個人,看看他到底有多大能耐。

        這里簡單總結一下根據“候選人熟悉哪一領域”來決定“在面試中需要涉及哪些方面”:

  • 面向對象編程——多繼承,虛擬方法,對象構建與析構順序,異常處理。
  • 前端——異步邏輯與終止,REST API,驗證用戶輸入。
  • 算法與數據結構——動機,用法,平均及最差情況下的復雜度。
  • 后端與架構——內存模型,垃圾處理機制,多線程,線程鎖機制,benchmarking, profiling。
  • 函數式編程——Lambdas,curring,排序操作,一元。
  • 內核層次——文件系統,網絡,POSIX,協議,標準的檢驗與分析工具。

        測試——單元測試,逆向測試和端對端測試,必要測試,基于模型的測試,測試驅動的和行為驅動的開發,集成測試。

        和候選人談到上面這些的時候,最好的方法是從舉一個例子開始。最好的例子就是讓他們自己寫一個短小簡單的例子。

        實際中,候選者寫的大多數代碼片段都是不完美的。這就提供了一個絕好的機會,看看候選者到底有多少知識。

        白板編程很有用,是因為:

  • 有限的寫代碼空間。
  • 有限的寫代碼速度。
  • 修改很麻煩,最好要避免。
  • 沒有補全,語法高亮和其他 IDE 的牛逼功能。

        想明白代碼到底要干嘛。

        過一遍代碼片段是如何運行的,這是非常好的練習。做技術面試的時候,絕對不要跳過。

        如果代碼寫的是一個算法,有人可以寫出所有步驟,有人可以考慮到特殊情況,有人可以寫出不變式(invariants)并能證明。有人可以根據每個獨立循環結構和遞歸調用解釋其復雜性。

        如果代碼是面向對象編程,有人可以明確指出其具體功能,對象在何時如何被創建,如何被銷毀,什么時候以什么樣的順序會調用構建與析構函數,以及異常出現會怎樣,內存布局看起來是什么樣的。

        I 代碼是否整潔,或是否包含明顯的 bug,這非常重要。

        觀察候選人認真解釋代碼每一步實現的功能,可以了解他們的思考與說話方式。以及他們在其他領域有多深的了解。

        最后,這些都是在技術面試中要用到的檢驗技巧。而不是使用 API 和使用 IDE 完成特定任務的技巧。

        白板編程很有用,是因為:

  • 白板上的內容或多或少是不變的。
  • 用不同顏色的筆標出“候選人的原始代碼”、“面試官的評論”、“候選人評論”,可以很好的將對話可視化。

白板與編程面試:為什么不在電腦上編程更有幫助

        不用白板是否有辦法做到上面這些技巧呢?

        能,也不能。

        對于寫整潔的代碼,我覺得可以讓候選人在自己的筆記本電腦上寫。

        但是要有這些條件:

  • 代碼要用投影儀投射在大屏幕上
  • 字體要非常大。
  • 關掉大多數 IDE 的牛逼功能。

        要知道,在不熟悉的操作系統、鍵盤甚至是編輯器上,相比在白板上編程可能會更難。要么讓他們在自己的電腦上寫程序,要么確認你提供的環境他們能夠接受。

        至于理解代碼的部分,白板要更有利。

        理想情況下,如果是投影儀的影像就是投放到白板上,我會讓候選人把投放投射的白板上,面試官再拿幾支記號筆。

        不過我要說明白,電腦上不允許使用“快速修改”之類的功能。

        如果只有兩個人的話,打印機又在旁邊,那就用用大字體打印出代碼,然后用幾支彩色筆去分析也非常好。

        教學可以幫助練習這些技巧。

        我經常被問到,一個人要如何掌握上面的這些技巧。我的答案就是:教學(teaching)。

        這對面試官和應聘者都是有益的。

        我自己對我的知識水平有一個簡單標準。如果我可以對一個領域不做準備就能進行討論的話,我就算是有豐富的知識了。

        在軟件領域,這就意味著不用點退格就寫出完美的代碼,然后能一步一步解釋它是做什么的。

        如果你是那種經常要被叫過去解釋一個算法或者 API 的人,那你基本上就不會對白板編程面試感到有困難。

        白板編程是面試的必要環節么?

        不可否認,白板編程很有幫助。但沒有它也可以。

        如果有一個大屏幕可以顯示代碼,如果屏幕本身就是個白板,可以在上面用彩色筆進行注釋。

        我個人喜歡鼓勵別人走到白板前。而且這樣做有什么不好呢?

        翻譯: 伯樂在線 - TonyRideBike

        譯文鏈接: http://blog.jobbole.com/65625/

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!