1.13k likes | 1.16k Views
7. Methods: A Deeper Look. Form ever follows function. Louis Henri Sullivan E pluribus unum. (One composed of many.) Virgil O! call back yesterday, bid time return. William Shakespeare Call me Ishmael. Herman Melville When you call me that, smile! Owen Wister. Answer me in one word.
E N D
7 • Methods: A Deeper Look
Form ever follows function. Louis Henri Sullivan E pluribus unum. (One composed of many.) Virgil O! call back yesterday, bid time return. William Shakespeare Call me Ishmael. Herman Melville When you call me that, smile! Owen Wister
Answer me in one word. William Shakespeare There is a point at which methodsdevour themselves. Frantz Fanon Life can only be understood backwards;but it must be lived forwards. Soren Kierkegaard
OBJECTIVES In this chapter you will learn: • How static methods and variables are associated with a class rather than specific instances of the class. • How the method call/return mechanism is supported by the method-call stack and activation records. • How to use random-number generation to implement game-playing applications. • How the visibility of declarations is limited to specific regions of applications.
OBJECTIVES • What method overloading is and how to create overloaded methods. • What recursive methods are. • The differences between passing method arguments by value and by reference.
7.1 Introduction • 7.2 Packaging Code in C# • 7.3 static Methods, static Variables and Class Math • 7.4 Declaring Methods with Multiple Parameters • 7.5 Notes on Declaring and Using Methods • 7.6 Method-Call Stack and Activation Records • 7.7 Argument Promotion and Casting • 7.8 The .NET Framework Class Library • 7.9 Case Study: Random-Number Generation • 7.9.1 Scaling and Shifting Random Numbers • 7.9.2 Random-Number Repeatability for Testing and Debugging
7.10 Case Study: A Game of Chance (Introducing Enumerations) • 7.11 Scope of Declarations • 7.12 Method Overloading • 7.13 Recursion • 7.14 Passing Arguments: Pass-by-Value vs. Pass-by-Reference • 7.15 (Optional) Software Engineering Case Study: Identifying Class Operations in the ATM System
7.1 Introduction • The best way to develop and maintain a large application is to construct it from small, simple pieces. • This technique is called divide and conquer.
7.2 Packaging Code in C# • Common ways of packaging code are properties, methods, classes and namespaces. • The Framework Class Library provides many predefined classes that contain methods for performing common tasks. Good Programming Practice 7.1 Familiarize yourself with the classes and methods provided by the Framework Class Library. Software Engineering Observation 7.1 Don’t try to “reinvent the wheel.” When possible, reuse Framework Class Library classes and methods.
7.2 Packaging Code in C# (Cont.) • Methods allow you to modularize an application by separating its tasks into reusable units. • Methods that you write are sometimes referred to as user-defined methods. • The “divide-and-conquer” approach makes application development more manageable by constructing applications from small, simple pieces. • Software reusability—existing methods can be used as building blocks to create new applications. • Avoid repeating code. • Dividing an application into meaningful methods makes the application easier to debug and maintain.
7.2 Packaging Code in C# (Cont.) Software Engineering Observation 7.2 To promote software reusability, every method should be limited to performing a single, well-defined task, and the name of the method should express that task effectively. Such methods make applications easier to write, debug, maintain and modify. Error-Prevention Tip 7.1 A small method that performs one task is easier to test and debug than a larger method that performs many tasks. Software Engineering Observation 7.3 If you cannot choose a concise name that expresses a method’s task, your method might be attempting to perform too many diverse tasks. It is usually best to break such a method into several smaller methods.
7.2 Packaging Code in C# (Cont.) • The code that calls a method is known as the client code. • An analogy to the method-call-and-return structure is the hierarchical form of management (Figure 7.1). Fig. 7.1 | Hierarchical boss-method/worker-method relationship. (Part 1 of 2.)
7.2 Packaging Code in C# (Cont.) • The boss method does not know how the worker method performs its designated tasks. • The worker may also call other worker methods. • This “hiding” of implementation details promotes good software engineering.
7.3 static Methods, static Variables and Class Math • A method that applies to the class in which it is declared as a whole is known as a static method. • To declare a method as static, place the keyword static before the return type in the method’s declaration. • You call any static method by specifying the name of the class in which the method is declared, followed by the member access (.) operator and the method name.
7.3 static Methods, static Variables and Class Math (Cont.) • Class Math provides a collection of static methods that enable you to perform common mathematical calculations. • You do not need to create a Math object before calling method Sqrt. • Method arguments may be constants, variables or expressions.
7.3 static Methods, static Variables and Class Math(Cont.) • Figure 7.2 summarizes several Math class methods. In the figure, x and y are of type double. Fig. 7.2|Math class methods. (Part 1 of 3.)
7.3 static Methods, static Variables and Class Math(Cont.) Fig. 7.2|Math class methods. (Part 2 of 3.)
7.3 static Methods, static Variables and Class Math(Cont.) Fig. 7.2|Math class methods. (Part 3 of 3.)
7.3 static Methods, static Variables and Class Math (Cont.) • Class Math also declares two static constants that represent commonly used mathematical values: Math.PIand Math.E. • These constants are declared in class Math as public and const. • public allows other programmers to use these variables in their own classes. • Keyword const prevents its value from being changed after the constant is declared.
7.3 static Methods, static Variables and Class Math (Cont.) Common Programming Error 7.1 Every constant declared in a class, but not inside a method of the class is implicitly static, so it is a syntax error to declare such a constant with keyword static explicitly. • Because these constants are static, you can access them via the class name Math and the member access (.) operator, just like class Math’s methods. • When objects of a class containing static variables are created, all the objects of that class share one copy of the class’s static variables. • Together the static variables and instance variables represent the fields of a class.
7.3 static Methods, static Variables and Class Math (Cont.) Why Is Method Main Declared static? • The Main method is sometimes called the application’s entry point. • Declaring Main as static allows the execution environment to invoke Main without creating an instance of the class. • When you execute your application from the command line, you type the application name, followed by command-line arguments that specify a list of strings separated by spaces. • The execution environment will pass these arguments to the Main method of your application.
7.3 static Methods, static Variables and Class Math (Cont.) Additional Comments about Method Main • Applications that do not take command-line arguments may omit the string[] args parameter. • The public keyword may be omitted. • You can declare Main with return type int (instead of void) to enable Main to return an error code with the return statement. • You can declare only one Main method in each class.
7.3 static Methods, static Variables and Class Math (Cont.) • You can place a Main method in every class you declare. • However, you need to indicate the application’s entry point. • Do this by clicking the menu Project> [ProjectName] Properties... and selecting the class containing the Main method that should be the entry point from the Startupobject list box.
Outline • A MaximumFinder class is presented in Fig. 7.3. MaximumFinder.cs ( 1 of 3 ) Prompt the user to enter three double values and read them from the user. Fig. 7.3 | User-defined method Maximum. (Part 1 of 3.)
Outline MaximumFinder.cs ( 2 of 3 ) Call method Maximum to determine the largest of the three double values passed as arguments to the method. The method’s name is Maximum and that the method requires three double parameters to accomplish its task Fig. 7.3 | User-defined method Maximum. (Part 2 of 3.)
Outline MaximumFinder.cs ( 3 of 3 ) Fig. 7.3 | User-defined method Maximum. (Part 3 of 3.)
Outline • Class MaximumFinderTest (Fig. 7.4) contains the application’s entry point. MaximumFinderTest.cs (1 of 2 ) Create an object of class MaximumFinder Calls the object’s DetermineMaximum method to produce the application’s output Fig. 7.4 | Application to test class MaximumFinder. (Part 1 of 2.)
Outline MaximumFinderTest.cs (2 of 2 ) Fig. 7.4 | Application to test class MaximumFinder. (Part 2 of 2.)
7.4 Declaring Methods with Multiple Parameters (Cont.) • When a method has more than one parameter, the parameters are specified as a comma-separated list. • There must be one argument in the method call for each parameter (sometimes called a formal parameter) in the method declaration. • Each argument must be consistent with the type of the corresponding parameter. • When program control returns from a method, that method’s parameters are no longer accessible in memory. • Methods can return at most one value.
7.4 Declaring Methods with Multiple Parameters (Cont.) • Variables should be declared as fields of a class only if they are required for use in more than one method or if the application needs to save their values between calls to the class’s methods. Common Programming Error 7.2 Declaring method parameters of the same type as floatx,y instead of floatx,floaty is a syntax error—a type is required for each parameter in the parameter list. Software Engineering Observation 7.4 A method that has many parameters may be performing too many tasks. Consider dividing the method into smaller methods that perform the separate tasks. As a guideline, try to fit the method header on one line if possible.
7.4 Declaring Methods with Multiple Parameters (Cont.) Implementing Method Maximum by Reusing Method Math.Max • The entire body of our maximum method could also be implemented with nested calls to Math.Max, as follows: return Math.Max( x, Math.Max( y, z ) ); • Before any method can be called, all its arguments must be evaluated to determine their values. • Math.Max(y,z) is evaluated first, then the result is passed as the second argument to the other call to Math.Max
7.4 Declaring Methods with Multiple Parameters (Cont.) Assembling Strings with String Concatenation • string concatenation allows you to combine strings using operator + . • When one of the + operator’s operands is a string, the other is implicitly converted to a string, then the two are concatenated. • If a bool is concatenated with a string, the bool is converted to the string"True" or "False".
7.4 Declaring Methods with Multiple Parameters (Cont.) • All objects have a ToString method that returns a string representation of the object. • When an object is concatenated with a string, the object’s ToString method is implicitly called to obtain the string representation of the object. • A large string literal in a program can be broken into several smaller strings and placed them on multiple lines for readability, and reassembled using string concatenation or string
7.4 Declaring Methods with Multiple Parameters (Cont.) Common Programming Error 7.3 If a string does not fit on one line, split the string into several smaller strings and use concatenation to form the desired string.C# also provides so-called verbatim string literals, which are preceeded by the @ character. Such literals can be split over multiple lines and the characters in the literal are processed exactly as they appear in the literal. Common Programming Error 7.4 Confusing the + operator used for string concatenation with the + operator used for addition can lead to strange results. The + operator is left-associative. For example, if integer variable y has the value 5, the expression "y+2="+y+2 results in the string "y+2=52", not "y+2=7", because first the value of y (5) is concatenated with the string "y+2=", then the value 2 is concatenated with the new larger string "y+2=5". The expression "y+2="+(y+2) produces the desired result "y+2=7".
7.5 Notes on Declaring and Using Methods • To access the class’s non-static members, a static method must use a reference to an object of the class. • There are three ways to return control to the statement that calls a method. • Reaching the end of the method. • A return statement without a value. • A return statement with a value.
7.5 Notes on Declaring and Using Methods (Cont.) Common Programming Error 7.5 Declaring a method outside the body of a class declaration or inside the body of another method is a syntax error. Common Programming Error 7.6 Omitting the return type in a method declaration is a syntax error. Common Programming Error 7.7 Redeclaring a method parameter as a local variable in the method’s body is a compilation error. Common Programming Error 7.8 Forgetting to return a value from a method that should return one is a compilation error. If a return type other than void is specified, the method must contain a return statement in each possible execution path.
7.6 Method-Call Stack and Activation Records • A stack is a last-in, first-out (LIFO) data structure. • Elements are added by pushing them onto the top of the stack. • Elements are removed by popping them off the top of the stack. • When an application calls a method, the return address of the calling method is pushed onto the program-execution stack.
7.6 Method-Call Stack and Activation Records (Cont.) • The program-execution stack also stores local variables. This data is known as the activation record or stack frame of the method call. • When a method call is made, its activation record is pushed onto the program-execution stack. • When the method call is popped off the stack, the local variables are no longer known to the application. • If so many method calls occur that the stack runs out of memory, an error known as a stack overflow occurs.
7.7 Argument Promotion and Casting • Argument promotion is the implicit conversion of an argument’s value to the type that the method expects to receive. • These conversions generate compile errors if they don’t follow C#’s promotion rules; these specify which conversions can be performed without losing data. • An int can be converted to a double without changing its value. • A double cannot be converted to an int without loss of data. • Converting large integer types to small integer types(e.g., long to int) can also result in changed values. • The types of the original values remain unchanged.
7.7 Argument Promotion and Casting(Cont.) • Figure 7.5 lists the simple types alphabetically and the types to which each can be promoted. Fig. 7.5|Implicit conversions between simple types.(Part 1 of 2.)
7.7 Argument Promotion and Casting (Cont.) Fig. 7.5|Implicit conversions between simple types.(Part 2 of 2.)
7.7 Argument Promotion and Casting (Cont.) • All simple types can also be implicitly converted to type object. • In cases where information may be lost, you must use a cast operator to explicitly force the conversion. Common Programming Error 7.9 Converting a simple-type value to a value of another simple type may change the value if the promotion is not allowed. For example, converting a floating-point value to an integral value may introduce truncation errors (loss of the fractional part) in the result.
7.8 The .NET Framework Class Library • Predefined classes are grouped into categories of related classes called namespaces. • Together, these namespaces are referred to as the .NET Framework Class Library.
7.8 The .NET Framework Class Library (Cont.) • Some key Framework Class Library namespaces are described in Fig. 7.6. Fig. 7.6|Framework Class Library namespaces (a subset). (Part 1 of 2.)
7.8 The .NET Framework Class Library (Cont.) Fig. 7.6|Framework Class Library namespaces (a subset). (Part 2 of 2.)
7.8 The .NET Framework Class Library (Cont.) Good Programming Practice 7.2 The online .NET Framework documentation is easy to search and provides many details about each class. As you learn each class in this book, you should review the class in the online documentation for additional information.
7.9 Case Study: Random-Number Generation • Objects of class Random can produce random byte, int and double values. • Method Next of class Random generates a random int value. • The values returned by Next are actually pseudorandom numbers—a sequence of values produced by a complex mathematical calculation. • The calculation uses the current time of day to seed the random-number generator.
7.9 Case Study: Random-Number Generation (Cont.) • If you supply the Next method with an argument—called the scaling factor—it returns a value from 0 up to, but not including, the argument’s value. • You can also shift the range of numbers produced by adding a shifting value to the number returned by the Next method. • Finally, if you provide Next with two int arguments, it returns a value from the first argument’s value up to, but not including, the second argument’s value.
Outline Rolling a Six-Sided Die • Figure 7.7 shows two sample outputs of an application that simulates 20 rolls of a six-sideddie and displays each roll’s value. RandomIntegers.cs (1 of 2 ) Create the Random object randomNumbers to produce random values. Fig. 7.7 | Shifted and scaled random integers. (Part 1 of 2.)
Outline RandomIntegers.cs (2 of 2 ) Call Next with two arguments. Fig. 7.7 | Shifted and scaled random integers. (Part 2 of 2.)