241-211 OOP (Java): Grouping/5 1 241-211. OOP (Java) Objectives – –discuss call-by-value and call-by-reference, arrays, collections, and iterators Semester.

Slides:



Advertisements
Similar presentations
Grouping objects Arrays and for loops. Fixed-size collections Sometimes the maximum collection size can be pre-determined. Programming languages usually.
Advertisements

Collections & Loops Chapter 5 Copyright © 2012 Pearson Education, Inc.
Arrays.
1 Features of the collection It increases its capacity as necessary. It keeps a private count: –size() accessor. It keeps the objects in order. Details.
Grouping objects Introduction to collections 5.0.
Grouping Objects Arrays and for loops. Objects First with Java - A Practical Introduction using BlueJ, © David J. Barnes, Michael Kölling Fixed-Size Collections.
 2003 Prentice Hall, Inc. All rights reserved. 7.1 Introduction Arrays –Data structures which reference one or more value –All items must have same data.
Using Collections. Review of Collections Using an ArrayList It increases its capacity as necessary. It keeps a private count ( size() accessor). It keeps.
Grouping Objects 3 Iterators, collections and the while loop.
Programming with Collections Collections in Java Using Arrays Week 9.
Loops Notes adapted from Dr. Flores. It repeats a set of statements while a condition is true. while (condition) { execute these statements; } “while”
ECE122 L11: For loops and Arrays March 8, 2007 ECE 122 Engineering Problem Solving with Java Lecture 11 For Loops and Arrays.
Grouping Objects 2 Collections and the for-each loop Collections and the while loop.
Grouping Objects 1 Introduction to Collections.
Arrays, Loops weeks 4-6 (change from syllabus for week 6) Chapter 4.
Grouping objects Collections and iterators. 04/11/2004Lecture 4: Grouping Objects2 Main concepts to be covered Collections Loops Iterators Arrays.
 2003 Prentice Hall, Inc. All rights reserved. Modified for use with this course. Introduction to Arrays Introduction to Computers and Programming in.
