High-Quality Routines Chapter 5-6. Review Class Quality Checklist 2.

Slides:



Advertisements
Similar presentations
Quality of a Class Abstraction: Coupling & Cohesion Michael L. Collard, Ph.D. Department of Computer Science Kent State University.
Advertisements

Chapter 3: Modules, Hierarchy Charts, and Documentation
Communication between modules, cohesion and coupling
Software Engineering Routine design. High quality routines Routine: individual method or procedure invocable for a single purpose.
Programming Logic and Design Fourth Edition, Introductory
Variables and Powerful Naming Ryan Ruzich. Naming Considerations The most important consideration in naming a variable is that the name fully and accurately.
Detailed Design Kenneth M. Anderson Lecture 21
Copyright W. Howden1 Lecture 6: Design Evaluation and Intro to OO Design Patterns.
Module: Definition ● A logical collection of related program entities ● Not necessarily a physical concept, e.g., file, function, class, package ● Often.
CSE1301 Computer Programming: Lecture 13 Documentation.
CS 201 Functions Debzani Deb.
Modules, Hierarchy Charts, and Documentation
1 ES 314 Advanced Programming Lec 2 Sept 3 Goals: Complete the discussion of problem Review of C++ Object-oriented design Arrays and pointers.
1 Working with Classes Chapter 6. 2 Class definition A class is a collection of data and routines that share a well-defined responsibility or provide.
Algorithm Programming Coding Advices Bar-Ilan University תשס " ו by Moshe Fresko.
General Issues in Using Variables
CMSC 104, Version 8/061L18Functions1.ppt Functions, Part 1 of 4 Topics Using Predefined Functions Programmer-Defined Functions Using Input Parameters Function.
Chapter 4 Procedural Abstraction and Functions That Return a Value.
Chapter 9: Coupling & Cohesion Omar Meqdadi SE 273 Lecture 9 Department of Computer Science and Software Engineering University of Wisconsin-Platteville.
INTRODUCTION TO PROGRAMMING STRUCTURE Chapter 4 1.
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All rights reserved Chapter 12 Object-Oriented.
Design-Making Projects Work (Chapter7) n Large Projects u Design often distinct from analysis or coding u Project takes weeks, months or years to create.
Coupling and Cohesion Pfleeger, S., Software Engineering Theory and Practice. Prentice Hall, 2001.
Coupling and Cohesion Source:
1 CSC 221: Introduction to Programming Fall 2012 Functions & Modules  standard modules: math, random  Python documentation, help  user-defined functions,
Program Design Simple Program Design Third Edition A Step-by-Step Approach 9.
SOFTWARE DESIGN (SWD) Instructor: Dr. Hany H. Ammar
First Steps in Modularization Simple Program Design Third Edition A Step-by-Step Approach 8.
Chapter 7: High Quality Routines By Raj Ramsaroop.
1 Software Design Reference: Software Engineering, by Ian Sommerville, Ch. 12 & 13, 5 th edition and Ch. 10, 6 th edition.
1 Software Design Overview Reference: Software Engineering, by Ian Sommerville, Ch. 12 & 13.
SE: CHAPTER 7 Writing The Program
Cohesion and Coupling CS 4311
Programming Logic and Design Using Methods. 2 Objectives Review how to use a simple method with local variables and constants Create a method that requires.
Chapter 4: Subprograms Functions for Problem Solving Mr. Dave Clausen La Cañada High School.
C++ Basics C++ is a high-level, general purpose, object-oriented programming language.
Chapter 10 Software Engineering. Understand the software life cycle. Describe the development process models. Understand the concept of modularity in.
CS242.  Reduce Complexity  Introduce an intermediate, understandable abstraction  Avoid code duplication  Support subclassing  Hide sequences  Hide.
First Steps in Modularization. Simple Program Design, Fourth Edition Chapter 8 2 Objectives In this chapter you will be able to: Introduce modularization.
1 FUNCTIONS - I Chapter 5 Functions help us write more complex programs.
Chapter 10 Defining Classes. The Internal Structure of Classes and Objects Object – collection of data and operations, in which the data can be accessed.
REFACTORINGREFACTORING. Realities Code evolves substantially during development Requirements changes 1%-4% per month on a project Current methodologies.
First Steps in Modularization. Simple Program Design, Fourth Edition Chapter 8 2 Objectives In this chapter you will be able to: Introduce modularization.
Chapter 3 Top-Down Design with Functions Part II J. H. Wang ( 王正豪 ), Ph. D. Assistant Professor Dept. Computer Science and Information Engineering National.
Jump to first page (C) 1998, Arun Lakhotia 1 Design Quality Metrics Arun Lakhotia University of Southwestern Louisiana Po Box Lafayette, LA 70504,
Controlling Program Flow with Decision Structures.
Functions in C++ Top Down Design with Functions. Top-down Design Big picture first broken down into smaller pieces.
Chapter 9: Coupling & Cohesion Omar Meqdadi SE 273 Lecture 9 Department of Computer Science and Software Engineering University of Wisconsin-Platteville.
An Introduction to Programming with C++ Sixth Edition Chapter 5 The Selection Structure.
Programming Logic and Design Fifth Edition, Comprehensive Chapter 7 Using Methods.
SOFTWARE DESIGN & SOFTWARE ENGINEERING Software design is a process in which data, program structure, interface and their details are represented by well.
Coupling and Cohesion Schach, S, R. Object-Oriented and Classical Software Engineering. McGraw-Hill, 2002.
Coupling and Cohesion Pfleeger, S., Software Engineering Theory and Practice. Prentice Hall, 2001.
Lecture 1 Page 1 CS 111 Summer 2013 Important OS Properties For real operating systems built and used by real people Differs depending on who you are talking.
Computer Programming 12 Lesson 4 - Computer Programming Structure By Dan Lunney.
Further Modularization, Cohesion, and Coupling. Simple Program Design, Fourth Edition Chapter 9 2 Objectives In this chapter you will be able to: Further.
Coupling and Cohesion Rajni Bhalla.
High-Quality Routines
Coupling and Cohesion 1.
The Selection Structure
High-Quality Routines
Improving the Design “Can the design be better?”
Chapter 09 – Part I Creating High-Quality Code
Programming Logic and Design Fourth Edition, Comprehensive
Software Design Lecture : 9.
Communication between modules, cohesion and coupling
C Programming Program Quality
Cohesion and Coupling.
Programming Issues Code Complete (Roger S. Pressman)
Presentation transcript:

