CS 106 Introduction to Computer Science I 10 / 10 / 2007 Instructor: Michael Eckmann.

Slides:



Advertisements
Similar presentations
Procedural programming in Java
Advertisements

BBS514 Structured Programming (Yapısal Programlama)1 Functions and Structured Programming.
CS 106 Introduction to Computer Science I 02 / 29 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 26 / 2007 Instructor: Michael Eckmann.
JavaScript Part for Repetition Statement for statement Cpecifies each of the items needed for counter-controlled repetition with a control variable.
Introduction to Computers and Programming Lecture 11: Introduction to Methods Professor: Evan Korth New York University.
CS 106 Introduction to Computer Science I 02 / 18 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 12 / 04 / 2006 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 10 / 11 / 2006 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 11 / 09 / 2007 Instructor: Michael Eckmann.
CS 206 Introduction to Computer Science II 01 / 21 / 2009 Instructor: Michael Eckmann.
Introduction to Computers and Programming Introduction to Methods in Java.
CS 106 Introduction to Computer Science I 01 / 30 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 11 / 06 / 2006 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 12 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 21 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 25 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 26 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 11 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 27 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 22 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 10 / 04 / 2006 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 28 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 28 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 11 / 08 / 2006 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 30 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 20 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 10 / 09 / 2006 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 03 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 08 / 2010 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 24 / 2010 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 19 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 10 / 15 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 02 / 23 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 09 / 28 / 2007 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 10 / 16 / 2006 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 17 / 2008 Instructor: Michael Eckmann.
11 Chapter 5 METHODS. 22 INTRODUCTION TO METHODS A method is a named block of statements that performs a specific task. Other languages use the terms.
Introduction to Methods
C Functions Programmer-defined functions – Functions written by the programmer to define specific tasks. Functions are invoked by a function call. The.
© Copyright 1992–2004 by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. C How To Program - 4th edition Deitels Class 05 University.
Chapter 06 (Part I) Functions and an Introduction to Recursion.
CS 106 Introduction to Computer Science I 01 / 31 / 2007 Instructor: Michael Eckmann.
1 CISC181 Introduction to Computer Science Dr. McCoy Lecture 6 September 17, 2009.
Procedural programming in Java Methods, parameters and return values.
Starting Out with Java: From Control Structures through Objects Fifth Edition by Tony Gaddis Chapter 5: Methods.
CS 376b Introduction to Computer Vision 01 / 23 / 2008 Instructor: Michael Eckmann.
© Copyright 1992–2004 by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. Functions Outline 5.1Introduction 5.2Program Modules.
KIC/Computer Programming & Problem Solving 1.  Introduction  Program Modules in C  Math Library Functions  Functions  Function Definitions  Function.
1 Methods Introduction to Methods Passing Arguments to a Method More About Local Variables Returning a Value from a Method Problem Solving with Methods.
C++ Programming: Program Design Including Data Structures, Fourth Edition Chapter 6: User-Defined Functions I.
CS 106 Introduction to Computer Science I 02 / 01 / 2008 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 03 / 02 / 2007 Instructor: Michael Eckmann.
Functions Math library functions Function definition Function invocation Argument passing Scope of an variable Programming 1 DCT 1033.
C++ Programming: Program Design Including Data Structures, Fourth Edition Chapter 6: User-Defined Functions I.
C++ Programming: From Problem Analysis to Program Design, Fourth Edition Chapter 6: User-Defined Functions I.
CS 106 Introduction to Computer Science I 03 / 22 / 2010 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 09 / 10 / 2007 Instructor: Michael Eckmann.
CSIS 113A Lecture 5 Functions. Introduction to Functions  Building Blocks of Programs  Other terminology in other languages:  Procedures, subprograms,
CS 106 Introduction to Computer Science I 10 / 08 / 2007 Instructor: Michael Eckmann.
L131 Assignment Operators Topics Increment and Decrement Operators Assignment Operators Debugging Tips rand( ) math library functions Reading Sections.
CS 106 Introduction to Computer Science I 02 / 15 / 2008 Instructor: Michael Eckmann.
Chapter 9: Value-Returning Functions
CSC113: Computer Programming (Theory = 03, Lab = 01)
User-Defined Functions
Subroutines Idea: useful code can be saved and re-used, with different data values Example: Our function to find the largest element of an array might.
Chapter 9: Value-Returning Functions
Chapter 6 – Methods Topics are:
Presentation transcript:

