Java How to Program, 9/e © Copyright 1992-2012 by Pearson Education, Inc. All Rights Reserved.

Slides:



Advertisements
Similar presentations
Generics and the ArrayList Class
Advertisements

C++ How to Program, 7/e © by Pearson Education, Inc. All Rights Reserved.
Generic programming in Java
Java Generics.
 2006 Pearson Education, Inc. All rights reserved Generics Many slides modified by Prof. L. Lilien (even many without an explicit message). Slides.
Java Generics. 2 The Dark Ages: Before Java 5 Java relied only on inclusion polymorphism  A polymorphism code = Using a common superclass Every class.
 2006 Pearson Education, Inc. All rights reserved Templates.
Slides prepared by Rose Williams, Binghamton University Chapter 14 Generics and the ArrayList Class.
Chapter 14 Generics and the ArrayList Class Copyright © 2010 Pearson Addison-Wesley. All rights reserved.
1 L39 Generics (1). 2 OBJECTIVES  To create generic methods that perform identical tasks on arguments of different types.  To create a generic Stack.
1 L40 Generics (2). 2 OBJECTIVES  To understand raw types and how they help achieve backwards compatibility.  To use wildcards when precise type information.
 2006 Pearson Education, Inc. All rights reserved Generics.
Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Starting Out with Java From Control Structures through Data Structures by.
©The McGraw-Hill Companies, Inc. Permission required for reproduction or display. Chapter Chapter 17 Animated Version Generics and Type Safety.
JAVA: An Introduction to Problem Solving & Programming, 5 th Ed. By Walter Savitch and Frank Carrano. ISBN © 2008 Pearson Education, Inc., Upper.
Visual Basic 2010 How to Program © by Pearson Education, Inc. All Rights Reserved.
C++ How to Program, 8/e © by Pearson Education, Inc. All Rights Reserved. Note: C How to Program, Chapter 22 is a copy of C++ How to Program Chapter.
Generics In Java 1.5 By Manjunath Beeraladinni. Generics ➲ New feature in JDK1.5. ➲ Generic allow to abstract over types. ➲ Generics make the code clearer.
Java™ How to Program, 9/e Presented by: Dr. José M. Reyes Álamo © Copyright by Pearson Education, Inc. All Rights Reserved.
INHERITANCE, POLYMORPHISM, CLASS HIERARCHIES AND GENERICS.
Chapter 21 Generics 1. Generics - Overview Generic Methods specify a set of related methods Generic classes specify a set of related types Software reuse.
CMSC 202 Generics. Nov Generalized Code One goal of OOP is to provide the ability to write reusable, generalized code. Polymorphic code using.
GENERIC COLLECTIONS. Type-Wrapper Classes  Each primitive type has a corresponding type- wrapper class (in package java.lang).  These classes are called.
 2005 Pearson Education, Inc. All rights reserved Generics.
Java™ How to Program, 9/e © Copyright by Pearson Education, Inc. All Rights Reserved.
Generics CSCI 201L Jeffrey Miller, Ph.D. HTTP :// WWW - SCF. USC. EDU /~ CSCI 201 USC CSCI 201L.
Generics and Collections. Introduction Generics New feature of J2SE 5.0 Provide compile-time type safety Catch invalid types at compile time Generic methods.
Part II © Copyright by Pearson Education, Inc. All Rights Reserved.
Chapter 14 Generics and the ArrayList Class Slides prepared by Rose Williams, Binghamton University Copyright © 2008 Pearson Addison-Wesley. All rights.
15440 Distributed Systems Recitation 1 Objected-Oriented Java Programming.
Java™ How to Program, 10/e © Copyright by Pearson Education, Inc. All Rights Reserved.
1 Generics Chapter 21 Liang, Introduction to Java Programming.
 All calls to method toString and earnings are resolved at execution time, based on the type of the object to which currentEmployee refers.  Known as.
