當你開始思考一個編程項目時,你首先要做什麼?你拿出一張紙並開始勾畫出建築物嗎?你有想法的筆記本嗎?你開始編碼嗎?或者你是在一個奇特的軟件包中建模軟件。來,澄清你的想法...當你開始思考一個編程項目時,你首先會做什麼?
回答
爲了開始思考架構或設計,我傾向於寫假設的代碼片段,我想「只是工作」,以解決核心問題的應用。
例如,我的設計數據庫時,我通常會盡量想一些例子查詢我想到寫,而不是抽象地考慮數據實體和關係。
這種方法可以幫助我(個人)避免第一遍抽象化太多。你可以稱之爲「美麗的代碼優先」方法。它與TDD有着相似之處,除了您首先針對表達性,簡潔的代碼,然後構建體系結構和抽象以支持它。
這是我個人認爲的表現,清晰的代碼是從長遠來看比笨重的,徹底的測試代碼更可取。當然,這些並不是相互排斥的。只是不要讓美麗的「架構」的願望導致您的業務邏輯笨拙的客戶端代碼。
+1:數據優先(通過查詢) – 2008-12-03 00:10:40
有人給出了這個名字......「Readme driven development」http://tom.preston-werner。com/2010/08/23/readme-driven-development.html – Larsenal 2012-01-27 21:33:00
我幾乎總是從繪製一個粗略的對象模型開始,給我一個關於系統結構的視覺概念。然後從那裏建立。
我寫下的功能列表,然後進入它詳細一點的,然後我開始我的對象的一些塗鴉,他們會如何相互交流,那種半arsed DFD ..我所有的圖紙是一團糟!
我會谷歌它首先看到的東西存在以相同的方式/甚至更接近和了解更多關於它。利用當今可用的語言和框架的強大功能,任何普通程序員都可以編寫代碼,但質量將取決於您用來實現該解決方案的多少'最佳實踐'。你實現結果的速度也很重要。
所以我覺得谷歌搜索將是在SDLC過程:)
一個重要週期我搶本子和筆,並開始素描筆記和流程圖,沒有什麼特別的,只是可視化概念模型從那以後,我嘗試在更簡單和更簡單的任務中打破每個部分。
一旦我無法進一步簡化了任務,我開始寫輸僞代碼和粗糙了數據庫方案。只有這樣我才能開始編碼樣本/測試代碼。
我把我寫的一切我都在想法的筆記本電腦。我一般寫一兩頁關於項目/產品/等密集的筆記,然後息事寧人,因爲我沒有時間做任何事情。在實際設計事物的時候,我會重讀我的筆記並嘗試在UML中創建類圖。通常這會失敗,這會導致更多頁面的筆記改進想法,解決奇怪的邊緣案例和未定義的事情等。沖洗並重復。一旦我有一個可以記錄所有主要參與者的類圖,我就開始編寫代碼。
我想想用戶和他們想要什麼,他們會得到。
他們不關心後端或花哨的語言,直到你已經計算出到底是什麼程序會做,爲什麼會有人想使用它,沒有別的真正重要的。
通過編程項目,我要承擔起「爲客戶」,而不是一個嗜好/個人項目。
我通過讓客戶介紹給我,他們想要什麼高級語言的第一次啓動。我尋找諸如「我想要一個有多個部門並允許通過電子郵件進行回覆/更新的票務系統」的東西。東西快速簡單。
從那裏開始規範文檔的初稿。我開始詢問客戶的問題,以幫助完善原始草案並降低到更細化的水平,直到系統最終完全被指定出來。完全地,我的意思是客戶無法給我更多關於他們想要的信息。
對於個人或愛好類的項目,我通常會花幾天圍繞滾動的東西在我的頭,設計在紙上或在我的模擬程序的一些基本的數據庫模式。我喜歡在幾個晚上睡覺,看看它是否會繼續有興趣發展,而不是在它完成之前放棄。一旦我確定它是我會看到的,我會繼續起草自己的規範並從那裏開始。
嘗試分析buisiness域。即應用程序試圖解決的業務問題的結構。它需要操縱/管理哪些實體,它們是可變的/不可變的嗎?應用程序需要實現哪些流程(從業務角度來看)?每個進程需要哪些實體,以及每個進程對該實體做了什麼?等等。
- 收集requrements
- 定義優先級
- 估算努力
- 開始工作
- 跟蹤和評估進展
我開始記錄一個視覺,一描述項目的簡短文檔,圍繞它的業務以及它的成功標準。
這有助於優先功能,並給出了同一個方向大家對項目的工作。
我總是解釋什麼,我認爲它是我試圖與該項目給別人,最好另一位開發人員來解決。除非我能夠清楚地解釋我想要做什麼,否則我不會希望地獄有機會創造能夠解決問題的東西。不得不將其描述給另一個人的行爲經常會引發我對問題領域知識的空白,並暴露出我有未經證實的假設。 如果我有一個方便,這通常涉及到我如何在白板上看到問題。
- 1. 當你開始一個新的POJO課程時,你會做什麼?
- 2. 當你突然投入大型項目時,你會做什麼?
- 3. 當你等待代碼編譯時,你通常會做什麼
- 4. 你會在幾歲開始教你的孩子編程?什麼語言開始?
- 5. 在開始項目之前你做了什麼?
- 6. 你怎麼做到這一點,當你按下一個鍵會發生什麼
- 7. 什麼時候你會首先使用實體框架代碼
- 8. 當你運行一個程序時會發生什麼?
- 9. 當你編寫你自己的jquery函數時,這是什麼意思?
- 10. 當你開始重寫程序時,你在源代碼控制庫中做了什麼?
- 11. 當你需要Erlang的高性能共享狀態時,你會做什麼?
- 12. 當你在你的項目中添加一個dll的引用時,會發生什麼.net
- 13. 當你公開私人回購時,你私下做的提交會公開嗎?
- 14. 項目開始爲你好的世界什麼樣的事情?
- 15. 在VS項目的OutDir開始時,最初的「。\」會做什麼?
- 16. 當主鍵溢出時,你會做什麼?
- 17. 當你不加入你的主題時會發生什麼?
- 18. 你支持哪些開源項目,或者什麼阻止你支持項目?
- 19. 當你證明一種語言是可判定的時,你在做什麼?
- 20. 當你產生一個循環時會發生什麼?
- 21. Erlang:當你f()中的一個Pid時會發生什麼?
- 22. 什麼Mercurial DVCS託管,你會推薦一個小型的開源項目?
- 23. 你無法用Angular.js做什麼,你可以用jQuery做什麼
- 24. 你什麼時候標記你的軟件項目?
- 25. 你什麼時候可以聲稱你的程序是一個「編譯器」?
- 26. 你會從哪開始?
- 27. 你會認爲什麼做法是「pythonic」?
- 28. 可搜索表格 - 你會做什麼?
- 29. 什麼時候你返回一個類,你什麼時候返回一個HttpResponseMessage?
- 30. 當你爲linux內核編寫一個路徑時會發生什麼
看到這個問題:http://stackoverflow.com/questions/284578/design-or-prototype-first。 – 2008-12-02 23:30:49