CS 106 Introduction to Computer Science I 10 / 10 / 2007 Instructor: Michael Eckmann

Michael Eckmann - Skidmore College - CS Fall 2007 Today’s Topics Comments and/or Questions? code using Math class methods methods –understanding how they work –creating our own

Math class Let's look at the Java API for the Math class. and write some code using these methods: abs cos, sin, tan ceil pow random sqrt Michael Eckmann - Skidmore College - CS Fall 2007

what is a method A method is small piece of a program designed to achieve some specific task and usually returns some piece of information. A method is invoked by a method call. To call a method, you provide its name and the correct arguments that are necessary for the method to execute. Michael Eckmann - Skidmore College - CS Fall 2007

methods Here’s a good analogy of a worker and boss to describe methods and their callers. A boss (the caller) asks a worker (the method that is called) to perform a task (the code in the method) and report (return results) back when the task is done. Michael Eckmann - Skidmore College - CS Fall 2007

methods All methods are defined within some class. we have seen the main method defined in the class of every application so far. Michael Eckmann - Skidmore College - CS Fall 2007

other methods we’ve used We have used other methods available in the Java API, methods like parseInt and parseFloat and println are available to us to use in their respective classes Integer, Float and System.out The methods in the Math class are other examples. These methods were defined for us to do a specific task. We call them when we need them. e.g. in the case of Integer.parseInt --- it’s task is to convert a String into an int. It takes a String as an argument (parameter) and returns a value of type int. Michael Eckmann - Skidmore College - CS Fall 2007

other methods we’ve used e.g. in the case of Integer.parseInt --- it’s task is to convert a String into an int. It takes a String as an argument (parameter) and returns a value of type int. example of a call to this method: some_int = Integer.parseInt( some_str ); In this example, some_str is the argument that is being passed in to the parseInt method and some_int is the variable that will get set to the value returned by the method. Michael Eckmann - Skidmore College - CS Fall 2007

methods We can create our own methods that we can call to perform specific tasks. Let’s say we’re writing a program to handle employee’s salaries. We might need to compute a salary after a raise. This example method would need to have access to the current salary and the raise percentage. It would then calculate the salary after the raise and return this value. Michael Eckmann - Skidmore College - CS Fall 2007

example of a programmer-defined method we might name this method salary_after_raise we need to take in two values, one for the current salary and one for the raise percentage. What primitive type might these be? we also need to return the salary that is computed. What primitive type might this returned value be? Michael Eckmann - Skidmore College - CS Fall 2007

example of a programmer-defined method so, this method could look like: public static double salary_after_raise(double curr_sal, double raise_pct ) { double new_sal; new_sal = curr_sal * ( 1 + raise_pct / 100 ); return new_sal; } Michael Eckmann - Skidmore College - CS Fall 2007

example of a programmer-defined method to call this method from some other method within the same class do the following: // example variable declarations... double new_salary; double old_sal = 35000; double raise = 4.5; // our call to the salary_after_raise method new_salary = salary_after_raise( old_sal, raise ); Michael Eckmann - Skidmore College - CS Fall 2007

example of a programmer-defined method Let’s look at a complete program that contains this method and calls it several times. Michael Eckmann - Skidmore College - CS Fall 2007

example of a programmer-defined method When certain code can be used in several places in a program, you may want to create a method containing that code. Then, wherever that code would have been, a simple method call appears. Programmer defined methods also aid in the ability to understand a program (readability) and make changes (maintainability). Michael Eckmann - Skidmore College - CS Fall 2007

when does a method end it’s execution? when it hits a return; statement when it hits a return some_expression; statement or, when it hits the right curly brace of the method whichever comes first. when the method ends its execution, the program execution continues back at the method call (from where the method was called)

more about methods methods that do not return a value are of type void (like the main method.) Methods can have 0 or more parameters separated by commas. Those with 0 parameters are defined with nothing between the parentheses to call a method with no parameters, you must still use the parentheses but with nothing between them Note that the return type of a method can be different than any or all of the types of parameters that get passed in.