Introduction to Generics
Nirmalya Roy School of Electrical Engineering and Computer Science Washington State University Cpt S 122 – Data Structures Templates.
C++ How to Program, 9/e © by Pearson Education, Inc. All Rights Reserved.
CIS 270—Application Development II Chapter 18-Generics.
Lecture 4 Generic programming Advanced Java Programming 1 dr hab. Szymon Grabowski dr inż. Wojciech Bieniecki
Chapter 5 Objects and Classes Inheritance. Solution Assignments 3 & 4 Review in class…..
Liang, Introduction to Java Programming, Sixth Edition, (c) 2007 Pearson Education, Inc. All rights reserved Chapter 9 Inheritance and.
CMSC 330: Organization of Programming Languages Java Generics.
1 CSE 331 Generics (Parametric Polymorphism) slides created by Marty Stepp based on materials by M. Ernst, S. Reges, D. Notkin, R. Mercer, Wikipedia
Liang, Introduction to Java Programming, Tenth Edition, (c) 2013 Pearson Education, Inc. All rights reserved. 1 Chapter 19 Generics.
©SoftMoore ConsultingSlide 1 Generics “Generics constitute the most significant change in the Java programming language since the 1.0 release.” – Cay Horstmann.
Generic(Parameterized ) types Mehdi Einali Advanced Programming in Java 1.
 In the java programming language, a keyword is one of 50 reserved words which have a predefined meaning in the language; because of this,
 2008 Pearson Education, Inc. All rights reserved. 1 Arrays and Vectors.
1 CSC 2053 New from AutoBoxing 3 Before J2SE 5.0, working with primitive types required the repetitive work of converting between the primitive.
CSCI-383 Object-Oriented Programming & Design Lecture 25.
JAVA: An Introduction to Problem Solving & Programming, 6 th Ed. By Walter Savitch ISBN © 2012 Pearson Education, Inc., Upper Saddle River,
Arrays (part 2) 1 -Based on slides from Deitel & Associates, Inc. - Revised by T. A. Yang.
Part III © Copyright by Pearson Education, Inc. All Rights Reserved.
Chapter 18 Introduction to Custom Templates C++ How to Program, 9/e ©2016 by Pearson Education, Inc., Hoboken, NJ. All Rights Reserved. Instructor Note:
1 Chapter 21 Generics. 2 Objectives F To use generic classes and interfaces (§21.2). F To declare generic classes and interfaces (§21.3). F To understand.
(C) 2010 Pearson Education, Inc. All rights reserved.  Best way to develop and maintain a large program is to construct it from small, simple pieces,
Copyright 2006 Pearson Addison-Wesley, 2008, 2012 Joey Paquet 1 Concordia University Department of Computer Science and Software Engineering SOEN6441 –
 2006 Pearson Education, Inc. All rights reserved Templates.
(C) 2010 Pearson Education, Inc. All rights reserved. Java How to Program, 8/e.
 Pearson Education, Inc. All rights reserved. 1 Ch 18 Generics OBJECTIVES In this chapter you will learn:  To create generic methods that perform.
Java Generics. Lecture Objectives To understand the objective of generic programming To be able to implement generic classes and methods To know the limitations.
Lecture 5:Interfaces and Abstract Classes Michael Hsu CSULA.
Java Generics.
Chapter 18 Introduction to Custom Templates
Chapter 20 Generic Classes and Methods
Chapter 14 Templates C++ How to Program, 8/e
Introduction to Custom Templates
Chapter 19 Generics Dr. Clincy - Lecture.
Chapter 6 Methods: A Deeper Look
Chapter 19 Generics.
Generic Classes and Methods
Presentation transcript:

Java How to Program, 9/e © Copyright by Pearson Education, Inc. All Rights Reserved.

 Generic methods and generic classes (and interfaces) enable you to specify, with a single method declaration, a set of related methods, or with a single class declaration, a set of related types, respectively.  Generics also provide compile-time type safety that allows you to catch invalid types at compile time. © Copyright by Pearson Education, Inc. All Rights Reserved.

 Overloaded methods are often used to perform similar operations on different types of data.  Study each printArray method. ◦ Note that the type array element type appears in each method’s header and for -statement header. ◦ If we were to replace the element types in each method with a generic name— T by convention—then all three methods would look like the one in Fig © Copyright by Pearson Education, Inc. All Rights Reserved.

 If the operations performed by several overloaded methods are identical for each argument type, the overloaded methods can be more com-pactly and conveniently coded using a generic- method.  You can write a single generic method declaration that can be called with arguments of different types.  Based on the types of the arguments passed to the generic method, the compiler handles each method call appropriately.  Line 22 begins method printArray ’s declaration. © Copyright by Pearson Education, Inc. All Rights Reserved.

 All generic method declarations have a type-parameter section delimited by angle brackets ( ) that precedes the method’s return type ( in this example).  Each type-parameter section contains one or more type parameters (also called formal type parameters), separated by commas.  A type parameter, also known as a type variable, is an identifier that specifies a generic type name.  Can be used to declare the return type, parameter types and local variable types in a generic method, and act as placeholders for the types of the arguments passed to the generic method (actual type arguments).  A generic method’s body is declared like that of any other method.  Type parameters can represent only reference types—not primitive types. © Copyright by Pearson Education, Inc. All Rights Reserved.

 When the compiler translates generic method printArray into Java bytecodes, it removes the type-parameter section and replaces the type parameters with actual types.  This process is known as erasure.  By default all generic types are replaced with type Object.  So the compiled version of method printArray appears as shown in Fig. 21.4—there is only one copy of this code, which is used for all printArray calls in the example. © Copyright by Pearson Education, Inc. All Rights Reserved.

 Generic method maximum determines and returna the largest of its three arguments of the same type.  The relational operator > cannot be used with reference types, but it’s possible to compare two objects of the same class if that class implements the generic interface Comparable (package java.lang ). ◦ All the type-wrapper classes for primitive types implement this interface.  Like generic classes, generic interfaces enable you to specify, with a single interface declaration, a set of related types. © Copyright by Pearson Education, Inc. All Rights Reserved.

 Comparable objects have a compareTo method. ◦ The method must return 0 if the objects are equal, a negative integer if object1 is less than object2 or a positive integer if object1 is greater than object2.  A benefit of implementing interface Comparable is that Comparable objects can be used with the sorting and searching methods of class Collections (package java.util ). © Copyright by Pearson Education, Inc. All Rights Reserved.

 The type-parameter section specifies that T extends Compar-able —only objects of classes that implement interface Comparable can be used with this method.  Comparable is known as the upper bound of the type parameter.  By default, Object is the upper bound.  Type-parameter declarations that bound the parameter always use keyword extends regardless of whether the type parameter extends a class or implements an interface.  The restriction of using Comparable objects is important, because not all objects can be compared. © Copyright by Pearson Education, Inc. All Rights Reserved.

 When the compiler translates generic method maximum into Java bytecodes, it uses erasure to replace the type parameters with actual types.  All type parameters are replaced with the upper bound of the type parameter, which is specified in the type- parameter section.  When the compiler replaces the type-parameter information with the upper-bound type in the method declaration, it also inserts explicit cast operations in front of each method call to ensure that the returned value is of the type expected by the caller. © Copyright by Pearson Education, Inc. All Rights Reserved.

 A generic method may be overloaded.  A class can provide two or more generic methods that specify the same method name but different method parameters.  A generic method can also be overloaded by nongeneric methods.  When the compiler encounters a method call, it searches for the method declaration that most precisely matches the method name and the argument types specified in the call. © Copyright by Pearson Education, Inc. All Rights Reserved.

 The concept of a data structure, such as a stack, can be understood independently of the element type it manipulates.  Generic classes provide a means for describing the concept of a stack (or any other class) in a type- independent manner.  These classes are known as parameterized classes or parameterized types because they accept one or more type parameters. © Copyright by Pearson Education, Inc. All Rights Reserved.

 The code in methods testPushDouble and testPushInteger from the previous example is almost identical for pushing values onto a Stack or a Stack, respectively, and the code in methods testPopDouble and testPopInteger is almost identical for popping values from a Stack or a Stack, respectively.  This presents another opportunity to use generic methods. © Copyright by Pearson Education, Inc. All Rights Reserved.

 It’s also possible to instantiate generic class Stack without specifying a type argument, as follows:  // no type-argument specified Stack objectStack = new Stack( 5 ); ◦ objectStack is said to have a raw type ◦ The compiler implicitly uses type Object throughout the generic class for each type argument. ◦ The preceding statement creates a Stack that can store objects of any type. ◦ Important for backward compatibility with prior versions of Java. ◦ Raw-type operations are unsafe and could lead to exceptions. © Copyright by Pearson Education, Inc. All Rights Reserved.

 Figure shows the warning messages generated by the compiler when the file RawTypeTest.java (Fig ) is compiled with the -Xlint:unchecked option, which provides more information about potentially unsafe operations in code that uses generics. © Copyright by Pearson Education, Inc. All Rights Reserved.

 In this section, we introduce a powerful generics concept known as wildcards.  Suppose that you’d like to implement a generic method sum that totals the numbers in an ArrayList. ◦ You’d begin by inserting the numbers in the collection. ◦ The numbers would be autoboxed as objects of the type-wrapper classes—any int value would be autoboxed as an Integer object, and any double value would be autoboxed as a Double object. ◦ We’d like to be able to total all the numbers in the ArrayList regardless of their type. ◦ For this reason, we’ll declare the ArrayList with the type argument Number, which is the superclass of both Integer and Double. ◦ In addition, method sum will receive a parameter of type ArrayList and total its elements. © Copyright by Pearson Education, Inc. All Rights Reserved.

 In method sum: ◦ The for statement assigns each Number in the ArrayList to variable element, then uses Number method doubleValue to obtain the Number ’s underlying primitive value as a double value. ◦ The result is added to total. ◦ When the loop terminates, the method returns the total. © Copyright by Pearson Education, Inc. All Rights Reserved.

 Given that method sum can total the elements of an ArrayList of Number s, you might expect that the method would also work for ArrayList s that contain elements of only one numeric type, such as ArrayList.  Modified class TotalNumbers to create an ArrayList- of Integer s and pass it to method sum.  When we compile the program, the compiler issues the following error message:  sum(java.util.ArrayList ) in TotalNumbersErrors cannot be applied to (java.util.ArrayList )  Although Number is the superclass of Integer, the compiler does not consider the parameterized type ArrayList to be a superclass of ArrayList.  If it were, then every operation we could perform on ArrayList would also work on an ArrayList. © Copyright by Pearson Education, Inc. All Rights Reserved.

 To create a more flexible version of the sum method that can total the elements of any ArrayList containing elements of any subclass of Number we use wildcard-type arguments.  Wildcards enable you to specify method parameters, return values, variables or fields, and so on, that act as supertypes or subtypes of parameterized types.  In Fig , method sum ’s parameter is declared in line 50 with the type:  ArrayList  A wildcard-type argument is denoted by a question mark ( ? ), which by itself represents an “unknown type.” ◦ In this case, the wildcard extends class Number, which means that the wildcard has an upper bound of Number. ◦ Thus, the unknown-type argument must be either Number or a subclass of Number. © Copyright by Pearson Education, Inc. All Rights Reserved.

 Because the wildcard ( ? ) in the method’s header does not specify a type-parameter name, you cannot use it as a type name throughout the method’s body (i.e., you cannot replace Number with ? in line 55).  You could, however, declare method sum as follows: ◦ public static double sum( ArrayList list ) ◦ allows the method to receive an ArrayList that contains elements of any Number subclass. ◦ You could then use the type parameter T throughout the method body.  If the wildcard is specified without an upper bound, then only the methods of type Object can be invoked on values of the wildcard type.  Also, methods that use wildcards in their parameter’s type arguments cannot be used to add elements to a collection referenced by the parameter. © Copyright by Pearson Education, Inc. All Rights Reserved.