Java 核心技术 卷I 基础知识 第 8 章泛型程序设计

本文深入探讨了Java中的泛型编程,从为什么要使用泛型、如何定义泛型类和方法,到类型变量的限定,以及泛型在虚拟机中的表现。同时,详细介绍了泛型的约束与局限性,如类型擦除、不能实例化类型参数等,并阐述了泛型类型的继承规则、通配符类型的概念和应用,最后讨论了反射与泛型的交互。
摘要由CSDN通过智能技术生成

在这里插入图片描述

8.1 为什么要使用泛型程序设计

在这里插入图片描述

8.1.1 类型参数的好处

在这里插入图片描述在这里插入图片描述在这里插入图片描述

8.1.2 谁想成为泛型程序员

在这里插入图片描述在这里插入图片描述

8.2 定义简单泛型类

在这里插入图片描述在这里插入图片描述在这里插入图片描述

package pair1;

/**
 * @version 1.00 2004-05-10
 * @author Cay Horstmann
 */
public class Pair<T> 
{
   private T first;
   private T second;

   public Pair() { first = null; second = null; }
   public Pair(T first, T second) { this.first = first;  this.second = second; }

   public T getFirst() { return first; }
   public T getSecond() { return second; }

   public void setFirst(T newValue) { first = newValue; }
   public void setSecond(T newValue) { second = newValue; }
}

package pair1;

/**
 * @version 1.01 2012-01-26
 * @author Cay Horstmann
 */
public class PairTest1
{
   public static void main(String[] args)
   {
      String[] words = { "Mary", "had", "a", "little", "lamb" };
      Pair<String> mm = ArrayAlg.minmax(words);
      System.out.println("min = " + mm.getFirst());
      System.out.println("max = " + mm.getSecond());
   }
}

class ArrayAlg
{
   /**
    * Gets the minimum and maximum of an array of strings.
    * @param a an array of strings
    * @return a pair with the min and max value, or null if a is null or empty
    */
   public static Pair<String> minmax(String[] a)
   {
      if (a == null || a.length == 0) return null;
      String min = a[0];
      String max = a[0];
      for (int i = 1; i < a.length; i++)
      {
         if (min.compareTo(a[i]) > 0) min = a[i];
         if (max.compareTo(a[i]) < 0) max = a[i];
      }
      return new Pair<>(min, max);
   }
}

8.3 泛型方法

在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

8.4 类型变量的限定

在这里插入图片描述在这里插入图片描述在这里插入图片描述

package pair2;

/**
 * @version 1.00 2004-05-10
 * @author Cay Horstmann
 */
public class Pair<T>
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值