Refactoring: Improving the Design of Existing Code (Hardcover)
暫譯: 重構:改善現有程式碼的設計 (精裝版)
Martin Fowler, Kent Beck, John Brant, William Opdyke, Don Roberts
- 出版商: Addison Wesley
- 出版日期: 1999-07-08
- 定價: $2,290
- 售價: 9.5 折 $2,176
- 語言: 英文
- 頁數: 464
- 裝訂: Hardcover
- ISBN: 0201485672
- ISBN-13: 9780201485677
-
相關分類:
Refactoring
-
相關翻譯:
重構:改善既有代碼的設計 (簡中平裝版) (Refactoring: Improving The Design of Existing Code) (簡中版)
銷售排行:
🥉 2019/12 英文書 銷售排行 第 3 名
立即出貨(限量) (庫存=2)
買這商品的人也買了...
-
$580$458 -
$2,500$2,375 -
$680$537 -
$980$774 -
$970Introduction to Algorithms, 2/e
-
$920$727 -
$880$695 -
$560$476 -
$1,920$1,824 -
$620$527 -
$780$741 -
$750$638 -
$650$553 -
$760$600 -
$590$466 -
$680$537 -
$690$538 -
$720$569 -
$750$638 -
$560$476 -
$2,370$2,252 -
$2,030$1,929 -
$480$379 -
$2,280$2,166 -
$1,980$1,881
相關主題
商品描述
Book Description Book Description
As the application of object technology-particularly the Java programming language-has become commonplace, a new problem has emerged to confront the software development community. Significant numbers of poorly designed programs have been created by less-experienced developers, resulting in applications that are inefficient and hard to maintain and extend. Increasingly, software system professionals are discovering just how difficult it is to work with these inherited, "non-optimal" applications. For several years, expert-level object programmers have employed a growing collection of techniques to improve the structural integrity and performance of such existing software programs. Referred to as "refactoring," these practices have remained in the domain of experts because no attempt has been made to transcribe the lore into a form that all developers could use. . .until now. In Refactoring: Improving the Design of Existing Software, renowned object technology mentor Martin Fowler breaks new ground, demystifying these master practices and demonstrating how software practitioners can realize the significant benefits of this new process.With proper training a skilled system designer can take a bad design and rework it into well-designed, robust code. In this book, Martin Fowler shows you where opportunities for refactoring typically can be found, and how to go about reworking a bad design into a good one. Each refactoring step is simple-seemingly too simple to be worth doing. Refactoring may involve moving a field from one class to another, or pulling some code out of a method to turn it into its own method, or even pushing some code up or down a hierarchy. While these individual steps may seem elementary, the cumulative effect of such small changes can radically improve the design. Refactoring is a proven way to prevent software decay.
In addition to discussing the various techniques of refactoring, the author provides a detailed catalog of more than seventy proven refactorings with helpful pointers that teach you when to apply them; step-by-step instructions for applying each refactoring; and an example illustrating how the refactoring works. The illustrative examples are written in Java, but the ideas are applicable to any object-oriented programming language.
Book Info
Demonstrates where opportunities for refactoring typically lie, and how to go about reworking a bad design into a good one using elementary steps. DLC: Software refactoring.
From the Inside Flap
Here's how to get the
From the Back Cover
As the application of object technology--particularly the Java programming language--has become commonplace, a new problem has emerged to confront the software development community. Significant numbers of poorly designed programs have been created by less-experienced developers, resulting in applications that are inefficient and hard to maintain and extend. Increasingly, software system professionals are discovering just how difficult it is to work with these inherited, "non-optimal" applications. For several years, expert-level object programmers have employed a growing collection of techniques to improve the structural integrity and performance of such existing software programs. Referred to as "refactoring," these practices have remained in the domain of experts because no attempt has been made to transcribe the lore into a form that all developers could use. . .until now. In Refactoring: Improving the Design of Existing Code, renowned object technology mentor Martin Fowler breaks new ground, demystifying these master practices and demonstrating how software practitioners can realize the significant benefits of this new process.0201485672B04062001
About the AuthorKent Beck is a noted programmer, tester, refactorer, author, and banjoist.
Table of Contents N/A
商品描述(中文翻譯)
書籍描述
隨著物件技術的應用,特別是 Java 程式語言,已變得司空見慣,軟體開發社群面臨了一個新問題。許多設計不良的程式是由經驗較少的開發者創建的,導致應用程式效率低下且難以維護和擴展。越來越多的軟體系統專業人士發現,處理這些繼承的「非最佳」應用程式是多麼困難。多年來,專家級的物件程式設計師使用越來越多的技術來改善這些現有軟體程式的結構完整性和性能。這些技術被稱為「重構」,但由於沒有將這些知識轉錄成所有開發者都能使用的形式,因此這些做法一直停留在專家的領域……直到現在。在《重構:改善現有軟體的設計》一書中,著名的物件技術導師馬丁·福勒開創了新局面,揭示了這些大師級的做法,並展示了軟體從業者如何實現這一新過程的顯著好處。
透過適當的訓練,熟練的系統設計師可以將不良設計重新加工成設計良好、穩健的程式碼。在本書中,馬丁·福勒告訴你重構的機會通常可以在哪裡找到,以及如何將不良設計重新加工成良好設計。每個重構步驟都很簡單——似乎過於簡單而不值得去做。重構可能涉及將一個欄位從一個類別移動到另一個類別,或將某些程式碼從一個方法中提取出來,變成自己的方法,甚至將某些程式碼向上或向下推進層級。雖然這些單獨的步驟看似基本,但這些小變化的累積效果可以徹底改善設計。重構是一種防止軟體衰退的有效方法。
除了討論各種重構技術外,作者還提供了超過七十種經過驗證的重構詳細目錄,並附有有用的提示,教你何時應用它們;每個重構的逐步指導;以及一個示例,說明重構如何運作。示例是用 Java 編寫的,但這些想法適用於任何物件導向程式語言。
書籍資訊
展示重構的機會通常位於何處,以及如何使用基本步驟將不良設計重新加工成良好設計。DLC:軟體重構。
內頁介紹
從前,一位顧問造訪了一個開發專案。顧問查看了一些已編寫的程式碼;系統的中心有一個類別層級。當他在層級中漫遊時,顧問發現它相當混亂。高層類別對類別的運作做出了一些假設,這些假設體現在繼承的程式碼中。然而,這些程式碼並不適合所有子類別,並且被大量覆寫。如果超類別稍微修改,那麼就不需要這麼多的覆寫。在其他地方,超類別的一些意圖沒有被正確理解,超類別中存在的行為被重複。在其他地方,幾個子類別用明顯可以向上移動的程式碼做了同樣的事情。
顧問建議專案管理層查看並清理程式碼,但專案管理層似乎並不熱衷。程式碼似乎運作良好,且有相當大的時間壓力。經理們表示他們會在稍後的某個時候處理這個問題。
顧問還向在層級上工作的程式設計師展示了發生了什麼。程式設計師們很熱衷,並看到了問題。他們知道這並不完全是他們的錯;有時需要一雙新眼睛來發現問題。因此,程式設計師們花了一兩天的時間清理層級。當他們完成時,程式設計師們在不減少功能的情況下,移除了層級中一半的程式碼。他們對結果感到滿意,並發現添加新類別到層級中以及在系統的其餘部分使用這些類別變得更快更容易。
專案管理層並不滿意。時間緊迫,工作量很大。這兩位程式設計師花了兩天的時間做的工作並沒有增加系統在幾個月內必須交付的許多功能。舊程式碼運作得很好。因此,設計變得更「純粹」和更「乾淨」。專案必須交付運作的程式碼,而不是能取悅學術界的程式碼。顧問建議在系統的其他核心部分進行這種清理。這樣的活動可能會使專案停滯一兩週。所有這些活動都是為了讓程式碼看起來更好,而不是讓它做任何它尚未做到的事情。
你對這個故事有什麼感覺?你認為顧問建議進一步清理是正確的嗎?還是你遵循那句老工程格言,「如果它能運作,就不要修理它」?
我必須承認這裡有一些偏見。我就是那位顧問。六個月後,專案失敗,主要原因是程式碼過於複雜,無法進行除錯或調整到可接受的性能。
顧問肯特·貝克被請來重啟專案,這是一項幾乎從頭開始重寫整個系統的工作。他做了幾件事情不同,但最重要的一件是堅持不斷清理程式碼,使用重構。這個專案的成功,以及重構在這一成功中所扮演的角色,激勵我寫這本書,以便我能傳遞肯特和其他人在使用重構改善軟體質量方面所學到的知識。什麼是重構?
重構是以不改變程式碼外部行為的方式改變軟體系統的過程,同時改善其內部結構。這是一種有紀律的清理程式碼的方法,最小化引入錯誤的機會。實質上,當你進行重構時,你是在改善已編寫程式碼的設計。
「在編寫後改善設計。」這是一個奇怪的說法。在我們目前對軟體開發的理解中,我們認為我們先設計,然後再編碼。良好的設計是第一步,編碼是第二步。隨著時間的推移,程式碼將被修改,系統的完整性,即根據該設計的結構,逐漸消退。程式碼慢慢地從工程變成了黑客。
重構正好與這種做法相反。透過重構,你可以將不良設計,甚至混亂,重新加工成設計良好的程式碼。每一步都很簡單,甚至過於簡單。你將一個欄位從一個類別移動到另一個類別,將一些程式碼從一個方法中提取出來,變成自己的方法,並將一些程式碼向上或向下推進層級。然而,這些小變化的累積效果可以徹底改善設計。這正是軟體衰退的正常觀念的完全相反。
透過重構,你找到工作變更的平衡。你會發現設計並不是在一開始就發生,而是在開發過程中持續發生。你從構建系統中學會如何改善設計。最終的互動導致一個設計在開發過程中保持良好的程式。這本書中有什麼?
這本書是重構的指南;它是為專業程式設計師撰寫的。我的目標是向你展示如何以受控和高效的方式進行重構。你將學會以不引入錯誤的方式進行重構,而是有條不紊地改善結構。
傳統上,書籍以引言開始。雖然我同意這一原則,但我發現用一般性的討論或定義來介紹重構並不容易。因此,我從一個示例開始。第一章以一個有一些常見設計缺陷的小程式為例,將其重構為一個更可接受的物件導向程式。在這個過程中,我們看到重構的過程以及幾個有用的重構的應用。如果你想了解重構的真正意義,這是關鍵的一章。
在第二章中,我涵蓋了更多重構的一般原則,一些定義,以及進行重構的原因。我概述了一些重構的問題。在第三章中,肯特·貝克幫助我描述如何在程式碼中找到壞味道,以及如何用重構來清理它們。測試在重構中扮演著非常重要的角色,因此第四章描述了如何使用一個簡單的開源 Java 測試框架將測試構建到程式碼中。
本書的核心,重構目錄,從第五章延伸到第十二章。這絕不是一個全面的目錄。這是這樣一個目錄的開始。它包括了我在這個領域的工作中迄今為止所記錄的重構。當我想做某件事情,例如用多型取代條件式(255),目錄提醒我如何以安全、逐步的方式做到這一點。我希望這是你會經常回來查閱的書籍部分。
在這本書中,我描述了許多其他人所做的研究成果。最後幾章是這些人的客座章節。第十三章由比爾·奧普代克撰寫,他描述了在商業開發中採用重構所遇到的問題。第十四章由唐·羅伯茲和約翰·布蘭特撰寫,他們描述了重構的真正未來。