1 TCSS 143, Autumn 2004 Lecture Notes Creating Java Classes.

Slides:



Advertisements
Similar presentations
Copyright 2008 by Pearson Education Building Java Programs Chapter 8 Lecture 8-3: Encapsulation, toString reading: self-checks: #13-18,
Advertisements

Lecture 9: More on objects, classes, strings discuss hw3 assign hw4 default values for variables scope of variables and shadowing null reference and NullPointerException.
Chapter 4&5 Defining Classes Copyright © 2010 Pearson Addison-Wesley. All rights reserved.
Singleton vs utility class  at first glance, the singleton pattern does not seem to offer any advantages to using a utility class  i.e., a utility class.
CS0007: Introduction to Computer Programming Introduction to Classes and Objects.
Composition CMSC 202. Code Reuse Effective software development relies on reusing existing code. Code reuse must be more than just copying code and changing.
Effective Java, Chapter 3: Methods Common to All Objects.
1 Class Design CS 3331 Fall Outline  Organizing classes  Design guidelines  Canonical forms of classes equals method hashCode method.
Defining classes and methods Recitation – 09/(25,26)/2008 CS 180 Department of Computer Science, Purdue University.
Road Map Introduction to object oriented programming. Classes
Searching. 2 Searching an array of integers If an array is not sorted, there is no better algorithm than linear search for finding an element in it static.
Searching and Sorting I 1 Searching and Sorting 1.
CS2200 Software Development Lecture: Object class A. O’Riordan, 2008.
ICS201 Lecture 20 : Searching King Fahd University of Petroleum & Minerals College of Computer Science & Engineering Information & Computer Science Department.
1 Java Object Model Part 2: the Object class. 2 Object class Superclass for all Java classes Any class without explicit extends clause is a direct subclass.
Searching. 2 Searching an array of integers If an array is not sorted, there is no better algorithm than linear search for finding an element in it static.
Terms and Rules Professor Evan Korth New York University (All rights reserved)
Searching. Searching an array of integers If an array is not sorted, there is no better algorithm than linear search for finding an element in it static.
Comparing Objects in Java. The == operator When you define an object, for instance Person p = new Person("John", 23); we talk about p as if its value.
Searching Also: Logarithms. 2 Searching an array of integers If an array is not sorted, there is no better algorithm than linear search for finding an.
1 Inheritance and Polymorphism Chapter 9. 2 Polymorphism, Dynamic Binding and Generic Programming public class Test { public static void main(String[]
1 CISC181 Introduction to Computer Science Dr. McCoy Lecture 19 Clicker Questions November 3, 2009.
Chapter 6 Class Inheritance F Superclasses and Subclasses F Keywords: super F Overriding methods F The Object Class F Modifiers: protected, final and abstract.
Writing Classes (Chapter 4)
Introduction to Object Oriented Programming. Object Oriented Programming Technique used to develop programs revolving around the real world entities In.
Searching Also: Logarithms. 2 Searching an array of integers If an array is not sorted, there is no better algorithm than linear search for finding an.
COP INTERMEDIATE JAVA Designing Classes. Class Template or blueprint for creating objects. Their definition includes the list of properties (fields)
Puzzle 3 1  Write the class Enigma, which extends Object, so that the following program prints false: public class Conundrum { public static void main(String[]
Non-static classes Part 2 1. Methods  like constructors, all non-static methods have an implicit parameter named this  for methods, this refers to the.
APCS Java AB 2004 Review of CS1 and CS2 Review for AP test #1 Sources: 2003 Workshop notes from Chris Nevison (Colgate University) AP Study Guide to go.
Objects and Classes Chapter 6 CSCI CSCI 1302 – Objects and Classes2 Outline Introduction Defining Classes for Objects Constructing Objects Accessing.
Java Objects and Classes. Overview n Creating objects that belong to the classes in the standard Java library n Creating your own classes.
10-Nov-15 Java Object Oriented Programming What is it?
Introduction to Java Java Translation Program Structure
Topic 1 Object Oriented Programming. 1-2 Objectives To review the concepts and terminology of object-oriented programming To discuss some features of.
Chapter 10 Defining Classes. The Internal Structure of Classes and Objects Object – collection of data and operations, in which the data can be accessed.
HashCode() 1  if you override equals() you must override hashCode()  otherwise, the hashed containers won't work properly  recall that we did not override.
© Copyright 1992–2004 by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. Chapter 26 - Java Object-Based Programming Outline 26.1Introduction.
COP INTERMEDIATE JAVA Designing Classes. Class Template or blueprint for creating objects. Their definition includes the list of properties (fields)
Chapter 4&5 Defining Classes Copyright © 2010 Pearson Addison-Wesley. All rights reserved.
Chapter 3 Introduction to Classes and Objects Definitions Examples.
CS305j Introduction to Computing Classes II 1 Topic 24 Classes Part II "Object-oriented programming as it emerged in Simula 67 allows software structure.
Application development with Java Lecture 21. Inheritance Subclasses Overriding Object class.
1 Class Design CS 3331 Sec 6.1 & 6.3 of [Jia03]. 2 Outline  Organizing classes  Design guidelines  Canonical forms of classes equals method hashCode.
(c) University of Washington06-1 CSC 143 Java Inheritance Tidbits.
Topic 1 Object Oriented Programming. 1-2 Objectives To review the concepts and terminology of object-oriented programming To discuss some features of.
1 Object-Oriented Programming Inheritance. 2 Superclasses and Subclasses Superclasses and Subclasses  Superclasses and subclasses Object of one class.
Inheritance and Polymorphism
Monday, Jan 27, 2003Kate Gregory with material from Deitel and Deitel Week 4 Questions from Last Week Hand in Lab 2 Classes.
1 CSE 331 The Object class; Object equality and the equals method slides created by Marty Stepp based on materials by M. Ernst, S. Reges, D. Notkin, R.
1 CSE 331 Comparing objects; Comparable, compareTo, and Comparator slides created by Marty Stepp based on materials by M. Ernst, S. Reges, D. Notkin, R.
Topic: Classes and Objects
Searching.
Software Development Java Classes and Methods
CSE 143 Lecture 24 Inheritance and the Object class; Polymorphism
Outline Anatomy of a Class Encapsulation Anatomy of a Method
JAVA CLASSES.
Searching.
CSE 373 Objects in Collections: Object; equals; compareTo; mutability
Suggested self-checks: Section 7.11 #1-11
CSE 142 Lecture Notes Defining New Types of Objects, cont'd.
Special instance methods: toString
CS 112 Programming 2 Lecture 02 Abstract Classes & Interfaces (2)
TCSS 143, Autumn 2004 Lecture Notes
CSE 143 Lecture 24 Inheritance and the Object class; Polymorphism
CSE 143 Lecture 24 Inheritance and the Object class; Polymorphism
CSE 143 Lecture 23 Inheritance and the Object class; Polymorphism
Review for Midterm 3.
Building Java Programs
Presentation transcript:

1 TCSS 143, Autumn 2004 Lecture Notes Creating Java Classes

2 Some terms field: an instance variable; a variable inside an object member: some entity belonging to an object, such as a field or method instance: an object type: a kind of variable; defined by a class

3 What is an object? State represented by object ’ s fields Behavior represented by object ’ s methods Identity represented by object itself, and its ability to distinguish itself from similar objects

4 Principles for designing a class encapsulation: protecting private data of objects from outside tampering private state, public behavior representation-independence: objects that aren ’ t locked in to a particular program or style of application (example: You should generally only call System.out.println from a static method)

5 Public vs. private public : can be seen by all other classes the class's name itself constructors, methods, constants private : can be seen only within this class fields private "helper" methods, if needed note: other objects of same type can access private fields of an object ("canine private") rule of thumb: "private state, public behavior"

6 Static vs. non-static Non-static (sometimes called virtual) attached to an object, and exist / operate within the context of that object affects the scope of what they can see and what they can do there is one copy of every non-static member for each object of the type Static members related to an entire class they are not attached to particular objects of that class ’ s type there is only one copy of a static member: the class ’ s copy

7 Designing a class: fields public class Person { private String myName; private int myPhoneNumber; give fields clear names to differentiate them from local variables (recommended: use prefix 'my') a variable should be made into a field if its state must persist past the end of any one method (all other variables can and should be local to the methods in which they are used) should always be private to provide encapsulation a private field should have a get methods if it should be accessible from outside, and a set method if it should be modifiable from outside refer to a field as fieldname or this. fieldname

8 Designing a class: static fields public class Person { public static final int SENIOR_CITIZEN_AGE = 65; private static int ourPersonCount = 0; data that is shared across the class should be stored in a static field (recommended: use prefix 'our') not often used; usually such 'global variables' are a bad design! public static fields are okay, but only if they are final (cannot be changed). No prefix, but USE_ALL_UPPER_CASE. Refer to static field by its name (SENIOR_CITIZEN_AGE), in code inside the class; and by its classname.fieldname (Person.SENIOR_CITIZEN_AGE), in code outside the class.

9 Designing a class: constructor public class Person { //... public Person(String name, int phoneNum) { myName = name; myPhoneNumber = phoneNum; ourPersonCount++; } constructors should take all arguments necessary to initialize the object's state; no more, no less a constructor should not do any heavy work, such as calling println to print state, or performing expensive computations what if bad values are passed to a constructor? What state should the object have?

10 Designing a class: methods public class Person { //... public boolean isOld() { return myAge >= SENIOR_CITIZEN_AGE; } accessor method: allows you to see state of object generally its name begins with get, but not always ( toString ) mutator method: allows you to modify the object a set method or method with side effects, such as setName or clear avoid mutators that allow undesired setting of state

11 Designing a class: static methods public class PrimeNumber { //... public static int[] sieve(int max) { //... } methods that perform general behavior related to the class, but do not depend on the state of any particular object, should be made static rule of thumb: make it static when you can; but if you find yourself passing an instance of your class as an argument, likely it shouldn't be static, and should instead be a method of your object. call a static method by its name (sieve), in code inside the class; and by its classname.methodname (PrimeNumber.sieve), in code outside the class.

12 Evaluating designs: "The 'C's" cohesion: Do the things in your class go together? completeness: Are any major concepts missing? Does this class represent just a partial concept? convenience: Is the class easy enough to use? clarity: Can someone else understand the class? consistency: Are the naming conventions and behavior the same between all classes and methods? coupling: Are many classes tied to each other? coupling is bad; the rest of the above are good!

13 Class design practice problem Design a class BankAccount to model users' bank accounts. The account should keep a user's ID and balance, accurate to the nearest cent. The user should be able to make deposits and withdrawals on his/her account, as well as changing the account's ID at any time. The balance must stay non-negative. Also, since bank accounts might be used as part of a larger bank system, the system needs to be able to find out how many BankAccount s have been created in total.

14 Java's Object class the most basic type of object in Java basis for all other types (excluding primitives) defines basic behavior that all objects will have (in other words, no matter what class you are dealing with, you are guaranteed that its objects have these methods) the behaviors of these methods are usually not useful unless you write your own version in your class

15 Methods in class Object protected Object clone() Returns a copy of this Object. public boolean equals(Object obj) Returns whether or not object obj is "equal to" this one. protected void finalize() Called by the garbage collector when it is time to collect this object. public Class getClass() Returns information about the class this object belongs to. public int hashCode() Used by some data structures to create an integer code for this object.

16 More Object methods public String toString() Returns a string representation of this object. public void notify() public void notifyAll() public void wait() public void wait(long timeout) public void wait(long timeout, int nanosec) Methods related to concurrent programming; these methods allow threads to "wait for" signals from each other by attaching themselves to important objects. (We won't use them.)

17 Printing objects: toString toString provides a string representation of a Java object primarily used to print objects on the console with System.out.println Sun's Java style guidelines suggest implementing a toString method for every class you write

18 toString practice problems Add a toString method to BankAccount so that BankAccount objects will print in this format: Marty Stepp, $ Add a toString method to Person so that Person objects will print in this format: Rich Mercen: (253)

19 Object equality test: equals Default equals method (from Object ) checks for referential equality; must literally refer to the same object (identical to behavior of == operator) Desired result: check for state equivalence (where they may refer to two different objects, but they have the same state) Advantages of overriding equals correct behavior in collections (can find elements) more accurate comparison of objects

20 Overriding equals Conditions for overriding equals correctly: reflexive: for any object x, the test x.equals(x) should return true symmetric: if and only if x.equals(y), then y.equals(x) transitive: if x.equals(y) and y.equals(z), then x.equals(z) (taken together, a relationship with these three properties is called an equivalence relation)

21 Overriding equals, cont'd. Things to do in a good equals implementation handle null case (should return false ) optimize the trivial case, when this == obj (should return true ) public boolean equals(Object obj) { if (this == obj) { return true; } else if (obj == null) { return false; } else { /* compare them and return answer */ } }

22 equals practice problems Add an equals method to Person so that persons will be considered equal only if they have exactly the same name and phone number. Should we add equals to BankAccount ? Why or why not?

23 Comparing objects: compareTo many types of objects have a natural ordering, a way to compare them and put them in some kind of order in Java, objects that have a natural ordering have a method compareTo that compares two objects advantage: can compare objects, organize or sort objects in a collection or array some classes that have compareTo : String, Date, File, URI

24 The method compareTo public int compareTo(Object o) Compares this object with the specified object for order. Returns a negative integer, zero, or a positive integer as this object is less than, equal to, or greater than the specified object. In summary: negative integer: this object is less than o zero: this object is equal to o positive integer: this object is greater than o

25 compareTo usage examples String marty = "Marty Stepp"; String jill = "Jill Jackson"; String amy = "Amy Clump"; marty.compareTo(marty) == ______ marty.compareTo(jill) == ______ amy.compareTo(jill) == ______ jill.compareTo(amy) == ______ jill.compareTo("Jill Jackson") == ______ amy.compareTo("Amy Smith") == ______

26 compareTo example public class Person { private String myName; private int myPhoneNumber; /* Compares Person objects by name, breaking ties by phone number. */ public int compareTo(Object o) { Person p = (Person)o; int nameCmp = myName.compareTo(p.getName()); if (nameCmp != 0) return nameCmp; else return myPhoneNumber - p.getPhoneNumber(); }

27 compareTo practice problems Make the class Fraction, as defined by instructor's Fraction.java, comparable. The compareTo method should return -1 if this fraction is less than the argument, 0 if they are equal, or 1 if this fraction is greater than the argument. Note that two fractions should be considered equal if they have the same value. This means, for example, that the fraction 2/3 should be considered equal to the fraction 4/6. Re-implement equals for class Person, taking advantage of an existing compareTo method.

28 compareTo search / sorting if the objects of your class are comparable, Java can sort an array of them using Arrays.sort, or a list of them using Collections.sort (seen later) practice problem: Write a static method isSorted that accepts an array of Fraction s as its argument, and returns true if the Fraction s in the array are stored in ascending order by value, and false if not.

29 References Koffman, Chapter 1, pp ; Appendix A, pp