High-Quality Routines Chapter 5-6

Review Class Quality Checklist 2

3

4

Outline 5 What is a Routine? Valid Reasons to Create a Routine Design at the Routine Level Good Routine Names How Long Can a Routine Be? How to Use Routine Parameters?

What Is a Routine? 6  An individual method or procedure invokcable for a single purpose  Function in C, macros in C/C++  Method in Java  What is a high/low-quality routine?

How Many Problems Can You Find? 7

Problems 8  Bad routine name – it tells you nothing  No documentation  Bad layout  InputRec is changed  if it is input, its value should not be modified (const), o.w. it should not be called inputRec  Read/write global variables  Read from corpExpense  Write to profit

Problems - cont 9  Non-single purpose  No defense against bad data – crntQtr =0?  Use of magic numbers - 100, 4.0, 12, 2, 3  Unused routine parameters: screenX, screenY  Two many parameters  Poorly ordered, undocumented parameters

Another Example 10 if ( ( (‘a’<=inputChar) && (inputChar <=‘z’)) || ( (‘A’<=inputChar) && (inputChar <=‘Z’))) { charType = CharacterType.Letter; } else if ( (inputChar==‘ ‘) ||(inputChar == ‘,’) || (inputChar==‘.‘) || (inputChar==‘!‘) || (inputChar==‘(‘) || (inputChar==‘)‘) || (inputChar==‘:‘) || (inputChar==‘;‘) || (inputChar==‘?‘) || (inputChar==‘-‘)) { charType = CharacterType.Punctuation; } else if ((‘0’<=inputChar) && (inputChar <=‘9’)) { charType = CharacterType.Digit; }

Valid Reasons to Create a Routine 11  Reduce complexity  Introduce an intermediate, understandable abstraction  Putting a section of code into a well-named routine is one of the best way to document its purpose  if (node<>null) then while (node.next<>null) do node=node.next leafName = node.name end while else leafName = “” end if  leafName = GetLeafName(node)

Valid Reasons to Create a Routine - cont 12  Avoid duplicate code  Creation of similar code in two routines implies an error in decomposition  Support subclassing  Need less new code to override a short, well-factored routine than a long, poorly factored routine  Reduce the chance of error in subclass if overrideable routines are kept simple  Hide sequences  Good to hide the order in which events happen to be processed  Independently get data from the user and from a file  Read the top of a stack and decrement StackTop variable  PopStack

