1 Arrays, Strings and Collections [2] Rajkumar Buyya Grid Computing and Distributed Systems (GRIDS) Laboratory Dept. of Computer Science and Software Engineering.

Slides:



Advertisements
Similar presentations
AP Computer Science Anthony Keen. Computer 101 What happens when you turn a computer on? –BIOS tries to start a system loader –A system loader tries to.
Advertisements

Basic Java Constructs and Data Types – Nuts and Bolts
1 Inheritance Classes and Subclasses Or Extending a Class.
1 Arrays, Strings and Collections [1] Rajkumar Buyya Grid Computing and Distributed Systems (GRIDS) Laboratory Dept. of Computer Science and Software Engineering.
1 Exceptions: An OO Way for Handling Errors Rajkumar Buyya Grid Computing and Distributed Systems (GRIDS) Laboratory Dept. of Computer Science and Software.
Classes and Objects in Java
Introduction to Java 2 Programming Lecture 3 Writing Java Applications, Java Development Tools.
The ArrayList Class and the enum Keyword
Two Dimensional Arrays and ArrayList
1 StringBuffer & StringTokenizer Classes Chapter 5 - Other String Classes.
Purpose : To convert this string to a new character array. Return Type : char[ ] Parameters : none Declaration : public char[ ] toCharArray() Returns.
String Pemrograman Berbasis Obyek Oleh Tita Karlita.
Liang, Introduction to Java Programming, Ninth Edition, (c) 2013 Pearson Education, Inc. All rights reserved. 1 Chapter 9 Strings.
Air Force Institute of Technology Electrical and Computer Engineering
Contents o Introduction o Characteristics of Constructor. o Types of constructor. - Default Constructor - Parameterized Constructor - Copy Constructor.
Self Check 1.Which are the most commonly used number types in Java? 2.Suppose x is a double. When does the cast (long) x yield a different result from.
Strings in Java 1. strings in java are handled by two classes String &
Chapter 7 Strings F To process strings using the String class, the StringBuffer class, and the StringTokenizer class. F To use the String class to process.
1 Strings and Text I/O. 2 Motivations Often you encounter the problems that involve string processing and file input and output. Suppose you need to write.
Chapter 7 Strings F Processing strings using the String class, the StringBuffer class, and the StringTokenizer class. F Use the String class to process.
Java Programming Strings Chapter 7.
Strings An extension of types A class that encompasses a character array and provides many useful behaviors Chapter 9 Strings are IMMUTABLE.
Chapter 10 Review. Write a method that returns true is s1 and s2 end with the same character; otherwise return false. Sample Answer: public boolean lastChar(String.
©2004 Brooks/Cole Chapter 7 Strings and Characters.
Jan Java Basics - II Yangjun Chen Dept. Business Computing University of Winnipeg.
CSM-Java Programming-I Spring,2005 String Handling Lesson - 6.
23-Jun-15 Strings, Etc. Part I: String s. 2 About Strings There is a special syntax for constructing strings: "Hello" Strings, unlike most other objects,
StringBuffer class  Alternative to String class  Can be used wherever a string is used  More flexible than String  Has three constructors and more.
Fundamental Programming Structures in Java: Strings.
Strings, Etc. Part I: Strings. About Strings There is a special syntax for constructing strings: "Hello" Strings, unlike most other objects, have a defined.
28-Jun-15 String and StringBuilder Part I: String.
Strings Edward J. Biebel. Strings Strings are fundamental part of all computing languages. At the basic level, they are just a data structure that can.
COMPUTER SCIENCE FEBRUARY 2011 Lists in Python. Introduction to Lists Lists (aka arrays): an ordered set of elements  A compound data type, like strings.
Java Methods A & AB Chapter 10 - Strings. Ch 10 Goals Understand Strings indepth Learn strategies to deal with the immutability of Strings Learn how to.
Chapter 9 Character Strings 9.1 Character String Constants A character string constant is a sequence of characters enclosed in double quotation mark. Examples.
Lecture # 8 Constructors Overloading. Topics We will discuss the following main topics: – Static Class Members – Overloaded Methods – Overloaded Constructors.
Strings Carol Yarbrough AP Computer Science Instructor Alabama School of Fine Arts.
Strings Chapter 7 CSCI CSCI 1302 – Strings2 String Comparisons Compare string contents with the equals(String s) method not == String s0 = “ Java”;
Chapter 7: Characters, Strings, and the StringBuilder.
String Handling StringBuffer class character class StringTokenizer class.
Geoff Holmes Date Math Weighted Distr Strings String methods Tokenizers System Examples Utility Classes (Chapter 17) import java.util.*;
Jaeki Song JAVA Lecture 07 String. Jaeki Song JAVA Outline String class String comparisons String conversions StringBuffer class StringTokenizer class.
Strings and Related Classes String and character processing Class java.lang.String Class java.lang.StringBuffer Class java.lang.Character Class java.util.StringTokenizer.
Computer Engineering 2 nd Semester Dr. Rabie A. Ramadan 3.
CS 139 Objects Based on a lecture by Dr. Farzana Rahman Assistant Professor Department of Computer Science.
1 Predefined Classes and Objects Chapter 3. 2 Objectives You will be able to:  Use predefined classes available in the Java System Library in your own.
17-Feb-16 String and StringBuilder Part I: String.
ENEE150 – 0102 ANDREW GOFFIN Strings. Project 2 Flight Database 4 options:  Print flight  Print airport  Find non-stop flights  Find one-stop flights.
1 Unit-2 Arrays, Strings and Collections. 2 Arrays - Introduction An array is a group of contiguous or related data items that share a common name. Used.
© 2006 Pearson Addison-Wesley. All rights reserved 1-1 Chapter 1 Review of Java Fundamentals.
String and Lists Dr. José M. Reyes Álamo. 2 Outline What is a string String operations Traversing strings String slices What is a list Traversing a list.
Strings, StringBuilder, and Character
The StringBuffer Class 
EKT 472: Object Oriented Programming
String and String Buffers
String and StringBuilder
Chapter 7: Strings and Characters
Object Oriented Programming
MSIS 655 Advanced Business Applications Programming
Unit-2 Objects and Classes
String and StringBuilder
String and StringBuilder
String and Lists Dr. José M. Reyes Álamo.
Java – String Handling.
String and StringBuilder
CS1110 Today: collections.
Object Oriented Programming
String Class.
Presentation transcript:

1 Arrays, Strings and Collections [2] Rajkumar Buyya Grid Computing and Distributed Systems (GRIDS) Laboratory Dept. of Computer Science and Software Engineering University of Melbourne, Australia

2 toString() Method toString() method is a special method that can be defined in any class. This method should return a String argument. When an object is used in a String concatenation operation or when specified in print statement, this method gets invoked automatically.

3 toString() Method -Example class Circle { double x, y,r; public Circle (double centreX, double centreY, double radius ) { x = centreX ; y = centreY; r = radius; } public String toString() { String s = I am a Circle with centre [ + x +, + y + ] and radius [+ r + ]; return s; }

4 toString() Method -Example class CircleTest { Circle c = new Circle(10,20, 30); System.out.println( c ); // I am a circle with centre [10.0,20.0] and radius [30.0] }

5 StringBufferClass Unlike the String class, StringBuffer class is mutable (changeable). Use StringBufferClass class in operations where the string has to be modified.

6 StringBuffer class - Constructors public StringBuffer()Constructs a StringBuffer with an empty string. public StringBuffer(String str)Constructs a StringBuffer with initial value of str.

7 StringBuffer class – Some operations public int length()Returns the length of the buffer public synchronized void setCharAt(int index, char ch) Replaces the character at the specified position s1.setLength(int n)Truncates or extends the buffer. If(n<s1.length(), s1 is truncated; else zeros are added to s1. public StringBuffer append(String str)StringBufferString Appends the string to this string buffer. public StringBuffer append(int i)StringBuffer Append of other data items (float, char, etc.) is supported. Appends the string representation of the int argument to this string buffer.

8 Inserting a String in Middle of Existing StringBuffer StringBuffer str = new StringBuffer(Object Language); String aString = new String(str.toString()); Int pos = aString.indexOf( Language); str.insert(pos, Oriented ); what will out put of at this point: System.out.println(Modified String:+str); What will be string after executing (modifying character): str.setChar(6,-);

9 StringTokenizer Breaks string into parts, using delimiters. The sequence of broken parts are the tokens of the string. More than one delimiter can be specified. The tokens can be extracted with or without the delimiters.

10 StringTokenizer - Functionality Consider the following String CREATE_USER: ;John;Smith Separate the tokens CREATE_USER John Smith

11 StringTokenizer - Constructors public StringTokenizer(String str, String delim, boolean returnTokens) Creates a SringTokenizer with the specified delimiter. If returnTokens is true the delimiters are also returned. public StringTokenizer(String str, String delim) Delimiters are not returned public StringTokenizer(String str) Delimiters are ( \t\n\r\f)

12 StringTokenizer - Operations public boolen hasMoreTokens()Returns true if more tokens are found. public String nextToken()Returns the next token of the String. public String nextToken(String delim) Switches the delimiter set to characters in delim and returns the next token. public int countTokens()Returns the count of remaining tokens.

13 StringTokenizer - example Output of the program CREATE_USER John Smith import java.util.StringTokenizer; class TokenizerExample { public static void main(string[] args) { String str = CREATE_USER:123456;John;Smith; StringTokenizer tokens = new StringTokenizer(str, :;); while ( tokens.hasMoreTokens() ) System.out.println(tokens.nextToken()); }

14 Collections Arrays are used to hold groups of specific type of items Collections (container) designed to hold generic (any) type of objects Collections let you store, organize and access objects in an efficient manner.

15 Legacy Collection Types Vector Stack Dictionary HashTable Properties Enumeration

16 Vector The Vector class implements a growable array of objects. Like an array, it contains components that can be accessed using an integer index. However, the size of a Vector can grow or shrink as needed to accommodate adding and removing items after the Vector has been created. In Java this is supported by Vector class contained in java.util package. The Vector class can be used to create generic dynamic arrays that hold objects of any type or any number. The objects do not have to be homogeneous. Like arrays, Vectors are created as follows: Vector list = new Vector(); // declaring without size Vector list = new Vector(3); // declaring with size

17 Vector properties Vectors posses a number of advantages over arrays: It is convenient to use vectors to store objects. A vector can be used to store list of objects that may vary in size. We can add and delete objects from the list as an when required. But vectors cannot be used to store basic data types (int, float, etc.); we can only store objects. To store basic data type items, we need convert them to objects using wrapper classes (discussed later).

18 Important Methods in Vector class addElement(Object item) insertElementAt(Object item, int index) elementAt(int index) – get element at index removeElementAt(int index) size() clone() - Returns a clone of this vector. clear() - Removes all of the elements from this Vector. get(int index) - Returns the element at the specified position in this Vector. get copyInto(array) – copy all items from vector to array.

19 Vector – Example 1 import java.util.*; public class VectorOne{ public static void main(String[] args) { Vector circleVector = new Vector(); System.out.println("Vector Length +, circleVector.size()); // 0 for ( int i=0; i < 5; i++) { circleVector.addElement( new Circle(i) ); // radius of the Circles 0,1,2,3,4 } System.out.println("Vector Length = " + circleVector.size());// 5 }

20 Vector – Example 2 import java.util.*; public class VectorTwo{ public static void main(String[] args) { …… code from VectorOne goes here circleVector.insertElementAt( new Circle(20), 3); System.out.println(Vector Length = + circleVector.size()); // 6 for ( int i = 0; i < 6; i++) { System.out.println("Radius of element [" + i + "] = " + ( (Circle) circleVector.elementAt(i)).getRadius()); // radius of the Circles are 0,1,2,20,3,4 }

21 Hash Table (Hashtable clalss) Allows associating values with keys. Allows efficient look ups for the value associated with the key This class implements a hashtable, which maps keys to values. Any non-null object can be used as a key or as a value. Useful Operations: put(Object key, Object value); remove(Object key); get(Object key);

22 HashTable put()/get() operations The following example creates a hashtable of numbers. It uses the names of the numbers as keys: Hashtable numbers = new Hashtable(); numbers.put("one", new Integer(1)); numbers.put("two", new Integer(2)); numbers.put("three", new Integer(3)); To retrieve a number, use the following code: Integer n = (Integer)numbers.get("two"); if (n != null) { System.out.println("two = " + n); }

23 HashTable -Example import java.util.*; public class HashtableDemo { public static void main(String[] args) { Hashtable tbl = new Hashtable(); Student s, sRet; s = new Student("121212", "John"); tbl.put (s.getId(), s); s = new Student("100000", "James"); tbl.put (s.getId(), s); sRet= (Student) tbl.get("121212"); System.out.println("Student name is = " + sRet.getName()); // Student name is = John }

24 Enumeration Used to enumerate or iterate through a set of values in a collection. Useful for iterating Hashtables – no index. Useful Operations: hasMoreElements(); nextElement();

25 Enumeration - Example import java.util.*; public class EnumerationDemo{ public static void main(String[] args) { Hashtable tbl = new Hashtable(); Student s, sRet; s = new Student("121212", "John"); tbl.put(s.getId(), s); s = new Student("100000", "James"); tbl.put(s.getId(), s); Enumeration e = tbl.elements(); while ( e.hasMoreElements()) { sRet = (Student) e.nextElement(); System.out.println("Student name is = " + sRet.getName()); // Student name is = James // Student name is = John }

26 Wrapper Classes As pointed out earlier, collections cannot handle basic data types such as int, float. They can converted into object types by using the wrapper classes supported by java.lang package. Basic TypeWrapper Class booleanBoolean charCharacter intInteger longLong floatFloat doubleDouble

27 Methods in Wrapper Classes Constructors: Integer intVal = new Integer(i); Float floatVal = new Float(f); Converting objects to basic values int i = intVal.intValue(); float f = floatValue.floatValue(); Converting Numbers to Strings str = Integer.toString(i) str = Float.toStrin(f);

28 Methods in Wrapper Classes String Objects to Numeric Objectrs Integer intVal = Integer.ValueOf(str); Float floatVal = Float.ValueOf(str); Numeric Strings to Basic Types int i = Integer.parseInt(str); long l = Long.parseFloat(str) These methods throw exception (NumberFormatException) if the value of the str does represent an integer. Exception are a OO way of reporting errors. More on it later.

29 Summary A special method, toString(), can be defined in any Java class, which gets invoked when one tries to concatenation operation with Strings. Collections are like arrays, but can hold any objects, dynamically expandable, and supports their easy manipulation. Java has strong support for Collections, which are very useful when developing large-scale software development. Wrapper classes helps in manipulating basic data types as Objects.