Modul 3 Collections af objekter Arraylist Collections Objektorienteret design og Java. 4.0.
Programming with Collections Grouping & Looping - Collections and Iteration Week 7.
Chapter 6Java: an Introduction to Computer Science & Programming - Walter Savitch 1 l Array Basics l Arrays in Classes and Methods l Programming with Arrays.
Random, Collections & Loops Chapter 5 Copyright © 2012 Pearson Education, Inc.
Programming With Java ICS201 University Of Ha’il1 Chapter 14 Generics and The ArrayList Class.
Grouping objects Collections and iterators. Main concepts to be covered Collections Loops Iterators.
Loops: Handling Infinite Processes CS 21a: Introduction to Computing I First Semester,
REPETITION CITS1001. Scope of this lecture Repetition for loops while loops 2.
ArrayList, Multidimensional Arrays
Objects First With Java A Practical Introduction Using BlueJ Grouping objects Collections and iterators 2.0.
Grouping objects Arrays, Collections and Iterators 1.0.
JAVA: An Introduction to Problem Solving & Programming, 5 th Ed. By Walter Savitch and Frank Carrano. ISBN © 2009 Pearson Education, Inc., Upper.
Arrays Module 6. Objectives Nature and purpose of an array Using arrays in Java programs Methods with array parameter Methods that return an array Array.
Arrays and ArrayLists in Java L. Kedigh. Array Characteristics List of values. A list of values where every member is of the same type. Each member in.
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.
Netprog: Java Intro1 Crash Course in Java. Netprog: Java Intro2 Why Java? Network Programming in Java is very different than in C/C++ –much more language.
Chapter 6Java: an Introduction to Computer Science & Programming - Walter Savitch 1 Chapter 6 l Array Basics l Arrays and Methods l Programming with Arrays.
Grouping objects Introduction to collections 5.0.
Grouping objects Collections and iterators Objects First with Java - A Practical Introduction using BlueJ, © David J. Barnes, Michael Kölling Main.
Chapter 4 Grouping Objects. Flexible Sized Collections  When writing a program, we often need to be able to group objects into collections  It is typical.
ArrayList Class An ArrayList is an object that contains a sequence of elements that are ordered by position. An ArrayList is an object that contains a.
JAVA COLLECTIONS M. TAIMOOR KHAN (ADAPTED FROM SWINBURNE NOTES)
Aug 9, CMSC 202 ArrayList. Aug 9, What’s an Array List ArrayList is  a class in the standard Java libraries that can hold any type of object.
Fall 2002CS 150: Intro. to Computing1 Streams and File I/O (That is, Input/Output) OR How you read data from files and write data to files.
This recitation 1 An interesting point about A3: Using previous methods to avoid work in programming and debugging. How much time did you spend writing.
Grouping objects Iterators. Iterator type Third variation to iterate over a collection Uses a while loop and Iterator object But NO integer index variable.
Objects First With Java A Practical Introduction Using BlueJ Grouping objects Collections and iterators 1.0.
Chapter 4 Grouping Objects. Flexible Sized Collections  When writing a program, we often need to be able to group objects into collections  It is typical.
CMSC 202 Advanced Section Classes and Objects: Object Creation and Constructors.
GROUPING OBJECTS CITS1001. Lecture outline The ArrayList collection Process all items: the for-each loop 2.
CSE 1201 Object Oriented Programming ArrayList 1.
Peter Andreae Computer Science Victoria University of Wellington Copyright: Peter Andreae, Victoria University of Wellington Summary and Exam COMP 102.
Grouping objects Arrays. 2 Fixed-size collections The maximum collection size may be pre-determined with an upper limit Array is an fixed-size collection.
Programming Fundamentals 2: Grouping/ F II Objectives – –discuss call-by-value and call-by-reference, arrays, collections, and iterators.
Grouping objects Introduction to collections 5.0.
1 COS 260 DAY 7 Tony Gauvin. 2 Agenda Questions? 3 rd Mini quiz next class (September 28) –Chap 3 concepts Assignment 1 Corrected Assignment 2 posted.
Arrays Chapter 7. MIS Object Oriented Systems Arrays UTD, SOM 2 Objectives Nature and purpose of an array Using arrays in Java programs Methods.
Collections and Iteration Week 13.  Collections  ArrayList objects  Using loops with collections Collections and Iteration CONCEPTS COVERED THIS WEEK.
Grouping Data Together Often we want to group together a number of values or objects to be treated in the same way e.g. names of students in a tutorial.
Grouping objects Iterators, collections and the while loop Equality and Equality == and equals(…)
Fixed-sized collections Introduction to arrays 6.0.
Chapter 9 Introduction to Arrays Fundamentals of Java.
Coming up ArrayList ArrayList vs Array – Declaration – Insertion – Access – Removal Wrapper classes Iterator object.
Objects First with Java CITS1001 week 4
Fixed-sized collections
John Hurley Cal State LA
COS 260 DAY 8 Tony Gauvin.
CS2013 Lecture 4 John Hurley Cal State LA.
Object Oriented Programming in java
F II 5. Grouping Objects Objectives
COS 260 DAY 11 Tony Gauvin.
Collections and iterators
Collections and iterators
Presentation transcript:

OOP (Java): Grouping/ OOP (Java) Objectives – –discuss call-by-value and call-by-reference, arrays, collections, and iterators Semester 2, Grouping Objects

OOP (Java): Grouping/5 2 Topics 1. Parameter Passing 2. Arrays: Similar but Different 3. Call-by-Reference with Classes 4. Grouping Objects 5. A Notebook Example 6. Iteration (looping) 7. A Counters Example 8. An Auction Example 9. Fixed-size Collections 10. More Information

OOP (Java): Grouping/ Parameter Passing In C all arguments are copied into functions: – –called call-by-value Java uses call-by-value and call-by-reference.