example method that returns nothing and has no parameters public static void print_error_msg() { System.out.println(“Invalid entry.”); System.out.println(“You must reenter.”); } how to call this method: note that there are no arguments passed in nor is there a variable to which to assign the returned value (because it doesn’t return a value.) print_error_msg();

example method that returns nothing but has one parameter public static void print_msg(String the_msg) { System.out.println(“The message is: ” + the_msg); // note: no return statement since nothing to return // The return type of this method is void. } how to call this method: print_msg(“Good afternoon gentlemen. I am a HAL 9000 computer.”);

example method that returns a String but has no parameters public static String random_string() { int num = (int) (Math.random() * 3); if (num == 0) return “Hello”; if (num == 1) return “Goodbye”; if (num == 2) return } how to call this method: System.out.println(“the random string is: “ + random_string());

reasons to create and use methods separation and modularization of ideas is helpful when writing large programs because smaller parts of a problem are easier to solve the individual methods can be tested and confirmed correct to reduce debugging woes methods lend themselves to software reuse less code repetition (how come?) more readable, better designed code

scope the scope of an identifier (a variable, reference or method name) is defined as the portion of the program that can access that identifier the two scopes for identifiers are class scope and block scope class scope starts at the opening left curly brace of a class definition and ends at its corresponding right curly brace block scope refers to identifiers that are accessible from when they are declared until the next right curly brace.

scope we've seen block scope when we declare a variable inside the main method. we've seen block scope when we declare a variable in the first expression of a for loop. we've seen block scope when we declare a variable within the curly braces of a while loop. etc. Does anyone recall? What makes these variable have block scope?

variables in methods variables declared in methods are said to be local variables --- they are local to that method parameters of the method are also considered local variables to that method. they are not usable, nor are they even known outside that method --- they have block scope they are created (memory is allocated for them) on entry into the method during execution they are destroyed (memory for them is marked for deallocation) on exit from the method

some method terminology the name of the method is salary_after_raise, and the body of the method is the three lines of code between the curly braces. public double salary_after_raise(double curr_sal, double raise_pct) { double new_sal; new_sal = curr_sal * ( 1 + raise_pct / 100 ); return new_sal; }

example of local variables in this method, new_sal is a local variable, and the parameters of the method: curr_sal and raise_pct are also local variables. public double salary_after_raise(double curr_sal, double raise_pct) { double new_sal; new_sal = curr_sal * ( 1 + raise_pct / 100 ); return new_sal; } they are only known to this method what does that mean “only known to this method”

return type and argument types the return type of the method is double the two parameters are of type double public double salary_after_raise(double curr_sal, double raise_pct ) { double new_sal; new_sal = curr_sal * ( 1 + raise_pct / 100 ); return new_sal; } note that the return statement returns the double and this is where the execution of the method ends

method calls in the call of the method, two values are passed in to the method (we call them the arguments) and the value returned by the method call is stored in new_salary double new_salary; double old_salary = 300; double raise = 4.5; // our call to the salary_after_raise method new_salary = salary_after_raise( old_salary, raise );

variables passed in as arguments when calling a method the values of variables (of primitive types) that are passed into a method as arguments remain unchanged after the method ends its execution even if the corresponding parameter in the method changes its value, this change is only local to the method, and the value is not “passed back out” of the method. we’ll see this in the factorial method on the next slide.

compute_factorial method public static int compute_factorial(int num) { int temp_factorial=1; while (num > 0) { temp_factorial = temp_factorial * num; num--; } return temp_factorial; }

compute_factorial method this method is a programmer-defined method (that is, we make up the name and the purpose of the method.) the name of the method is: compute_factorial the return type of the method is: int there is one parameter to the method, which is: num (of type int) note that the value of num inside the method changes (it gets decremented in the loop) but this is only a local change the other local variable (temp_factorial) is used to compute the factorial and its value is the one that is returned to the caller.

compute_factorial method note that the value of num inside the method changes (it gets decremented in the loop) but this is only a local change the variable sent in as an argument does NOT change its value Let’s write a quick program to show how the variable that is “passed in” to the method as an argument doesn’t actually get changed. We’ll print the argument’s value before and after the call to the method.