Valid Reasons to Create a Routine - cont 13  Hide pointer operations  Improve portability  Simplify complicated boolean tests  Get the details of the test out of the way  A descriptive routine name summarizes the purpose of the test  Improve performance  Having code in one place will make it easier to profile to find inefficiencies  Optimize the code in one place instead of in several places

Operations That Seem Too Simple 14  Assume the calculation in a dozen places points = deviceUnits * (POINTS_PER_INCH/DeviceUnitsPerInch())  What does the expression mean?  Convert a measurement in device units to a measurement in points  Put the expression into a routine?

Function Version 15  Function DeviceUnitsToPoints(deviceUnits Integer): Integer DeviceUnitsToPoints = deviceUnits * (POINTS_PER_INCH/DeviceUnitsPerInch()) End Function  Function Call points = DeviceUnitsToPoints(deviceUnits)  More readable – even approaching self-doc  Any other benefit of the function?

16

Design at Routine Level 17  Cohesion:  how much do two routines have to know about each other?  Criteria  size of the coupling  how many things do two routines share?  Intimacy  how closely coupled is the shared information?  Ex: Function A(p1, p2, p3) { Function B(p1); Function C(p2); Function D(p3); } # using local variables rather than global variables increases intimacy and visibility # hide data, but not manipulation of it.  Flexibility  how easily can you change the connection between routines?  you want to be able to change any routine without impacting other routines

Design at Routine Level 18  Functional cohesion – strongest and best  A routine performs one and only operation  Sin, GetCustomerName, EraseFile  Assume they do what their names say they do

Cohesion Less Than Ideal 19  Sequential cohesion – operations in routine  must be performed in a specific order  share data from step to step  don’t make up a complete function  Calculate Birthrate->age->retirement date  Communicational cohesion - operations in routine  make use of the same data, aren’t related in any other way  Print a summary and re-init the data passed to it  Temporal cohesion  Operations are combined into a routine because they are all done at the same time  Read config file->init scratch file->set up a memory manager and how an screen

Cohesion Unacceptable 20  Procedural cohesion  Operations are done in a specified order and the operation don’t need to be combined for any other reason.  A routine gets an employee name, then an address, and then a phone number – matching the order in which the user is asked for  Another routine gets the rest of the employee data - procedural cohesion  Make sure the calling routine has a single, complete job: getEmployee() vs GetFirstPart…()

Cohesion Unacceptable - cont 21  illogical cohesion  Several operations are stuffed into the same routine and one of the operations is selected by a control flag that is passed in  Control flow is the only thing that ties them together  Compute(), Edit(), Print();  Coincidental cohesion  The operations in a routine have no discernible relationship to each other  HandleStuff

Good Routine Names 22  Describe everything the routine does  Describe all the outputs and side effects  ComputeReportTotals - inadequate for ‘compute report totals and open an output file’  ComputeReportTotalsAndOpenOutputFile – too long and silly  Not to use less-descriptive names  To avoid side effects  Avoid meaningless, vague, or wishy-washy verbs  HandleCalculation, PerformService, DealWithOutput don’t tell you what the routines do

Good Routine Names - cont 23  Don’t differentiate names solely by number  OutputUser, OutputUser1, OutputUser2  Make names as long as necessary  Optimum average length for variables: 9-15  Routine names tend to be longer  For a function, use a description of the return value  printer.IsReady, pen.CurrentColor()  Use opposite precisely  Show/hide, open/close, source/target,…  FileOpen and _lclose  Establish conventions for common operations

Hong Long Can a Routine Be? 24  Theoretical best max length: one screen or one/two pages – approximately lines  non-comment, non-blank  IBM once limited routines to 50 lines  Complex algorithm: lines  Decades of evidence say that routines of such length are no more error-prone than short routines  Be careful if you want to write routines longer than about 200 lines

How to Use Routine Parameters 25  Put parameters in input-modify-output order  The sequence of operations - inputting data, changing it and sending back a result  Conflicts with the C-lib convention  If several routines use similar parameters, put them in a consistent order  Use all the parameters  Don’t use parameters as working variables int sample (int inputVal) { inputVal = inputVal * CurrentMultiplier(inputVal); … return inputVal; }

26

How to Use Routine Parameters - cont 27  Document interface assumptions about paras  Whether input-only, modified, or output-only  Units of numeric parameters (inches, meters,…)  Meanings of status codes and error values if enumerated types are not used  Ranges of expected values  Specific values that should never happen  Limit the number of parameters to about 7

28

29