神回答:編程到底難在哪里?
設(shè)為“置頂或星標(biāo)”,第一時間送達(dá)干貨
知乎上有個問題:編程到底難在哪里?知乎網(wǎng)友 DJ Hitori 的回答獲贊無數(shù)。
這篇回答并不是講述在生活中程序員如何買蘋果,而是以買蘋果為例說明程序員如何解決問題。程序員需要對問題進(jìn)行透徹的分析,理清其涉及的所有細(xì)節(jié),預(yù)測可能發(fā)生的所有意外與非意外的情況,列出解決方案的所有步驟,以及對解決方案進(jìn)行盡量全面的測試。而這些正是編程難的地方。任何一點遺漏都會成為bug,輕則導(dǎo)致挨罵,重則導(dǎo)致經(jīng)濟(jì)損失甚至危害安全。
回答原文:
普通人:
我今天要買一斤蘋果。
程序員:
我今天要買一斤蘋果。
因為我只喜歡紅富士蘋果,所以我只買紅富士蘋果。
我能接受的最高價格是 10 元 / 斤。
正常情況下一斤蘋果用一個袋子能裝下,但是為防萬一,我會帶兩個袋子。
我知道附近的 3 家水果店,所以我會依次訪問這 3 家水果店。
根據(jù)上述條件,我設(shè)計出以下的買蘋果的流程:

這個流程怎么樣?我來設(shè)計一些測試樣例,測試一下這個流程。
測試發(fā)現(xiàn)一個問題:如果水果店 0 和水果店 1 都有紅富士蘋果并且價格都低于 10 元 / 斤,而且水果店 1 的價格比水果店 0 更低,那么我希望買水果店 1 的蘋果,但我設(shè)計的流程會讓我買水果店 0 的蘋果。
為了解決這個問題,我應(yīng)該先詢問所有水果店的價格,然后去價格最低的那一家買蘋果。
經(jīng)過修改,我重新設(shè)計出以下的買蘋果的流程:

現(xiàn)在這個流程是不是完美了呢?不是,我還能發(fā)現(xiàn)很多問題。
如果 3 家水果店都有紅富士蘋果但都不到一斤,但是三家店加起來能達(dá)到一斤,那么我不應(yīng)該結(jié)束流程回家,而是應(yīng)該把三家店的紅富士蘋果都買下來。
如果我向水果店詢問價格的時候這家店還有紅富士蘋果,但我詢問完所有水果店的價格后這家店的紅富士蘋果賣完了,那么我的流程會讓我試圖處理不存在的紅富士蘋果。
我走路的過程中可能會遇到突發(fā)事件,比如發(fā)現(xiàn)了新的水果店,比如袋子破掉了蘋果掉一地,對于這些情況我的流程都無法進(jìn)行處理。
啊問題太多了我懶得再改流程了。我還是去 X 寶買吧。那么接下來我要設(shè)計一個在 X 寶買紅富士蘋果的流程……
作者:DJ Hitori
鏈接:https://www.zhihu.com/answer/141334678
——End——
后臺回復(fù)關(guān)鍵字:1024,獲取一份精心整理的技術(shù)干貨 后臺回復(fù)關(guān)鍵字:進(jìn)群,帶你進(jìn)入高手如云的交流群。 推薦閱讀
SQL 語句中 where 條件后 寫上1=1 是什么意思 國產(chǎn)數(shù)據(jù)庫建模工具,看到界面第一眼,良心了! 快手公司廁所裝坑位計時器,網(wǎng)友:再也不能帶薪拉屎了! 如何優(yōu)雅地給妹子優(yōu)化電腦? 最全MySQL面試題集合 這是一個能學(xué)到技術(shù)的公眾號,歡迎關(guān)注
點擊「閱讀原文」了解SQL訓(xùn)練營
