Presentation is loading. Please wait.

Presentation is loading. Please wait.

CSCI 51 Introduction to Programming Dr. Joshua Stough February 24, 2009.

Similar presentations


Presentation on theme: "CSCI 51 Introduction to Programming Dr. Joshua Stough February 24, 2009."— Presentation transcript:

1 CSCI 51 Introduction to Programming Dr. Joshua Stough February 24, 2009

2 Today in CSCI 51 Making your own methods –Procedural abstraction. Object-Oriented Design –Data abstraction

3 6 Fundamental Concepts of Programming Variables, and Assignment (data storage) Expressions, and Data Retrieval Conditional statements (making choices) Loops (repetition) Structured data, arrays (data abstraction) Functions (procedural abstraction)

4 What is a Method? Group of programming statements that we give a name Statements usually work together to perform a specific task/operation Every method belongs to a class

5 Why Use Methods? To divide complex programs into manageable pieces Abstraction –provide an operation to be performed on an object (ex: computeArea) Code Re-use –write a small piece of code that can be used (called) multiple times (saves typing)

6 Methods Pre-defined methods –provided by Java standard library –we've used these before –Math class (Math.pow, Math.sqrt,...) –Integer class (Integer.parseInt,...) User-defined methods –you write these

7 String Methods boolean equals(String str) int length() String toLowerCase() char charAt(int index) the result can be stored in a boolean variable or used in a boolean expression (return type) the method needs to be given another String (parameter) method name method specification, not syntax of use

8 Using String Methods list of String methods: Chapter 3 Steps: –create a String object –put data into the object –use the dot operator to "call" the method String line; line = keyboard.readLine(); String greeting = "Hello"; int len = line.length(); greeting = greeting.toUpperCase(); char ch = greeting.charAt(3);

9 Two Types of Methods Value-returning methods –"return", "evaluate to", "result in" some value –like mathematical functions –only returns a single value Void methods –performs operations but returns no value

10 Value-Returning Methods Think mathematical function f(x) = 2x + 5f(x, y) = 2x + y f(1) = 7f(1, 5) = 7 f(2) = 9f(2, 3) = 7 f(3) = 11f(3, 1) = 7 Can have multiple arguments (parameters) Only one result of the function

11 Using Methods What You Need To Know 1.Name of the method 2.Number of parameters 3.Data type of each parameter 4.Data type of value computed (returned) by the method 5.The code required to accomplish the task * Only need to know 1-4 for predefined methods

12 Value-Returning Methods Uses Save the value for future calculation Use the value in a calculation Print the value So, often used in expressions: x = Math.pow (y, 2); z = a + Math.pow (y, 2) + x; System.out.println (Math.pow (y, 2));

13 Control Flow Program control flow –execution always begins with the first statement in the method main –other methods execute only when called Method control flow –when a method is invoked, the flow of control jumps to the method and the computer executes its code –when complete, the flow of control returns to the place where the method was called and the computer continues executing code

14 Method Declaration Specifies the code that will be executed when the method is invoked (or called) Located inside a class definition Contains –method header –method body

15 Method Header public static int countCharInWord (char ch, String word) method name return type formal parameter list The parameter list specifies the type and name of each parameter The name of a parameter in the method declaration is called a formal argument A method declaration begins with a method header visibility modifiers

16 int number = countCharInWord ('e', "Heels"); 2 Return Type Indicates the type of value that the method evaluates to (or, sends back to the calling location) –primitive data type –class name –void reserved word indicating that nothing is returned When a value is returned, the method call is replaced with the returned value

