這篇回答并不是講述在生活中程序員如何買蘋果,而是以買蘋果為例說明程序員如何解決問題池磁。
程序員需要對問題進行透徹的分析奔害,理清其涉及的所有細節(jié),預(yù)測可能發(fā)生的所有意外與非意外的情況地熄,列出解決方案的所有步驟华临,以及對解決方案進行盡量全面的測試。
而這些正是我認為編程難的地方端考。任何一點遺漏都會成為bug雅潭,輕則導(dǎo)致挨罵,重則導(dǎo)致經(jīng)濟損失甚至危害安全却特。
普通人:
我今天要買一斤蘋果扶供。
程序員:
我今天要買一斤蘋果。
因為我只喜歡紅富士蘋果裂明,所以我只買紅富士蘋果椿浓。
我能接受的最高價格是10元/斤。
正常情況下一斤蘋果用一個袋子能裝下漾岳,但是為防萬一轰绵,我會帶兩個袋子。
我知道附近的3家水果店尼荆,所以我會依次訪問這3家水果店。
根據(jù)上述條件唧垦,我設(shè)計出以下的買蘋果的流程:
買蘋果流程開始
? 對水果店0捅儒、水果店1、水果店2依次執(zhí)行:
? 拜訪一家水果店流程開始
? ? ? 走到此水果店
? ? ? 如果此水果店沒有開門振亮,則結(jié)束當前的“拜訪一家水果店流程”
? ? ? 如果此水果店沒有蘋果巧还,則結(jié)束當前的“拜訪一家水果店流程”
? ? ? 如果此水果店的蘋果當中沒有紅富士蘋果,則結(jié)束當前的“拜訪一家水果店流程”
? ? ? 如果此水果店的紅富士蘋果剩余不到一斤坊秸,則結(jié)束當前的“拜訪一家水果店流程”
? ? ? 如果此水果店的紅富士蘋果的價格高于10元/斤麸祷,則執(zhí)行3次:
? ? ? 講價流程開始
? ? ? ? ? 詢問店主是否愿意將價格降到10元/斤或更低
? ? ? ? ? 如果店主愿意,則跳過剩余的“講價流程”
? ? ? 講價流程結(jié)束
? ? ? 如果此水果店的紅富士蘋果的價格仍然高于10元/斤褒搔,則結(jié)束當前的“拜訪一家水果店流程”
? ? ? 打開一個袋子阶牍,將其作為當前的袋子
? ? ? 重復(fù)執(zhí)行以下流程喷面,直到總重量大于一斤:
? ? ? 裝袋一個蘋果流程開始
? ? ? ? ? 從所有的不在袋子中的紅富士蘋果中選出最好的一個
? ? ? ? ? 如果此蘋果能裝入當前的袋子,則將此蘋果裝入當前的袋子走孽,否則執(zhí)行:
? ? ? ? ? 換袋子流程開始
? ? ? ? ? ? ? 如果我有剩余的袋子惧辈,則從中任意選出一個并作為當前的袋子,否則執(zhí)行:
? ? ? ? ? ? ? 向店主要袋子流程開始
? ? ? ? ? ? ? ? ? 向店主索要一個袋子
? ? ? ? ? ? ? ? ? 如果店主拒絕給我袋子磕瓷,則將我的所有袋子里的所有蘋果取出盒齿,然后結(jié)束當前的“拜訪一家水果店流程”
? ? ? ? ? ? ? ? ? 將店主給我的袋子作為當前的袋子
? ? ? ? ? ? ? 向店主要袋子流程結(jié)束
? ? ? ? ? 換袋子流程結(jié)束
? ? ? ? ? 測量我的所有袋子里的所有蘋果的總重量
? ? ? 裝袋一個蘋果流程結(jié)束
? ? ? 根據(jù)我的所有袋子里的所有蘋果的總重量和店主給出的價格,計算我應(yīng)付的價格
? ? ? 向店主詢問我應(yīng)付的價格
? ? ? 如果我不接受店主索要的價格困食,則執(zhí)行3次:
? ? ? 校對流程開始
? ? ? ? ? 向店主解釋我計算出的價格边翁,并詢問其是否同意
? ? ? ? ? 如果店主同意,則跳過剩余的“校對流程”
? ? ? 校對流程結(jié)束
? ? ? 如果我仍然不接受店主索要的價格硕盹,則將我的所有袋子里的所有蘋果取出倒彰,然后結(jié)束當前的“拜訪一家水果店流程”
? ? ? 如果我沒帶錢,則將我的所有袋子里的所有蘋果取出莱睁,然后結(jié)束當前的“拜訪一家水果店流程”
? ? ? 付錢拿走蘋果
? ? ? 跳過剩余的“拜訪一家水果店流程”
? 拜訪一家水果店流程結(jié)束
買蘋果流程結(jié)束
這個流程怎么樣待讳?我來設(shè)計一些測試樣例,測試一下這個流程仰剿。
測試發(fā)現(xiàn)一個問題:
如果水果店0和水果店1都有紅富士蘋果并且價格都低于10元/斤创淡,而且水果店1的價格比水果店0更低,那么我希望買水果店1的蘋果南吮,但我設(shè)計的流程會讓我買水果店0的蘋果琳彩。
為了解決這個問題,我應(yīng)該先詢問所有水果店的價格部凑,然后去價格最低的那一家買蘋果露乏。
經(jīng)過修改,我重新設(shè)計出以下的買蘋果的流程:
買蘋果流程開始
? 對水果店0涂邀、水果店1瘟仿、水果店2依次執(zhí)行:
? 詢問一家水果店的紅富士價格流程開始
? ? ? 走到此水果店
? ? ? 如果此水果店沒有開門,則視此水果店的紅富士價格為無窮大元/斤比勉,并結(jié)束當前的“詢問一家水果店的紅富士價格流程”
? ? ? 如果此水果店沒有蘋果劳较,則視此水果店的紅富士價格為無窮大元/斤,并結(jié)束當前的“詢問一家水果店的紅富士價格流程”
? ? ? 如果此水果店的蘋果當中沒有紅富士蘋果浩聋,則視此水果店的紅富士價格為無窮大元/斤观蜗,并結(jié)束當前的“詢問一家水果店的紅富士價格流程”
? ? ? 如果此水果店的紅富士蘋果剩余不到一斤,則視此水果店的紅富士價格為無窮大元/斤衣洁,并結(jié)束當前的“詢問一家水果店的紅富士價格流程”
? ? ? 向店主詢問此水果店的紅富士蘋果價格并記錄
? 詢問一家水果店的紅富士價格流程結(jié)束
? 從3家水果店中選出紅富士價格最低的一家(如果有并列則隨機選擇)墓捻,將其作為目標水果店
? 如果目標水果店的紅富士蘋果價格為無窮大元/斤,則結(jié)束當前的“買蘋果流程”
? 走到目標水果店
? 如果此水果店的紅富士蘋果的價格高于10元/斤坊夫,則執(zhí)行3次:
? 講價流程開始
? ? ? 詢問店主是否愿意將價格降到10元/斤或更低
? ? ? 如果店主愿意砖第,則跳過剩余的“講價流程”
? 講價流程結(jié)束
? 如果此水果店的紅富士蘋果的價格仍然高于10元/斤撤卢,則結(jié)束當前的“買蘋果流程”
? 打開一個袋子,將其作為當前的袋子
? 重復(fù)執(zhí)行以下流程厂画,直到總重量大于一斤:
? 裝袋一個蘋果流程開始
? ? ? 從所有的不在袋子中的紅富士蘋果中選出最好的一個
? ? ? 如果此蘋果能裝入當前的袋子凸丸,則將此蘋果裝入當前的袋子,否則執(zhí)行:
? ? ? 換袋子流程開始
? ? ? ? ? 如果我有剩余的袋子袱院,則從中任意選出一個并作為當前的袋子屎慢,否則執(zhí)行:
? ? ? ? ? 向店主要袋子流程開始
? ? ? ? ? ? ? 向店主索要一個袋子
? ? ? ? ? ? ? 如果店主拒絕給我袋子,則將我的所有袋子里的所有蘋果取出忽洛,然后結(jié)束當前的“買蘋果流程”
? ? ? ? ? ? ? 將店主給我的袋子作為當前的袋子
? ? ? ? ? 向店主要袋子流程結(jié)束
? ? ? 換袋子流程結(jié)束
? ? ? 測量我的所有袋子里的所有蘋果的總重量
? 裝袋一個蘋果流程結(jié)束
? 根據(jù)我的所有袋子里的所有蘋果的總重量和店主給出的價格腻惠,計算我應(yīng)付的價格
? 向店主詢問我應(yīng)付的價格
? 如果我不接受店主索要的價格,則執(zhí)行3次:
? 校對流程開始
? ? ? 向店主解釋我計算出的價格欲虚,并詢問其是否同意
? ? ? 如果店主同意集灌,則跳過剩余的“校對流程”
? 校對流程結(jié)束
? 如果我仍然不接受店主索要的價格,則將我的所有袋子里的所有蘋果取出复哆,然后結(jié)束當前的“買蘋果流程”
? 如果我沒帶錢欣喧,則將我的所有袋子里的所有蘋果取出,然后結(jié)束當前的“買蘋果流程”
? 付錢拿走蘋果
買蘋果流程結(jié)束
現(xiàn)在這個流程是不是完美了呢梯找?不是唆阿,我還能發(fā)現(xiàn)很多問題。
如果3家水果店都有紅富士蘋果但都不到一斤锈锤,但是三家店加起來能達到一斤驯鳖,那么我不應(yīng)該結(jié)束流程回家,而是應(yīng)該把三家店的紅富士蘋果都買下來久免。
如果我向水果店詢問價格的時候這家店還有紅富士蘋果浅辙,但我詢問完所有水果店的價格后這家店的紅富士蘋果賣完了,那么我的流程會讓我試圖處理不存在的紅富士蘋果阎姥。
我走路的過程中可能會遇到突發(fā)事件记舆,比如發(fā)現(xiàn)了新的水果店,比如袋子破掉了蘋果掉一地丁寄,對于這些情況我的流程都無法進行處理氨淌。
啊,問題太多了我懶得再改流程了伊磺,我還是去X寶買吧。
那么接下來我要設(shè)計一個在X寶買紅富士蘋果的流程……