面試官如何面試程序員

學識都 人氣:3.12W

   一、提問之前的準備

面試官如何面試程序員

首先,最重要的是,你自己一開始就應該想清楚:

1. 需要新員工完成什麼樣的任務?

2. 怎樣的人能完成這樣的任務?

3. 哪些途徑和方法可以發現這樣的人?

只有明確這些根本性的問題,才能正確高效地完成面試。

二、提問的原則

假定你對上一節的三個問題,已經有了清晰的想法,那麼接下來就可以設計如何提問了。

有一些提問的原則,是你應該遵循的:

每一個面試問題都有明確的目的。你不僅自己瞭解,還能向其他面試官解釋清楚。

多提一些開放性(Open-ended)的問題,而不是那種用Yes/No就可以回答的問題。這樣做使你有機會與面試者展開討論,並且提出後續的問題,儘可能多地瞭解對方。

不要問宗教、家庭、健康、個人隱私等方面的問題。

不要問太複雜的問題。因爲面試者沒有太多思考時間,所以無法周全地回答,你也就無從判斷他的能力了。

三、考察專業能力

爲了確認面試者是勝任的,你可以問一些與職位相關的專業方面的問題。(不過通常來說,一次面試不足以看出一個人的專業能力。)

比如,你的招聘職位是系統管理員,你可以問"如何快速地在50臺機器上部署Linux?"(提示:正確答案不是刻錄50張安裝光盤。)

另外,你還應該向面試者瞭解他的過去,因爲過去是未來的最好預測依據。不過,提問的重點不要僅僅是他過去的成果,更要關注在當時的環境中,他是如何決策和實施的。

四、考察綜合素質

因爲人是會發展的,所以某種程度上,面試者的綜合素質要比他的專業能力更重要。

所以,具體的`技術問題(如何調用API、什麼是設計模式、編程語言的語法等等)可以少問一些,更應該關注面試者的事業心、對工作的熱情、進取心、自律能力、毅力等方面。

下面是一些典型問題:

Why did you get into development?

你爲什麼開發軟件?

How many technical books did you read in the past year?

去年你讀了幾本技術書籍?

What was your favorite technical book in the past year? What did you learn from it?

去年你最喜歡的技術書籍是哪本?你從中學到了什麼?

What websites do you read regularly, related to development?

平時你經常訪問哪些編程類網站?

Do you maintain any open-source projects?

你有自己的開源項目嗎?

Do you code in your spare-time?

業餘時間你編程嗎?

Do you love programming, or do you do it for the money?

對於你來說,編程是一種愛好,還是一種謀生手段?

Have you accomplished anything important in your career yet? Do you want to?

你的職業生涯之中有什麼重要的成就?它是你主導的嗎?

What would make you feel that you have done something important?

什麼事情會讓你很有成就感?

五、考察理性思維

某些情況下,你可能需要了解面試者的分析判斷能力,看他能否全面地思考問題、客觀地評價自己。

那麼,你可以依次提出這樣三個問題:

What's your favorite programming language? Why?

你最喜歡的編程語言是哪種?爲什麼?

If you could add one feature to your favorite language, what would it be? Why?

如果允許你爲這種語言加一種功能,你會加什麼功能?爲什麼?

If you could remove one feature from it, what would it be? Why?

如果允許你取消一種功能,會是什麼功能?爲什麼?

這裏的重點是,讓面試者從正反兩方面評價一件自己熟悉的東西,看看他的思維是否片面。答案無所謂對錯,只要面試者有一個明確的立場,能夠從正反兩方面說出令人信服的理由,就可以了。比如,某個軟件的口碑不好,但是面試者說他很喜歡,而且說得出一大堆理由,清楚地解釋了這種軟件的優點和缺點在哪裏,這樣就很好。

你還可以把這些問題,套用在其他東西上面,比如操作系統、文字編輯器等等。