OOP (Java): Grouping/5 4 What is Call-by-Reference? An example for an imaginary language: function foo() { integer x := 2; bar(x); print(“x is” + x); } function bar(ref integer w) { w := 5; } “x is 5” is printed continued

OOP (Java): Grouping/5 5 Call-by-reference creates a link from the variable in the called function (e.g. w in bar() ) to the original variable (e.g. x in foo() ) – –when w changes, x is also changed

OOP (Java): Grouping/5 6 Java’s Parameter Passing Variables of primitive types (e.g. int, double, char ) are passed call-by-value (copied) – –this means that methods must 'return' results – –e.g. see next example Object-type variables are passed call-by- reference – –this means that changes to objects are 'remembered' when a method finishes without the need for a 'return'

OOP (Java): Grouping/5 7 Call-by-Value Example public class SimpleCalls { public static void main(String[] args) { int x = 3; System.out.println("1. x = " + x); squareBad(x); // x = squareGood(x); System.out.println("2. x = " + x); } // end of main() continued

OOP (Java): Grouping/5 8 private static void squareBad(int x) { System.out.println("sqBad 1. x = " + x); x = x*x; System.out.println("sqBad 2. x = " + x); } private static int squareGood(int x) { System.out.println("sqGood 1. x = " + x); x = x*x; System.out.println("sqGood 2. x = " + x); return x; } } // end of SimpleCalls class static is used so that main() can call these methods without creating an object first; it has nothing to do with parameter passing

OOP (Java): Grouping/5 9 Execution When calling squareBad() → no change to x in main() When calling squareGood() → x is changed in main()

OOP (Java): Grouping/ Arrays: Similar but Different Java arrays look like C arrays, but... Java arrays do not support pointer manipulation. Arrays are objects, and so are passed to methods using call-by-reference.

OOP (Java): Grouping/5 11 Declaring and Allocating Arrays Some coding styles: int c[] = new int[12]; // creates a 12 element int array c[0] = 2; or int c[]; // declares an array; no memory yet c[0] = 2; // ERROR! c = new int[12]; // allocates memory c[0] = 2; // OK declare the type (e.g. int) allocate memory with new continued

OOP (Java): Grouping/5 12 or: int n[] = {1, 3, 4, 6, 78} // creates a 5 element integer array A common error: int foo[12]; // a syntax error in Java a bit confusing, since no 'new' is required

OOP (Java): Grouping/5 13 A Different Syntax Instead of: int c[] = new int[12]; Can write: int[] c = new int[12];

OOP (Java): Grouping/5 14 UseArray.java import javax.swing.JOptionPane; public class UseArray { public static void main(String[] args) { int n[]; // declare array name n = new int[10]; // allocate memory to array // no values stored in n[], so will contain 0's String output = "Cell Value\n"; for(int i = 0; i < n.length; i++) output += "n[" + i + "] == " + n[i] + "\n"; JOptionPane.showMessageDialog( null, output, "Using an Array", JOptionPane.INFORMATION_MESSAGE ); } // end of main() } // end of UseArray class two steps

OOP (Java): Grouping/5 15 Execution

OOP (Java): Grouping/5 16 Notes n is declared: its type is specified int n[] n is allocated memory with new n = new int[10]; n.length – –length always holds the length of the array object (i.e. 10 in this case) object n

OOP (Java): Grouping/5 17 Using an Array Square brackets are used to access an array element: n[i] Array elements are used like ordinary variables – –on the left of an assignment: n[0] = 3; – –in an expression: x = n[1] – 3; n[i]++;

OOP (Java): Grouping/5 18 For-loop pseudo-code for(initialization; condition; post-body action) { statements to be repeated } General form of a for loop Equivalent in while-loop form initialization; while(condition) { statements to be repeated post-body action }

OOP (Java): Grouping/5 19 Example for(int i = 0; i < n.length; i++) { System.out.println(i + ": " + n[i]); } int i = 0; while(i < n.length) { System.out.println(i + ": " + n[i]); i++; } for loop version while loop version i only exists inside the loop

OOP (Java): Grouping/5 20 Passing Arrays to Methods Arrays are Java objects – –they are passed to methods using call-by-reference – –i.e. changes to an array inside a method affects the original – –no return or pointers are required

OOP (Java): Grouping/5 21 PassArray.java public class PassArray { public static void main(String[] args) { int a[] = { 1, 2, 3, 4, 5 }; System.out.println("Values in the original array:"); for(int i = 0; i < a.length; i++) System.out.print( a[i] + " "); System.out.println(); :

OOP (Java): Grouping/5 22 modifyArray(a); // pass array call-by-reference System.out.println("Values in the modified array:"); for(int i = 0; i < a.length; i++) System.out.print( a[i] + " "); System.out.println(); System.out.println("Before: a[3] = " + a[3]); modifyElement(a[3]); // pass call-by-value System.out.println("After: a[3] = " + a[3]); } // end of main() continued

OOP (Java): Grouping/5 23 private static void modifyArray(int b[]) // multiply each element by 2 { for (int j = 0; j < b.length; j++) b[j] *= 2; } private static void modifyElement(int elem) // multiply elem by 2 { elem *= 2; } } // end of PassArray class static is used so that main() can call these methods without creating an object first; it has nothing to do with parameter passing b is an array object, so passed call-by-reference elem is a primitive type, so passed call-by-value no return required

OOP (Java): Grouping/5 24 Execution changed unchanged

OOP (Java): Grouping/5 25 Notes This application uses call-by-reference to change an entire array object, a – –it remains changed back in main() It also tries to changes an array element, a[3], by using call-by-value (copying) – –it does not stay changed back in main()

OOP (Java): Grouping/5 26 Call-by-Reference Diagram object main() : modifyArray(a); : modifyArray(int b[]) b variable reference back to object : b[i] *= 2; : a

OOP (Java): Grouping/5 27 Call-by-Value Diagram object main() : modifyElement( a[3]); : modifyElement(int elem) elem : elem *= 2; : value is copied over 8 a a

OOP (Java): Grouping/ Call-by-Ref with Classes public class Counter { private int val; public Counter(int x) { val = x; } public void incr() { val++; } public int getVal() { return val; } }

OOP (Java): Grouping/5 29 Using Counter (1) Counter c = new Counter(5); Counter d = c; Counter e = d; e.incr(); System.out.println( c.getVal() ); What is printed? What is printed?

OOP (Java): Grouping/5 30 Using Counter (2) public static void main(String[] args) { Counter c = new Counter(5); Counter c = new Counter(5); foo(c); foo(c); System.out.println( c.getVal() ); System.out.println( c.getVal() );} private static void foo(Counter w) { w.incr(); } What is printed? What is printed?

OOP (Java): Grouping/5 31 Using Counter (3) public static void main(String[] args) { Counter c = bar(); Counter c = bar(); System.out.println( c.getVal() ); System.out.println( c.getVal() );} private static Counter bar() { Counter w = new Counter(5); Counter w = new Counter(5); return w; return w;} What is printed? What is printed?

OOP (Java): Grouping/ Grouping Objects Many applications involve collections of objects: – –personal organizers – –library catalogs – –student-record system The number of stored items varies over time as new items are added and old ones removed. Arrays have a basic problem: their size is fixed – –e.g. what should the size be for a student-record array?

OOP (Java): Grouping/5 33 Collection Classes Grouping objects is a common need – –the java.util package contains useful classes I'll be using the ArrayList collection class – –a list data structure with no fixed size it grows and shrinks depending on how many obejcts are stored inside it

OOP (Java): Grouping/5 34 ArrayList Example ArrayList msgs; msgs = new ArrayList (); // no fixed size msgs.add(“hello”); msgs.add(“see you”); String s1 = msgs.get(0); System.out.println(“size: “ + msgs.size()); “hello” msgs... “see you”

OOP (Java): Grouping/5 35 remove() Complicates Things msgs.remove(0); System.out.println( msgs.size() ); // ?? String s2 = msgs.get(0); // ?? msgs... “see you”

OOP (Java): Grouping/ A Notebook Example store a note remove a note show a note list all notes get the number of notes This interface helps the implementor decide on the class's operation/methods.

OOP (Java): Grouping/5 37 The Notebook Class import java.util.ArrayList; public class Notebook { private ArrayList notes; public Notebook() { notes = new ArrayList (); } The list will store String objects, and is called notes continued

OOP (Java): Grouping/5 38 public void storeNote(String note) // add a note (a string) to the notebook { notes.add(note); } public void removeNote(int noteIdx) // Remove a note from the notebook if it exists. { if ((noteIdx >= 0) && (noteIdx < notes.size())) // a valid note number notes.remove(noteIdx); } ArrayList.add(), ArrayList.remove() ArrayList.size()

OOP (Java): Grouping/5 39 ArrayList.add() adds to the end of the list, and each entry has an index position ArrayList.add() adds to the end of the list, and each entry has an index position –the indicies start at 0 ArrayList.remove() removes the object at the specified index position, which changes the indicies of the objects after it in the list. ArrayList.remove() removes the object at the specified index position, which changes the indicies of the objects after it in the list. ArrayList.size() returns the current size of the list. ArrayList.size() returns the current size of the list.

OOP (Java): Grouping/5 40 Using add() notes.add("11:30 meet John"); notes.size() now returns 3

OOP (Java): Grouping/5 41 Using remove() notes.remove(1); The index position of the "meet" note changes when the second object is removed. notes.size() is now 2

OOP (Java): Grouping/5 42 The Notebook Class (continued) public void showNote(int noteIdx) { if ((noteIdx >= 0) && (noteIdx < notes.size())) // if a valid note number System.out.println( notes.get(noteIdx) ); } public int numNotes() { return notes.size(); } ArrayList.get() returns a link to the object at index noteIdx continued

OOP (Java): Grouping/5 43 public void listNotes() // for each note in notes, print it public void listNotes() // for each note in notes, print it { for (String note : notes) { for (String note : notes) System.out.println(note); System.out.println(note); } } // end of Notebook class The Java for-each loop

OOP (Java): Grouping/5 44 The For-each Loop for(ElementType element : collection) { loop body; } For each element in collection, do the statements in the loop body. loop header for keyword Statement(s) to be repeated

OOP (Java): Grouping/5 45 Generic Classes Collections are known as parameterized or generic classes. The type parameter says what we want in the list: – –ArrayList – –etc. ArrayList implements list functionality, and there are other classes in java.util that implement queues, sets, maps, etc.

OOP (Java): Grouping/5 46 The Notebook Class Diagram My class diagram generation tool, essmodel, doesn't handle generic collections correctly

OOP (Java): Grouping/5 47 Using Notebook public class NotebookDemo { public static void main(String[] args) { Notebook book = new Notebook(); System.out.println("Store note: \"Teaching maths\""); book.storeNote("Teaching maths"); System.out.println("Store note: \"Teaching Java\""); book.storeNote("Teaching Java"); System.out.println("No. of notes: " + book.numNotes()); :

OOP (Java): Grouping/5 48 System.out.println("Note 1: "); book.showNote(1); System.out.println("Note 2: "); book.showNote(2); System.out.println("All notes: "); book.listNotes(); System.out.println("Remove Note 0"); book.removeNote(0); System.out.println("No. of notes: " + book.numNotes()); System.out.println("All notes: "); book.listNotes(); } // end of main() } // end of NotebookDemo class

OOP (Java): Grouping/5 49 Execution

OOP (Java): Grouping/ Iteration (looping) We often want to perform some actions an arbitrary number of times. – –e.g., print all the notes in the notebook Java has several sorts of loop statement – –familiar ones: for, while, do-while – –new one: for-each

OOP (Java): Grouping/5 51 public void listNotes() { int index = 0; while(index < notes.size()) { System.out.println(notes.get(index)); index++; } while the value of index is less than the size of the collection, print the next note, and then increment index listNotes() using 'while' compare with the for-each version on slide 37

OOP (Java): Grouping/5 52 for-each versus while for-each: – –easier to write – –safer: it's guaranteed to finish while: – –processing order can be varied – –'while' can be used with data structures other than collections – –take care: a 'while' loop can go into an infinite loop (never stops)

OOP (Java): Grouping/5 53 'While' Without a Collection // print all even integers from 0 to 30 int index = 0; while(index <= 30) { System.out.println(index); index = index + 2; // steps of 2 }

OOP (Java): Grouping/5 54 Searching a Collection public int findNote(String searchString) { int index = 0; while(index < notes.size()) { String note = notes.get(index); if(note.contains(searchString)) return index; index++; } return -1; // used to indicate failure } contains() is from the String class

OOP (Java): Grouping/5 55 Iterators The 'while' loop requires that the data structure have an index, so that different elements can be accessed The 'while' loop requires that the data structure have an index, so that different elements can be accessed –e.g. array[index], notes.get(index) Many data structures don't have indicies Many data structures don't have indicies –e.g. trees, graphs –so it's not easy to search them with 'while' –iterators are the solution

OOP (Java): Grouping/5 56 Using an Iterator Object Iterator it = myCollection.iterator(); while(it.hasNext()) { call it.next() to get the next object do something with that object } java.util.Iterator returns an Iterator object public void listNotes() { Iterator it = notes.iterator(); while(it.hasNext()) System.out.println(it.next()); } continued compare with the for-each and while versions on slides 37 and 45

OOP (Java): Grouping/5 57 All collection classes (e.g. ArrayList) provide special Iterator objects that provide sequential access to the whole collection. Test for a 'next' element with hasNext() Get 'next' element with next()

OOP (Java): Grouping/5 58 Comparing for-each, 'while' and Iterator Ways to iterate over a collection: – –for-each loop use if we want to process every element from start to finish – –while loop use if we want to vary the processing order use for repetition that doesn't involve a collection – –Iterator object often used with collections where indexed access is not very efficient, or impossible

OOP (Java): Grouping/ A Counters Example An ArrayList of Counter objects. cnts ArrayList of Counter objects..

OOP (Java): Grouping/5 60 CountersStore Class public class CountersStore { private ArrayList cnts; public CountersStore() { cnts = new ArrayList (); } public void add(Counter c) { cnts.add(c); } public Counter get(int idx) { if ((idx = cnts.size()) { System.out.println("Index out of range"); return null; } return cnts.get(idx); } } // end of CountersStore class

OOP (Java): Grouping/5 61 Using CountersStore public class CountersStoreDemo { public static void main(String[] args) { CountersStore cs = new CountersStore(); Counter c1 = new Counter(5); cs.add(c1); cs.add ( new Counters(7) ); // second object added Counter c = cs.get(1); // get ref to second object c.incr(); // 7 --> 8 System.out.println( c.getVal() ); // prints 8 Counter foo = cs.get(1); // get ref to second object System.out.println( c.getVal() ); // prints 8! } )

OOP (Java): Grouping/ An Auction Example An auction consists of a list of lots (things to sell). A lot may include a bid. auction ArrayList of Lot objects.. Lot object idNum description highest Bid Bid object bidderName value or null

OOP (Java): Grouping/5 63 The Auction Class Diagrams uses

OOP (Java): Grouping/5 64 Using Auction public class AuctionDemo { public static void main(String[] args) { Auction auc = new Auction(); System.out.println("Add lot 5: \"Amazing Fantasy 15\""); auc.enterLot(5, "Amazing Fantasy 15"); System.out.println("Add lot 6: \"FF 1\""); auc.enterLot(6, "FF 1"); System.out.println("Add lot 2: \"Xmen 5\""); auc.enterLot(2, "Xmen 5"); :

OOP (Java): Grouping/5 65 System.out.println("Current lots"); auc.showLots(); System.out.println("ad bids 100 for lot 5"); auc.bidFor(5, "ad", 100); System.out.println("klc bids 25 for lot 6"); auc.bidFor(6, "klc", 25); System.out.println("ad bids 10 for lot 6"); auc.bidFor(6, "ad", 10); System.out.println("klc bids 101 for lot 5"); auc.bidFor(5, "klc", 101); System.out.println("Lot 5 info: " + auc.getLot(5)); System.out.println("Current lots"); auc.showLots(); } // end of main() } // end of AuctionDemo class

OOP (Java): Grouping/5 66 Execution

OOP (Java): Grouping/5 67 The Auction Class public class Auction { private ArrayList lots; // list of lots in the auction public Auction() { lots = new ArrayList (); } public void enterLot(int lotNum, String description) { lots.add( new Lot(lotNum, description) ); } // should check uniqueness of lotNum public void showLots() { for (Lot lot : lots) System.out.println(lot.toString()); } an anonymous object (one with no variable name) continued (partial)

OOP (Java): Grouping/5 68 public Lot getLot(int lotNum) /* Return the lot with the given number. Return null if a lot with this number does not exist. */ { for (Lot lot : lots) if (lot.getIdNum() == lotNum) return lot; // lot with that number not found System.out.println("Lot number: " + lotNum + " does not exist."); return null; } // end of getLot() : // more methods } // end of Auction class null means 'no object'

OOP (Java): Grouping/ Fixed-size Collections If the size of the collection is known when the program is being written then the collection can be stored in an array. Java arrays can store objects or primitive- type values (e.g. ints, chars, floats).

OOP (Java): Grouping/5 70 The LogAnalyzer Example The LogAnalyzer reads in a log file and reports the information grouped into hours. The log file (weblog.txt) consists of lines of the form: – –year month day hour minute

OOP (Java): Grouping/5 71 weblog.txt Contents : : year month day hour minute

OOP (Java): Grouping/5 72 Using LogAnalyzer public class LADemo { public static void main(String[] args) { LogAnalyzer la = new LogAnalyzer(); la.printData(); la.printHourlyCounts(); // hourly output } // end of main() } // end of LADemo class

OOP (Java): Grouping/5 73 Hourly Output The output is always grouped into 24 hours, and so can be stored in an array.

OOP (Java): Grouping/5 74 The hourCounts[] Array

OOP (Java): Grouping/5 75 The LogAnalyzer Class public class LogAnalyzer { private static final String LOG_FNM = "weblog.txt"; private int[] hourCounts; private LogfileReader reader; public LogAnalyzer() { hourCounts = new int[24]; reader = new LogfileReader(LOG_FNM); analyzeHourlyData(); } // end of LogAnalyzer() Array object creation Array variable declaration continued

OOP (Java): Grouping/5 76 private void analyzeHourlyData() { while (reader.hasMoreEntries()) { LogEntry entry = reader.nextEntry(); int hour = entry.getHour(); hourCounts[hour]++; } } // end of analyzeHourlyData() continued

OOP (Java): Grouping/5 77 public void printHourlyCounts() { System.out.println(" "); System.out.println("Hour: Count"); for (int hour = 0; hour < hourCounts.length; hour++) System.out.println(hour + ": " + hourCounts[hour]); System.out.println(" "); } // end of printHourlyCounts()

OOP (Java): Grouping/ More Information Java has many tutorials on different topics, and extensive documentation Java has many tutorials on different topics, and extensive documentation –I asked you to download the Java tutorials and docs along with the SDK at the start of this course

OOP (Java): Grouping/5 79 Collections Tutorial

OOP (Java): Grouping/5 80 Collections Documentation

OOP (Java): Grouping/5 81 ArrayList Documentation