Methods - PowerPoint PPT Presentation

1 / 12
About This Presentation
Title:

Methods

Description:

a method called isPrime that tests whether an integer is prime ... boolean returnValue = true; // assume x is prime unless we find a divisor ... – PowerPoint PPT presentation

Number of Views:35
Avg rating:3.0/5.0
Slides: 13
Provided by: foxr
Category:
Tags: methods | prime

less

Transcript and Presenter's Notes

Title: Methods


1
Methods
  • We have been using Java methods since the first
    day of the course. For example, the following
    methods are provided by the Java libraries
  • Math.abs()
  • Math.sqrt()
  • Graphics.drawLine()
  • Graphics.fillRect()
  • JOptionPane.showInputDialog()
  • JOptionPane.showMessageDialog()

2
Methods
  • We have also been writing some user defined
    methods as well, namely
  • - the main method
  • - the paintComponent method

3
Methods
  • Today we will look more deeply into how we can
    create our own methods.
  • Writing our own methods is basically a process
    whereby we get to define new instructions in Java
    that we can then call from our program
  • For example, we might want to write
  • a method called isPrime that tests whether an
    integer is prime
  • a method called courseGrade that takes a students
    exams scores and returns his/her course grade
  • a method called isWinner that takes a tic-tac-toe
    board and tests whether a particular player has
    won the game

4
Components of a Method
  • A method consists of a method header and a method
    body
  • The header contains the name of the method, the
    type it will return (if any) and parameters
  • The body consists of variable declarations and
    executable statements

5
Skeleton of a Method
public static returntype name(parameter
list) declared constants
declared variables executable
statements return statement

Method header Method body
All of our methods (for now) will be defined as
public static The return type is the type of
value returned in the return statement if there
is one, if not, we use the word void to denote
that the method returns no value The executable
statements are any type that weve already
covered including calls to other methods
6
Some Examples
public static int larger(int x, int y)
if(x gt y) return x else return y public
static String getInitials(String first, String
middle, String last) return
first.toUpperCase().charAt(0) "."
middle.toUpperCase().charAt(0) "."
last.toUpperCase().charAt(0) "."
public static double computeAverage(int array,
int n) int sum 0 for (int
i0 iltn i) sum arrayi
double average (double) sum / n
return average
sum, i and average are known as local variables
they are known only within this method
7
Invoking a Method
  • One method calls another method
  • the method call is accomplished by listing the
    name of the method and parens as in doIt( )
  • When a method is called
  • the calling method suspends itself
  • and the called method begins
  • The called method executes until it terminates
    and then control returns to the calling method
  • Method calls can be nested as shown below
  • main calls doIt( ) and main suspends
  • doIt( ) calls helpMe( ) and doIt suspends
  • helpMe executes until it completes
  • doIt resumes from right after the point
  • where it called helpMe
  • when helpMe ends, main resumes


8
Parameters
  • To communicate between the calling method and the
    called method, parameters are passed
  • Parameters are lists of variables or values to be
    used
  • Without the parameters, the method does not
    receive any information from the calling method
    so does not know anything specific
  • For instance, a method that computes sales tax
    needs to know how much the sale was in order to
    compute the tax
  • Or the previous method that determined someones
    initials needed to know that persons name
  • Note that parameters must match in terms of the
    type of value and the number of parameters, but
    the names may differ

9
Actual vs. Formal Parameters
  • Actual parameters
  • the parameters listed in the method call
  • Formal parameters
  • the parameters listed in the method header
  • The number of parameters in both list must be the
    same, and the types must be the same, but their
    names may differ

Here we see that the method is called passing
firstnum and secnum, but the formal parameters
are named x and y instead
10
Complete Example
  • We put together several of the concepts discussed
    to write a method that is passed 4 test scores,
    computes the average and based on the average,
    returns a letter grade (a char)

public static char returnGrade(int exam1, int
exam2, int exam3, int exam4) int sum
double average sum (exam1 exam2
exam3 exam4) average (double) sum /
4.0 if (average gt 90.0) return A
else if (average gt 80.0) return B
else if (average gt 70.0) return C else
if (average gt 60.0) return D else
return F
Notice that this method will return one of A,
B, C, D, or F if our method ended with
the statement else if(average gt0) return F we
would get a syntax error because Java is not
convinced that any of the return statements would
execute So be aware of this problem in Java and
make sure that, if the method is to return a
value, it definitely will under all circumstances
11
Complete Method Calling Example
public class PrimeNumbers public static
void main(String args)
System.out.println("I will tell you all prime
numbers between 1 and 100") for (j1
jlt100 j) if (isItPrime(j))
System.out.println(j " is a prime number")
// end main method public static
boolean isItPrime(int x) int limit
2 boolean returnValue true //
assume x is prime unless we find a divisor
if (x gt 1) while (returnValue
limit lt x) if (x limit 0)
returnValue false // divisor found, x is not
prime else limit
return returnValue // end isItPrime
method // end PrimeNumbers class
12
Complete Method Calling Example
public class PrimeNumbers public static
void main(String args)
System.out.println("I will tell you all prime
numbers between 1 and 100") for (int
j1 jlt100 j) if
(isItPrime(j))
System.out.println(j " is a prime number")
// end main method public static
boolean isItPrime(int x) if (x lt
2) return false int
trialDivisor 2 boolean returnValue
true // assume x is prime unless we find a
divisor while (returnValue
trialDivisor lt x) if (x limit 0)
returnValue false // divisor
found, x is not prime else
limit return
returnValue // end isItPrime method //
end PrimeNumbers class
Write a Comment
User Comments (0)
About PowerShow.com