Presentation is loading. Please wait.

Presentation is loading. Please wait.

On to Object Design 徐迎晓 复旦大学软件学院 2005.11.

Similar presentations


Presentation on theme: "On to Object Design 徐迎晓 复旦大学软件学院 2005.11."— Presentation transcript:

1 On to Object Design 徐迎晓 xuyingxiao@126.com http://javabook.126.com 复旦大学软件学院 2005.11

2 Outline Agile Modeling and UML UML Case Tools Limit time spent drawing Dynamic and Static Models CRC Cards

3 Agile Modeling and UML Two of the aims of Agile modeling: Reduce drawing overhead Model to understand and communicate This is a change from a view of modeling as documentation. In a era of rapid change, documentation tends to have minimal value.

4 More Agile Principles Modeling with others Create several models in parallel Use temporary models such as diagrams on white boards Digital photographs of white boards can be shared on a wiki. (See www.twiki.org)

5 Fig. 14.1

6 Outline Agile Modeling and UML UML Case Tools Limit time spent drawing Dynamic and Static Models CRC Cards

7 UML Case Tools You can also do agile modeling with UML case tools like Rational Rose, or one that comes with a popular IDE such as Eclipse or Visual Studio. Choose a tool that can read your code and reverse engineer it to create diagrams from your code. Switch back and forth from diagramming to reverse engineering.

8 Outline Agile Modeling and UML UML Case Tools Limit time spent drawing Dynamic and Static Models CRC Cards

9 Limit time spent drawing A few hours or at most one day of diagramming should do most of the work for a three week iteration. Occasional short sessions of modeling during the iteration can clarify any concepts that still need to be understood.

10 Outline Agile Modeling and UML UML Case Tools Limit time spent drawing Dynamic and Static Models CRC Cards

11 Dynamic and Static Models Dynamic models such as interaction diagrams (sequence or communication diagrams) help design logic, code behavior, and method bodies. Static Models such as class diagrams help define packages, class names, attributes, and method signatures. Switch back and forth during modeling sessions.

12 Dynamic Models Most of the challenging, interesting, and useful design work comes during dynamic modeling. The interaction diagrams are typically where we apply design patterns such as the GRASP patterns. If the most important skill in object design is assigning behavior to objects, this is when it usually takes place.

13 Dynamic Models (continued) Dynamic UML models include sequence, communication, state machine and deployment diagrams.

14 Static Models If behavior is designed during dynamic modeling, it is the static models, such as the class diagrams, which give the overall structure to our software, and allow us to divide the work into manageable and maintainable chunks. Static UML models include class, package, and deployment diagrams.

15 Design Skill, not UML skill UML is only an ancillary tool to object design. The real skill is the design, not the diagramming. Seeking a software design job because you are good at making UML diagrams is like seeking a career as a novelist because you have good penmanship.

16 Outline Agile Modeling and UML UML Case Tools Limit time spent drawing Dynamic and Static Models CRC Cards

17 An alternative to UML Object Design is the Class, Responsibility, Collaboration cards popularized by Kent Beck in eXtreme Programming. There are some brief examples in the text, but you should get a book on eXtreme Programming or go to a Web site if you are interested.

18 Fig. 14.2

19 Fig. 14.3


Download ppt "On to Object Design 徐迎晓 复旦大学软件学院 2005.11."

Similar presentations


Ads by Google