test/com/sun/javadoc/testNewLanguageFeatures/pkg/TypeParameters.java

Sat, 01 Dec 2007 00:00:00 +0000

author
duke
date
Sat, 01 Dec 2007 00:00:00 +0000
changeset 1
9a66ca7c79fa
child 554
9d9f26857129
permissions
-rw-r--r--

Initial load

duke@1 1 /*
duke@1 2 * Copyright 2003-2004 Sun Microsystems, Inc. All Rights Reserved.
duke@1 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
duke@1 4 *
duke@1 5 * This code is free software; you can redistribute it and/or modify it
duke@1 6 * under the terms of the GNU General Public License version 2 only, as
duke@1 7 * published by the Free Software Foundation.
duke@1 8 *
duke@1 9 * This code is distributed in the hope that it will be useful, but WITHOUT
duke@1 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
duke@1 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
duke@1 12 * version 2 for more details (a copy is included in the LICENSE file that
duke@1 13 * accompanied this code).
duke@1 14 *
duke@1 15 * You should have received a copy of the GNU General Public License version
duke@1 16 * 2 along with this work; if not, write to the Free Software Foundation,
duke@1 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
duke@1 18 *
duke@1 19 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
duke@1 20 * CA 95054 USA or visit www.sun.com if you need additional information or
duke@1 21 * have any questions.
duke@1 22 */
duke@1 23
duke@1 24 package pkg;
duke@1 25
duke@1 26 import java.util.*;
duke@1 27
duke@1 28 /**
duke@1 29 * Just a sample class with type parameters. This is a link to myself:
duke@1 30 * {@link TypeParameters}
duke@1 31 *
duke@1 32 * @param <E> the type parameter for this class.
duke@1 33 * @param <BadClassTypeParam> this should cause a warning.
duke@1 34 * @see TypeParameters
duke@1 35 */
duke@1 36
duke@1 37 public class TypeParameters<E> implements SubInterface<E> {
duke@1 38
duke@1 39 /**
duke@1 40 * This method uses the type parameter of this class.
duke@1 41 * @param param an object that is of type E.
duke@1 42 * @return the parameter itself.
duke@1 43 */
duke@1 44 public E methodThatUsesTypeParameter(E param) {
duke@1 45 return param;
duke@1 46 }
duke@1 47
duke@1 48 /**
duke@1 49 * This method has type parameters. The list of type parameters is long
duke@1 50 * so there should be a line break in the member summary table.
duke@1 51 *
duke@1 52 * @param <T> This is the first type parameter.
duke@1 53 * @param <V> This is the second type parameter.
duke@1 54 * @param <BadMethodTypeParam> this should cause a warning.
duke@1 55 * @param param1 just a parameter.
duke@1 56 * @param param2 just another parameter.
duke@1 57 *
duke@1 58 */
duke@1 59 public <T extends List, V> String[] methodThatHasTypeParameters(T param1,
duke@1 60 V param2) { return null;}
duke@1 61
duke@1 62 /**
duke@1 63 * This method has type parameters. The list of type parameters is short
duke@1 64 * so there should not be a line break in the member summary table.
duke@1 65 * @author Owner
duke@1 66 *
duke@1 67 * @param <A> This is the first type parameter.
duke@1 68 */
duke@1 69 public <A> void methodThatHasTypeParmaters(A... a) {}
duke@1 70 }

mercurial