`
sunnymoon
  • 浏览: 87864 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Java泛型的使用

阅读更多
package com.mycompany.mavenproject1;

import java.lang.reflect.Array;
import java.util.ArrayList;
import java.util.List;

/**
 *
 * @author sunnymoon
 * 2010-10-16 16:07:40
 * 
 * 泛型使用:包括�上界和下界通配符;无界通配符;泛型类;泛型方法;泛型类的具体化�
 */
public class TestGeneral {

    public static void main(String[] args) {
        TestGeneral.test1();
        System.out.println("test1");
        TestGeneral.test2();
        System.out.println("test2");
        TestGeneral.test3();
        System.out.println("test3");
        TestGeneral.test4();
        System.out.println("test4");
        TestGeneral.test5();
        System.out.println("test5");
        TestGeneral.test6();
        System.out.println("test6");
    }

    /**
     * 集合风格(Collection-like)的泛型函数
     */
    public static void test1() {
        Pair<Integer, Boolean> pair1 = new Pair<Integer, Boolean>(123, true);
        System.out.println(pair1.first + "|" + pair1.second);
        Pair<Integer, Long> pair2 = new Pair<Integer, Long>(123, 123l);
        System.out.println(pair2.first + "|" + pair2.second);
    }

    /**
     * 集合之外风格的泛型函数
     */
    public static void test2() {
        DBFactory facotry = new PairDBFactory();
        System.out.println(facotry.createPair().first + "|" + facotry.createPair().second);
    }

    /**
     * 上界和下界通配符
     * A
     * ?
     * ?
     * A
     */
    public static void test3() {
        /**
         * 用面向对象继承的去思考上界只可读,下界只可写更容易
         * 不可指的是不安全,会在编译,运行时报异常
         */
        final ArrayList<Integer> list = new ArrayList<Integer>(1);
        list.add(100);
        final List<? extends Number> readList = list;
//        readList.add(new Integer(2));//不保证可写
        Number n = readList.get(0);
        System.out.println(n);
        List<? super Number> writeList = new ArrayList<Object>();
        writeList.add(new Integer(5));
//        System.out.println(writeList.get(0));//不保证可读
    }

    /**
     * 通配符
     * 无界通配符
     */
    public static void test4() {
        List<?> list = new ArrayList<Integer>();
        list = new ArrayList<Object>();
    }

    /**
     * 关于泛型方法
     */
    public static void test5() {
        PairMethod<Integer> pairMethod = new PairMethod<Integer>();
        pairMethod.pair(new ArrayList<Long>(1));
        pairMethod.pair2(3);
        pairMethod.pair2_1(4);
        pairMethod.pair3(4);
        PairMethod.pair4(123123l);
        PairMethod.pair4_1(pairMethod);
    }

    /**
     * 关于泛型具体化
     * 您可能想要构造一个数组T[], new T[]是不允许的
     * 解决方案使用的是“类型令牌”
     */
    public static void test6() {
        ArrayExample<Double> example = new ArrayExample<Double>(Double.class);
        Double[] doubles = example.getArray(10);
        System.out.println(doubles.length);
    }
}

/**
 * 以下是测试时创建的类
 */
final class Pair<A, B> {

    public final A first;
    public final B second;

    public Pair(A first, B second) {
        this.first = first;
        this.second = second;
    }
}

abstract class DBFactory<T extends Pair> {

    protected abstract T createPair();

    public List<T> get(String constraint) {
        List<T> pairs = new ArrayList<T>();
        return pairs;
    }
}

final class PairDBFactory extends DBFactory {

    @Override
    protected Pair createPair() {
        return new Pair<Integer, Boolean>(123, false);
    }
}

final class PairMethod<R> {

    /**
     * 开始的<T>为所埯的类型型
     * @param <T>
     * @param list
     * @return
     */
    public <T> List<T> pair(List<T> list) {
        return list;
    }

    /**
     * 同上
     * @param <T>
     * @param obj
     * @return
     */
    public <T> List<T> pair2(T obj) {
        return null;
    }

    public <T> T pair2_1(T obj) {
        return obj;
    }

    /**
     * 打酱油的,实际是泛型类
     * @param obj
     * @return
     */
    public List<R> pair3(R obj) {
        return null;
    }

    /**
     * 静态方法也可
     * @param <T>
     * @param obj
     * @return
     */
    public static <T> List<T> pair4(T obj) {
        return null;
    }

    public static <T> T pair4_1(T obj) {
        return obj;
    }
}

final class ArrayExample<T> {

    private Class<T> clazz;

    public ArrayExample(Class<T> clazz) {
        this.clazz = clazz;
    }

    public T[] getArray(int size) {
        return (T[]) Array.newInstance(clazz, size);
    }
}

分享到:
评论

相关推荐

    Java泛型使用详细分析.pdf

    Java泛型使用详细分析.pdf

    java 泛型方法使用示例

    java 泛型方法使用示例 java 泛型方法使用示例 java 泛型方法使用示例

    Java泛型编程指南.pdf

    Java泛型编程指南.pdf 此文章译自SUN的泛型编程指南

    Java泛型应用实例

    网上很多讲泛型原理的文章, 很少有提到我们什么时候使用泛型有优势, 我就泛型类和方法搞了两个实例,算是探索下泛型使用的冰山一角吧,在我博客里面有配套的文章,可以配套看.

    Java泛型和集合

    Java Generics and Collections 英文版,详细描述java 泛型技术

    JAVA泛型加减乘除

    这是一个使用JAVA实现的泛型编程,分为两部分,第一部分创建泛型类,并实例化泛型对象,得出相加结果。 第二部分用户自行输入0--4,选择要进行的加减乘除运算或退出,再输入要进行运算的两个数,并返回运算结果及...

    java 泛型接口示例

    java 泛型接口示例 java 泛型接口示例 java 泛型接口示例

    java 泛型类的类型识别示例

    java 泛型类的类型识别示例 java 泛型类的类型识别示例 java 泛型类的类型识别示例

    1.java泛型定义.zip

    1.java泛型定义.zip1.java泛型定义.zip1.java泛型定义.zip1.java泛型定义.zip1.java泛型定义.zip1.java泛型定义.zip1.java泛型定义.zip1.java泛型定义.zip1.java泛型定义.zip1.java泛型定义.zip1.java泛型定义.zip1....

    java泛型技术之发展

    java泛型技术之发展,学习JAVA 泛型的不错东东

    4.java泛型的限制.zip

    4.java泛型的限制.zip4.java泛型的限制.zip4.java泛型的限制.zip4.java泛型的限制.zip4.java泛型的限制.zip4.java泛型的限制.zip4.java泛型的限制.zip4.java泛型的限制.zip4.java泛型的限制.zip4.java泛型的限制.zip...

    Java泛型的用法及T.class的获取过程解析

    主要介绍了Java泛型的用法及T.class的获取过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

    java泛型总结

    深入理解java泛型,包括类名泛型的定义,方法泛型定义,泛型的返回

    java 泛型的使用 详细讲解

    java 泛型的使用 详细讲解

    java泛型学习ppt

    java,学习java泛型,java培训之泛型.pptxjava培训之泛型.pptxjava培训之泛型.pptxjava培训之泛型.pptx

    很好的Java泛型的总结

    很好的Java泛型的总结,看完之后你一定会知道java泛型的底层机制,你一定会学会Java泛型!

    java泛型详解.pdf

    java泛型详解.pdf

    思维导图之Java泛型详解

    思维导图之Java泛型详解

Global site tag (gtag.js) - Google Analytics