ch03 implementing classes

Upload: cindy-gasparico-pacheco

Post on 04-Apr-2018

223 views

Category:

Documents


0 download

TRANSCRIPT

  • 7/31/2019 Ch03 Implementing Classes

    1/20

    Chapter 3

    Implementing Classes

    Chapter Goals

    l To become familiar with the process of implementing classesl To be able to implement simple methodsl To understand the purpose and use of constructorsl To understand how to access instance fields and local variablesl To appreciate the importance of documentation comments

    Black Boxes

    l A black box magically does its thingl Hides its inner workingsl Encapsulation: the hiding of unimportant detailsl What is the right conceptfor each particular black box?l Concepts are discovered through abstractionl Abstraction: taking away inessential features, until only the essence of the concept remainsl In object-oriented programming the black boxes from which a program is manufactured are called

    objects

    Levels of abstraction: A Real Life Example

    l Black boxes in a car: transmission, electronic control module, etc.

    Page 1 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    2/20

    Levels of abstraction: A Real Life Example

    l Users of a car do not need to understand how black boxes workl Interaction of a black box with outside world is well-defined

    Drivers interact with car using pedals, buttons, etc. Mechanic can test that engine control module sends the right firing signals to the spark

    plugs For engine control module manufacturers, transistors and capacitors are black boxes

    magically produced by an electronics component manufacturerl Encapsulation leads to efficiency:

    Mechanic deals only with car components (e.g. electronic control module), not with sensorsand transistors

    Driver worries only about interaction with car (e.g. putting gas in the tank), not about motoror electronic control module

    Levels of abstraction: Software Design

    Page 2 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    3/20

    Levels of abstraction: Software Design

    l Old times: computer programs manipulated primitive types such as numbers and characters

    l Manipulating too many of these primitive quantities is too much for programmers and leads toerrors

    l Solution: Encapsulate routine computations to software black boxesl Abstraction used to invent higher-level data typesl In object-oriented programming, objects are black boxesl Encapsulation: Programmer using an object knows about its behavior, but not about its internal

    structurel In software design, you can design good and bad abstractions with equal facility; understanding

    what makes good design is an important part of the education of a software engineerl First, define behavior of a class; then, implement it

    Self Check1. In Chapters 1 and 2, you used System.out as a black box to cause output to appear on the screen.

    Who designed and implemented System.out?2. Suppose you are working in a company that produces personal finance software. You are asked to

    design and implement a class for representing bank accounts. Who will be the users of your class?

    Answers

    Page 3 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    4/20

    1. The programmers who designed and implemented the Java library2. Other programmers who work on the personal finance application

    Designing the Public Interface of a Class

    Behavior of bank account (abstraction):

    l deposit moneyl withdraw moneyl get balance

    Designing the Public Interface of a Class: Methods

    Methods ofBankAccount class:

    l deposit

    l withdrawl getBalance

    We want to support method calls such as the following:

    harrysChecking.deposit(2000);

    harrysChecking.withdraw(500);

    System.out.println(harrysChecking.getBalance());

    Designing the Public Interface of a Class: Method Definition

    l access specifier (such as public)l return type (such as String or void)l method name (such as deposit)l list of parameters (double amount for deposit)

    l method body in { }

    Examples:

    l public void deposit(double amount) { . . . }l public void withdraw(double amount) { . . . }

    l public double getBalance() { . . . }

    Syntax 3.1: Method Definition

    accessSpecifier returnType methodName(parameterType parameterName, . . .)

    {

    method body

    }

    Page 4 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    5/20

    Designing the Public Interface of a Class: Constructor Definition

    l A constructor initializes the instance variablesl Constructor name = class name

    public BankAccount(){

    // body--filled in later

    }

    l Constructor body is executed when new object is createdl Statements in constructor body will set the internal data of the object that is being constructedl All constructors of a class have the same namel Compiler can tell constructors apart because they take different parameters

    Syntax 3.2 : Constructor Definition

    BankAccount Public Interface

    Example:

    Purpose:

    To define the behavior of a method

    public void deposit(double amount)

    {

    . . .

    }

    Example:

    Purpose:

    To define the behavior of a constructor

    accessSpecifier ClassName(parameterType parameterName, . . .)

    {

    constructor body

    }

    public BankAccount(double initialBalance)

    {

    . . .

    }

    Page 5 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    6/20

    The public constructors and methods of a class form thepublic interface of the class.

    public class BankAccount

    {

    // Constructors

    public BankAccount()

    {

    // body--filled in later

    }public BankAccount(double initialBalance)

    {

    // body--filled in later

    }

    // Methods

    public void deposit(double amount)

    {

    // body--filled in later

    }

    public void withdraw(double amount)

    {

    // body--filled in later}

    public double getBalance()

    {

    // body--filled in later

    }

    // private fields--filled in later

    }

    Syntax 3.3 : Class Definition

    Self Check

    Example:

    Purpose:

    To define a class, its public interface, and its implementation details

    accessSpecifierclass ClassName

    {

    constructors

    methods

    fields

    }

    public class BankAccount

    {

    public BankAccount(double initialBalance) { . . . }

    public void deposit(double amount) { . . . }

    . . .}

    Page 6 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    7/20

    3. How can you use the methods of the public interface to empty the harrysChecking bank account?

    4. Suppose you want a more powerful bank account abstraction that keeps track of an accountnumberin addition to the balance. How would you change the public interface to accommodatethis enhancement?

    Answers

    3. harrysChecking.withdraw(harrysChecking.getBalance()) 4. Add an accountNumber parameter to the constructors, and add a getAccountNumber method.

    There is no need for a setAccountNumber methodthe account number never changes afterconstruction.

    Commenting the Public Interface

    /**

    Withdraws money from the bank account.

    @param the amount to withdraw

    */

    public void withdraw(double amount)

    {

    // implementation filled in later

    }

    /**

    Gets the current balance of the bank account.

    @return the current balance

    */

    public double getBalance(){

    // implementation filled in later

    }

    Class Comment

    /**

    A bank account has a balance that can

    be changed by deposits and withdrawals.

    */

    public class BankAccount

    {

    . . .

    }

    l Provide documentation comments for every class every method every parameter every return value.

    Page 7 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    8/20

    Javadoc Method Summary

    Javadoc Method Detail

    Page 8 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    9/20

    Self Check

    5. Suppose we enhance the BankAccount class so that each account has an account number. Supply

    a documentation comment for the constructor BankAccount(int accountNumber, doubleinitialBalance)

    6. Why is the following documentation comment questionable?

    /**

    Each account has an account number.

    @return the account number of this account.

    */

    int getAccountNumber()

    Answers

    5. /**Constructs a new bank account with a given initial balance.

    @param accountNumber the account number for this account

    @param initialBalance the initial balance for this account*/

    6. The first sentence of the method description should describe the methodit is displayed inisolation in the summary table

    Instance Fields

    l An object stores its data in instance fieldsl Field: a technical term for a storage location inside a block of memory

    l Instance of a class: an object of the classl The class declaration specifies the instance fields:

    public class BankAccount

    {

    . . .

    private double balance;

    }

    Instance Fields

    l An instance field declaration consists of the following parts: access specifier (such as private) type of variable (such as double) name of variable (such as balance)

    l Each object of a class has its own set of instance fieldsl You should declare all instance fields as private

    Instance Fields

    Page 9 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    10/20

    Syntax 3.4 : Instance Field Declaration

    Accessing Instance Fields

    l The deposit method of the BankAccount class can access the private instance field:public void deposit(double amount)

    {

    double newBalance =balance + amount;

    Example:

    Purpose:

    To define a field that is present in every object of a class

    accessSpecifierclass ClassName

    {

    . . .

    accessSpecifier fieldType fieldName;

    . . .

    }

    public class BankAccount

    {

    . . .

    private double balance;

    . . .

    }

    Page 10 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    11/20

    balance = newBalance;

    }

    l Other methods cannot:public class BankRobber

    {

    public static void main(String[] args)

    {

    BankAccount momsSavings = new BankAccount(1000);

    . . . momsSavings.balance = -1000; // ERROR

    }

    }l Encapsulation = Hiding data and providing access through methods

    Self Check

    7. Suppose we modify the BankAccount class so that each bank account has an account number.How does this change affect the instance fields?

    8. What are the instance fields of the Rectangle class?

    Answers

    7. An instance fieldprivate int accountNumber;needs to be added to the class

    8. private int x;private int y;

    private int width;

    private int height;

    Implementing Constructors

    l Constructors contain instructions to initialize the instance fields of an object

    public BankAccount()

    {

    balance = 0;

    }

    public BankAccount(double initialBalance)

    {

    balance = initialBalance;

    }

    Constructor Call Example

    l BankAccount harrysChecking = new BankAccount(1000); Create a new object of type BankAccount Call the second constructor (since a construction parameter is supplied) Set the parameter variable initialBalance to 1000 Set the balance instance field of the newly created object to initialBalance

    Page 11 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    12/20

    Return an object reference, that is, the memory location of the object, as the value of thenew expression

    Store that object reference in the harrysChecking variable

    Implementing Methods

    l Some methods do not return a value

    public void withdraw(double amount)

    {

    double newBalance = balance - amount;

    balance = newBalance;

    }

    l Some methods return an output value

    public double getBalance()

    {

    return balance;

    }

    Method Call Example

    l harrysChecking.deposit(500); Set the parameter variable amount to 500 Fetch the balance field of the object whose location is stored in harrysChecking Add the value of amount to balance and store the result in the variable newBalance

    Store the value ofnewBalance in the balance instance field, overwriting the old value

    Syntax 3.5: The return Statement

    File BankAccount.java

    Example:

    Purpose:

    To specify the value that a method returns, and exit the method immediately. Thereturn value becomes the value of the method call expression.

    returnexpression;orreturn;

    return balance;

    Page 12 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    13/20

    Self Check

    9. How is the getWidth method of the Rectangle class implemented?10. How is the translate method of the Rectangle class implemented?

    Answers9. public int getWidth()

    {

    return width;

    }

    10. There is more than one correct answer. One possible implementation is as follows:

    public void translate(int dx, int dy)

    01: /**

    02: A bank account has a balance that can be changed by

    03: deposits and withdrawals.

    04: */

    05: publicclass BankAccount

    06: {

    07: /**

    08: Constructs a bank account with a zero balance.09: */

    10: public BankAccount()

    11: {

    12: balance = 0;

    13: }

    14:

    15: /**

    16: Constructs a bank account with a given balance.

    17: @param initialBalance the initial balance

    18: */

    19: public BankAccount(double initialBalance)

    20: {

    21: balance = initialBalance;

    22: }

    23:

    24: /**

    25: Deposits money into the bank account.

    26: @param amount the amount to deposit

    27: */

    28: publicvoid deposit(double amount)

    29: {

    30: double newBalance = balance + amount;

    31: balance = newBalance;

    32: }

    33:

    34: /**

    35: Withdraws money from the bank account.36: @param amount the amount to withdraw

    37: */

    38: publicvoid withdraw(double amount)

    Page 13 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    14/20

    {

    int newx = x + dx;

    x = newx;

    int newy = y + dy;

    y = newy;

    }

    Testing a Class

    l Test class: a class with a main method that contains statements to test another class.l Typically carries out the following steps:

    1. Construct one or more objects of the class that is being tested2. Invoke one or more methods3. Print out one or more results

    l Details for building the program vary. In most environments, you need to carry out these steps:1. Make a new subfolder for your program2. Make two files, one for each class3. Compile both files

    4. Run the test program

    File BankAccountTester.java

    Page 14 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    15/20

    Output:

    1500

    Testing With BlueJ

    01: /**

    02: A class to test the BankAccount class.

    03: */

    04: publicclass BankAccountTeste

    05: {

    06: /**

    07: Tests the methods of the BankAccount class.

    08: @param args not used09: */

    10: publicstaticvoid main(String[] args)

    11: {

    12: BankAccount harrysChecking = new BankAccount();

    13: harrysChecking.deposit(2000);

    14: harrysChecking.withdraw(500);

    15: System.out.println(harrysChecking.getBalance());

    16: }

    17: }

    Page 15 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    16/20

    Self Check

    11. When you run the BankAccountTester program, how many objects of class BankAccount areconstructed? How many objects of type BankAccountTester?

    12. Why is the BankAccountTester class unnecessary in development environments that allowinteractive testing, such as BlueJ?

    Answers

    11. One BankAccount object, no BankAccountTester object. The purpose of theBankAccountTester class is merely to hold the main method

    12. In those environments, you can issue interactive commands to construct BankAccount objects,invoke methods, and display their return values

    Page 16 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    17/20

    Categories of Variables

    l Categories of variables1. Instance fields (balance in BankAccount)2. Local variables (newBalance in deposit method)

    3. Parameter variables (amount in deposit method)

    l An instance field belongs to an objectl The fields stay alive until no method uses the object any longerl In Java, the garbage collectorperiodically reclaims objects when they are no longer usedl Local and parameter variables belong to a methodl Instance fields are initialized to a default value, but you must initialize local variables

    Lifetime of Variables

    harrysChecking.deposit(500);

    double newBalance = balance + amount;

    balance = newBalance;

    Page 17 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    18/20

    Self Check

    13. What do local variables and parameter variables have in common? In which essential aspect dothey differ?

    14. During execution of the BankAccountTester program in the preceding section, how manyinstance fields, local variables, and parameter variables were created, and what were their names?

    Answers

    13. Variables of both categories belong to methodsthey come alive when the method is called, andthey die when the method exits. They differ in their initialization. Parameter variables areinitialized with the call values; local variables must be explicitly initialized.

    14. One instance field, named balance. Three local variables, one named harrysChecking and two

    Page 18 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    19/20

    named newBalance (in the deposit and withdraw methods); two parameter variables, both

    named amount (in the deposit and withdraw methods).

    Implicit and Explicit Method Parameters

    l The implicit parameter of a method is the object on which the method is invoked

    l The this reference denotes the implicit parameterl Use of an instance field name in a method denotes the instance field of the implicit parameter

    public void withdraw(double amount)

    {

    double newBalance =balance - amount;

    balance = newBalance;

    }

    l balance is the balance of the object to the left of the dot:

    momsSavings.withdraw(500)

    means

    double newBalance =momsSavings.balance - amount;

    momsSavings.balance = newBalance;

    Implicit Parameters and this

    l Every method has one implicit parameterl The implicit parameter is always called this

    l Exception: Static methods do not have an implicit parameter (more on Chapter 9)l double newBalance = balance + amount;

    // actually means

    double newBalance = this.balance + amount;

    l When you refer to an instance field in a method, the compiler automatically applies it to the this

    parameter

    momsSavings.deposit(500);

    Implicit Parameters and this

    Page 19 of 20Horstmann Chapter 3

    18/01/2012file://G:\Java Clase\Slides\slides03\Ch03\ch03.html

  • 7/31/2019 Ch03 Implementing Classes

    20/20

    Self Check

    15. How many implicit and explicit parameters does the withdraw method of the BankAccount classhave, and what are their names and types?

    16. In the deposit method, what is the meaning ofthis.amount? Or, if the expression has nomeaning, why not?17. How many implicit and explicit parameters does the main method of the BankAccountTester

    class have, and what are they called?

    Answers

    15. One implicit parameter, called this, of type BankAccount, and one explicit parameter, called

    amount, of type double.16. It is not a legal expression. this is of type BankAccount and the BankAccount class has no field

    named amount.

    17. No implicit parameterthe method is staticand one explicit parameter, called args.

    Page 20 of 20Horstmann Chapter 3