Data Structures and Algorithms revision

Slides:



Advertisements
Similar presentations
Chapter 13 - Inheritance. Goals To learn about inheritance To learn about inheritance To understand how to inherit and override superclass methods To.
Advertisements

IMPLEMENTING CLASSES Chapter 3. Black Box  Something that magically does its thing!  You know what it does but not how.  You really don’t care how.
Inheritance Part I. Lecture Objectives To learn about inheritance To understand how to inherit and override superclass methods To be able to invoke superclass.
I NHERITANCE Chapter 10. I NHERITANCE Mechanism for enhancing existing classes You need to implement a new class You have an existing class that represents.
1 CS 171: Introduction to Computer Science II Review: OO, Inheritance, and Libraries Ymir Vigfusson.
Chapter 3 Implementing Classes. Instance Variables Instance variables store the data of an object; the fields of an object. Instance of a class: an object.
Inheritance. Class Relationships Composition: A class contains objects of other class(es) (actually, references to such objects) –A “has a” relationship.
Chapter 13 Inheritance. An Introduction to Inheritance Inheritance: extend classes by adding methods and fields (variables) Example: Savings account =
CHAPTER 11 INHERITANCE CHAPTER GOALS To understand how to inherit and override superclass methods To be able to invoke superclass constructors To learn.
Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved. Chapter Three - Implementing Classes.
Chapter 9 – Inheritance Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.
Chapter 2 – An Introduction to Objects and Classes Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.
Inheritance Part III. Lecture Objectives To learn about inheritance To understand how to inherit and override superclass methods To be able to invoke.
CS 106 Introduction to Computer Science I 11 / 15 / 2006 Instructor: Michael Eckmann.
CS 106 Introduction to Computer Science I 11 / 19 / 2007 Instructor: Michael Eckmann.
Datalogi A 2: 15/9. Java Slides based on Horstmann chapter 2&3 Objects and classes Import, methods, references Implementing a class.
Inheritance Part II. Lecture Objectives To learn about inheritance To understand how to inherit and override superclass methods To be able to invoke superclass.
Inheritance and Subclasses in Java CS 21a: Introduction to Computing I Department of Information Systems and Computer Science Ateneo de Manila University.
GETTING INPUT Simple I/O. Simple Input Scanner scan = new Scanner(System.in); System.out.println("Enter your name"); String name = scan.nextLine(); System.out.println("Enter.
Inheritance One of the biggest advantages of object-oriented design is that of inheritance. A class may be derived from another class, the base class.
(c) University of Washington04-1 CSC 143 Java Inheritance Example (Review)
Programming Languages and Paradigms Object-Oriented Programming.
Basic Object- Oriented Concepts Presented By: George Pefanis 21-Sep-15.
COP INTERMEDIATE JAVA Designing Classes. Class Template or blueprint for creating objects. Their definition includes the list of properties (fields)
Programming in Java Unit 2. Class and variable declaration A class is best thought of as a template from which objects are created. You can create many.
Week 4 Introduction to Computer Science and Object-Oriented Programming COMP 111 George Basham.
Big Java by Cay Horstmann Copyright © 2008 by John Wiley & Sons. All rights reserved. Inheritance.
Often categorize concepts into hierarchies: Inheritance Hierarchies Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.
Classes CS 21a: Introduction to Computing I First Semester,
 Sometimes a new class is a special case of the concept represented by another ◦ A SavingsAccount is-a BankAccount ◦ An Employee is-a Person  Can extend.
Hello.java Program Output 1 public class Hello { 2 public static void main( String [] args ) 3 { 4 System.out.println( “Hello!" ); 5 } // end method main.
Inheritance CSC 171 FALL 2004 LECTURE 18. READING Read Horstmann, Chapter 11.
Chris Kiekintveld CS 2401 (Fall 2010) Elementary Data Structures and Algorithms Inheritance and Polymorphism.
Week 4 Introduction to Computer Science and Object-Oriented Programming COMP 111 George Basham.
Introduction to Java Java Translation Program Structure
Topic 4 Inheritance.
CHAPTER 11 INHERITANCE. CHAPTER GOALS To understand how to inherit and override superclass methods To be able to invoke superclass constructors To learn.
COP INTERMEDIATE JAVA Designing Classes. Class Template or blueprint for creating objects. Their definition includes the list of properties (fields)
Inheritance and Subclasses CS 21a. 6/28/2004 Copyright 2004, by the authors of these slides, and Ateneo de Manila University. All rights reserved L16:
 Sometimes a new class is a special case of the concept represented by another ◦ A SavingsAccount is-a BankAccount ◦ An Employee is-a Person  Can extend.
Quick Review of OOP Constructs Classes:  Data types for structured data and behavior  fields and methods Objects:  Variables whose data type is a class.
CS 116 Lecture 1 John Korah Contains content provided by George Koutsogiannakis & Matt Bauer.
Inheritance INHERITANCE: extend existing classes by adding or redefining methods, and adding instance fields Suppose we have a class Vehicle: public class.
Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved. Chapter Three - Implementing Classes.
COP INTERMEDIATE JAVA Inheritance, Polymorphism, Interfaces.
Chapter 3 Implementing Classes
COMPUTER SCIENCE & TECHNOLOGY DEGREE PROGRAMME FACULTY OF SCIENCE & TECHNOLOGY UNIVERSITY OF UVA WELLASSA ‏ Properties of Object Oriented Programming.
CS100Lecture 61 Announcements Homework P1 due on Thursday Homework P2 handed out.
Java Programming: Guided Learning with Early Objects Chapter 9 Inheritance and Polymorphism.
Polymorphism and access control. RHS – SOC 2 What is polymorphism? In general: the ability of some concept to take on different forms In Java: the ability.
2-Oct-16 Basic Object-Oriented Concepts. 2 Concept: An object has behaviors In old style programming, you had: data, which was completely passive functions,
More on Objects Static and equals.. Each object takes memory Each time you make an object of a given class – you create a space in memory. E.g. public.
Slides by Evan Gallagher
Slides by Evan Gallagher
Chapter 13 - Inheritance.
Lecture 3 John Woodward.
Lecture Notes – Inheritance (Ch 9-10)
Implementing Classes Yonglei Tao.
UML Class Diagram: class Rectangle
CS 302 Week 11 Jim Williams, PhD.
Computer Science II Exam 1 Review.
Chapter Three - Implementing Classes
null, true, and false are also reserved.
Polymorphism and access control
Inheritance.
JAVA CLASSES.
Classes CS 21a: Introduction to Computing I
Chapter 11 Inheritance and Encapsulation and Polymorphism
CIS 110: Introduction to computer programming
Introduction to Computer Science and Object-Oriented Programming
Presentation transcript:

Data Structures and Algorithms revision

Objects An Object is “some data/attributes”, and a set of ways (methods) of changing/accessing the data.

Classes vs Objects You have a single class e.g. Person. You can make many objects of the type Person. Person p1 = Person(); // the default object Person p2 = Person(“John”, 99); // makes a person called p2 with the values John with age 99 Person p3 = p2; //makes a person p3 …. All 3 Person objects belong to the Person class CSCU9A3 - Autumn 2015

Analogy: In an Office (before computers) Imagine you work in an office (bank). You have a paper form with blanks in (e.g. name, address, salary) When somebody opens a bank account – you photocopy the form and fill in their individual details. The blank form is like a Class – there is only one blank form (THE MASTER COPY). Each photocopied form is like an Object. CSCU9A3 - Autumn 2015

One class, many objects A class is a template for making objects. E.g. PERSON CLASS Int Age String Name P2 P1 PERSON OBJECT Int Age 55 String Name dave PERSON OBJECT Int Age 98 String Name james

DANGER OF PUBLIC If your data is public – it can be changed to anything PERSON CLASS public int age string Name Person p1 = new Person(“dave”,55); PERSON OBJECT int age -100 string Name “dave” P1.age = -100; //SHOULD NOT HAPPEN

Private data If your data is private– you are forces to use the set methods to change it. PERSON CLASS private Int age string Name Person p1 = new Person(“dave”,55); p1.age = -100; //SHOULD CANNOT HAPPEN We use a setAge method PERSON OBJECT int Age 55 String Name “dave”

setAge method public void setAge(int a) { if (a > 0) { this.age = a; } else { System.out.println("age not set, cannot be negative"); }

Overloaded Methods A class can have a number of methods with the same name, but different parameters Example: println methods, one for each different type of thing you might want to print: public void println(int output) public void println(double output) public void println(String output) CSCU9A3 - Autumn 2015

Overloaded Methods This solve the problem of having to explicitly tell the program which method: public void printlnINT(int output) public void printlnDOUBLE(double output) public void printlnSTRING(String output) CSCU9A3 - Autumn 2015

Encapsulation Encapsulation means we do not need to know the details of how the data is stored. You just need to know how to use it. This is sometimes called “data hiding” We do not want to expose the internal workings of out class – but have an agreed set of methods by which we communicate with other classes.

e.g. counter class A counter class with method Increment (adds one to the count) Reset (sets the count to zero) getCount (give the current number) (DO AN EXAMPLE WITH THE CLASS) This is the interface of the class – it is just the methods you can see (and the constructor)

Encapsulation - example A counter class with methods Increment and getCount. Could store an integer, which is incremented by one each time the counter is pressed. Could store a string “1111111”, and append “1” each time. The length represents the count. Could store a number 1000, and multiply by 10 each time we press counter. The count would just be log of the number.

Syntax 3.1 Instance Variable Declaration Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.

Accessing Instance Variables The count method advances the counter value by 1: public void count() { value = value + 1; } The getValue method returns the current value: public int getValue() return value; Private instance variables can only be accessed by methods of the same class Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.

Instance Variables Encapsulation is the process of hiding object data and providing methods for data access To encapsulate data, declare instance variables as private and declare public methods that access the variables Encapsulation allows a programmer to use a class without having to know its implementation Information hiding makes it simpler for the implementor of a class to locate errors and change implementations Protects your data (get/set methods accessor/mutator methods) from others and from yourself!!! How else could the class counter be implemented instead of using int ???? (float, string…) Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.

Equals (==) for primitive data types When comparing primitive data types int boolean float double char, … USE x == y NOT x=y (means x becomes the value y)

Equals with objects Person p1 = new person(“John”, 55); == compares memory address!!! Need to use .equals String name1 = “John”; String name2 = “John”; name1==name2;// give False name1.equals(name2); // gives True

Steps to check equality 1/ is the object null 2/ is the object the same type as you want e.g. Person, or Percent or Thermometer.. 3/ now check each of the relevant fields for equality. (usually all fields)

Example Percent public boolean equals(Object object) { if (object == null) { return false; } else if (!(object instanceof Percent )) { } else { Percent percent = (Percent ) object; return this.percent == percent.getPercent(); }

Static vs non-Static Static variables are the same for every instance of a class Non-Static variables are different for each instance of a class E.g. we all have an individual blood pressure (e.g. 140 over 100 mmHg) non-static But the normal for all of us is 120 over 80 mmHg. What about height, weight and indicators of obesity as body mass index. CSCU9A3 - Autumn 2015

Object References Rectangle box = new Rectangle(5, 10, 20, 30); Object reference: describes the location of an object The new operator returns a reference to a new object: Rectangle box = new Rectangle(); Multiple object variables can refer to the same object: Rectangle box = new Rectangle(5, 10, 20, 30); Rectangle box2 = box; box2.translate(15, 25); Primitive type variables ≠ object variables Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.

Object Variables and Number Variables Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.

Object Variables and Number Variables Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.

Inheritance Means you can use the methods of the super class. This saves you time writing more java which is common to a set of classes. The common methods and data attributes can abstracted out as a super class.

Inheritance e.g. 1 E.g. in the lecture/tutorial we looked at vehicles. All vehicles (car, coach, train) have a weight/color/passengerCapacity/fuelType. Things specific to the subclass can be stored only in that class e.g. for coach doubleDecker = True hasToilet = False

Inheritance e.g. 2 If you are storing information about people, there are commonalities that all people have E.g. name, nationality, height, date of birth. For different people you store different information E.g. Professor class extends Person String areaOfExpertize = “blackholes”; String Chair = “Lucasian ”; String university = “Cambridge”; Int numberBooksPublished = 23;

Syntax 9.1 Inheritance Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.

Overriding Methods public class BankAccount { . . . Example: deposit and withdraw methods of the CheckingAccount class override the deposit and withdraw methods of the BankAccount class to handle transaction fees: public class BankAccount { . . . public void deposit(double amount) { . . . } public void withdraw(double amount) { . . . } public double getBalance() { . . . } } public class CheckingAccount extends BankAccount public void deductFees() { . . . } Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.

Overriding Methods A subclass method overrides a superclass method if it has the same name and parameter types as a superclass method When such a method is applied to a subclass object, the overriding method is executed Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.

Overriding Methods Use the super reserved word to call a method of the superclass: public class CheckingAccount extends BankAccount { public void deposit(double amount) transactionCount++; // Now add amount to balance super.deposit } Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.

Syntax 9.2 Calling a Superclass Method Big Java by Cay Horstmann Copyright © 2009 by John Wiley & Sons. All rights reserved.

Overriding methods. The subclass may override superclass methods. We do not want this to happen in some cases E.g. getAge To stop overriding say final getAge To force overriding say abstact getAge