17 Method Body The method header is followed by the method body { int count = 0; for (int i = 0; i<word.length(); i++) { if (word.charAt(i) == ch) { count++; } return count; } The return expression must be consistent with the return type ch and word are local data They are created each time the method is called, and are destroyed when it finishes executing public static int countCharInWord (char ch, String word)

18 Parameters Each time a method is called, the actual parameters in the call are copied into the formal parameters int num = countCharInWord ('e', "Heels"); { int count = 0; for (int i = 0; i<word.length(); i++) { if (word.charAt(i) == ch) { count++; } return count; } public static int countCharInWord (char ch, String word)

19 The return Statement Tells the computer to "return" back to where the call was originally made. Specifies the value that will be returned return expression; The data type of expression must match the method's return type Methods with return types of void usually don't (but can) have a return statement Value-returning methods must have at least one return statement

20 Using return public static double larger (double x, double y) { double max; if(x >= y) max = x; else max = y; return max; } public static double larger (double x, double y) { if(x >= y) return x; else return y; } These are equivalent methods.

21 Void Methods Does not return a value Has a return type of void Similar in structure to value-returning methods Call to method is always a stand-alone statement Can use return statement to exit method early

22 The main Method The main method looks just like all other methods public static void main (String[] args) modifiersreturn type method name parameter list

23 Code Re-Use Methods can also be used to save typing If you have a section of code that does one task and it needs to be done multiple times, you can write it as a method Example: you want to print the following heading to start your program *********************************** ************ Blackjack ************ ***********************************

24 public class MyProgram { public static void main (String[] args) { printStars(); System.out.print ("************"); System.out.print (" Blackjack "); System.out.println ("************"); printStars(); } public static void printStars() { System.out.print ("***************"); System.out.println ("*****"); }

25 printStars What if we wanted to change the number of stars printed on the line? give the number of stars as a parameter

26 public class MyProgram { public static void main (String[] args) { printStars(35); System.out.print ("************"); System.out.print (" Blackjack "); System.out.println ("************"); printStars(35); } public static void printStars(int numStars) { for (int i = 0; i<numStars; i++) { System.out.print ("*"); } System.out.println(); }

27 printStars What if we wanted to change the character printed (something besides stars?) change the name of the method (because it may not print stars) --> printChars give the character as a parameter

28 public class MyProgram { public static void main (String[] args) { printChars(35, '#'); System.out.print ("###############"); System.out.print (" Blackjack "); System.out.println ("###############"); printChars(35, '#'); } public static void printChars(int num, char ch) { for (int i = 0; i<num; i++) { System.out.print (ch); } System.out.println(); }

29 printStars (35); printStars (30 + 5); int num = 35; printStars (num); Parameters Formal parameters –variable declarations in the method header –automatic local variables for the method Actual parameters –actual values that are passed to the method –can be variables, literals, or expressions

30 Object-Oriented Design What is it? Designing a solution to a problem by first identifying components called objects, and determining how the objects interact with each other

31 Objects VCR Example Use it without knowing how it's made Internal parts are hidden -- only interact with the provided buttons Can't modify the functions of a VCR -- record button always records, play button always plays Same is true for with objects (like strings) that are provided by Java

32 Objects Consists of data and operations on the data Data - descriptive characteristics Operations - what it can do (or what can be done to it) Example A coin that can be flipped so that its face shows either "heads" or "tails" –data: its current face (heads or tails) –operations: it can be flipped Operations can change data.

33 Objects And Methods and Classes We represent operations with methods –group of statements that are given a name We can use objects and their methods without knowing exactly how the methods work An object is an instance of a class. A class is the blueprint of an object. –the class provides the methods that can operate on an object of that class

34 Classes A class contains data declarations and method declarations A class is a description of an object –just a model, not an actual object –you can think of the concept of a book without thinking of a particular book A class is no more an object than a blueprint is an actual house

35 Object-Oriented Design Simplified Methodology 1. Write down detailed description of problem 2. Identify all (relevant) nouns and verbs 3. From list of nouns, select objects 4. Identify data components of each object 5. From list of verbs, select operation

36 Object-Oriented Design Example 1 Problem Statement –Write a program to input the length and width of a rectangle and calculate and print the perimeter and area of the rectangle

37 Example 1 Building a Rectangle Identify nouns –length, width, rectangle, perimeter, area Identify each class –length of a rectangle –width of a rectangle –perimeter of a rectangle –area of a rectangle

38 Example 1 Building a Rectangle Identify data members for each class –nouns: length, width, area, perimeter –what are the essential nouns for describing the rectangle? –area and perimeter can be computed if we know the length and width

39 Example 1 Building a Rectangle Identify operations for each class –input, calculate, print –setLength –setWidth –computePerimeter –computeArea –print –getLength –getWidth directly from problem statement customary to include operations to get the value of the data members

40 class Rectangle Data Members and Operations Last Step: design and implement an algorithm for each operation class name data members operations (methods)

41 Anatomy of a Class A class contains data declarations and method declarations int width; int length; Data declarations Method declarations (operations)

42 ` Rectangle A class (the concept) length = 15, width = 3 An object (the realization) length = 20, width = 6 length = 15, width = 15 Multiple objects from the same class

43 Non-Concrete Objects Objects in programs don't always have real-world analogs Example object: error message data: text of the error message operation: print the text of the error message to the screen


Download ppt "CSCI 51 Introduction to Programming Dr. Joshua Stough February 24, 2009."

Similar presentations


Ads by Google