JDK 1.5之Generics

 更新时间:2006年10月13日 00:00:00   作者:  
Generics 是JDK 1.5 一个最重要的特性,主要用来处理Collection。

  以下代码在JDK 1.5 调试通过。

  代码实例1: Demo.java

  package maoxiang.examples.jdk15.generics;
  import java.util.ArrayList;
  import java.util.Collection;
  import java.util.HashMap;
  import java.util.LinkedList;
  import java.util.List;
  import java.util.Map;

  /**
  * @author 毛翔
  *
  * 演示如何使用Generics 特性。代码来自于 Generics 教程:
  * http://java.sun.com/j2se/1.5/pdf/generics-tutorial.pdf
  *
  * Generics类似于C++中的模板。
  * 区别:
  * 1.
  * 2.
  */

  public class Demo {
  public static void main(String[] args) {}

  /**
  * 最简单的用法
  */

  public void Test1() {

  // 以前的用法
  //List myIntList = new LinkedList(); // 1
  //myIntList.add(new Integer(0)); // 2
  //Integer x = (Integer) myIntList.iterator().next(); // 3 需要强制转换
  // 1.5 的用法
  List myIntList = new LinkedList(); // 1'
  myIntList.add(new Integer(0)); //2'
  Integer x = myIntList.iterator().next(); // 3'
  }

  /**
  * 匿名字符的用法
  */

  public void Test2() {
  List list = new ArrayList();
  //通过匿名字符打印一个集合

  Wildcards(list);
  Wildcards1();
  /*
  * 如果 Wildcards2 定义为Wildcards2(List shapes)
  * 以下调用错误
  */
  Wildcards2(list);
  }

  public void Wildcards(Collection< ? > c) {
  // 以前的用法
  //Iterator i = c.iterator();
  //for (int k = 0; k < c.size(); k++) {
  //
  log(i.next());
   //}

  //1.5 的用法
  //Collection c 表示
  for (Object e : c) {
  log(e);
  }
  }

  public void Wildcards1() {
  //Collection c = new ArrayList();
  //c.add(new Object()); // compile time error

  //以上为错误的用法,因为不能确定 c 的类型 ,不能使用add ,但get可以 。正确的用法如下:

  ArrayList c = new ArrayList();
  c.add("test");
  List< ? > list = c;
  log(c.get(0));
  }

  public void Wildcards2(List< ? extends Shape> shapes) {
  //List shapes 定义只能接受List shapes,也不能接受 List
  for (Shape s : shapes) {
  s.draw();
  }

  //以下写法错误,因为为参数申明为 extends Shpape,无法确定Rectangle 为Shape子类,属于不安全调用
  //shapes.add(0, new Rectangle());

  Map allDrivers = new HashMap();
  Census.addRegistry(allDrivers);
  //以下写法允许,因为drivers明确定义,
  List drivers = new ArrayList();
  Census.add(drivers);
  }

  /**
  * Generic Methods 的用法
  *
  */

  public void Test3() {
  //适用于各种类型的函数
  Object[] oa = new Object[100];
  Collection

相关文章

  • jsp输出金字塔的简单实例

    jsp输出金字塔的简单实例

    下面小编就为大家带来一篇jsp输出金字塔的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • SSM框架整合JSP中集成easyui前端ui项目开发示例详解

    SSM框架整合JSP中集成easyui前端ui项目开发示例详解

    这篇文章主要介绍了SSM框架JSP中集成easyui前端ui项目开发示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2021-10-10
  • 基于jsp的井字游戏实例

    基于jsp的井字游戏实例

    井字游戏是一款小时候的游戏,一张纸就能玩,本文主要介绍了基于jsp的井字游戏实例,有兴趣的同学可以来看一下。
    2016-10-10
  • JSP和JSTL获取服务器参数示例

    JSP和JSTL获取服务器参数示例

    JSP和JSTL获取服务器参数,项目中很常见的,下面有个不错的获取示例,感兴趣的朋友可以参考下,希望对大家有所帮助
    2013-10-10
  • (jsp/html)网页上嵌入播放器(常用播放器代码整理)

    (jsp/html)网页上嵌入播放器(常用播放器代码整理)

    网页上嵌入播放器,只要在HTML上添加以上代码就OK了,下面整理了一些常用的播放器代码,总有一款适合你,感兴趣的朋友可以参考下哈,希望对你有所帮助
    2013-05-05
  • 我认为JSP有问题(下)

    我认为JSP有问题(下)

    我认为JSP有问题(下)...
    2006-10-10
  • 详解Hibernate注解方式的二级缓存

    详解Hibernate注解方式的二级缓存

    这篇文章主要介绍了详解Hibernate注解方式的二级缓存的相关资料,需要的朋友可以参考下
    2017-06-06
  • 【算法】扑克发牌算法实现

    【算法】扑克发牌算法实现

    扑克发牌算法是棋牌游戏中常用的基础算法,也是游戏开发人员需要熟悉的基础算法之一。下面介绍一下该算法的一种实现方式。
    2008-11-11
  • jsp action中保存和修改的关系

    jsp action中保存和修改的关系

    这篇文章主要是为大家介绍了jsp中通过action保存与修改的判断方法,学习jsp的朋友可以参考下
    2013-11-11
  • JSP 动态树的实现

    JSP 动态树的实现

    在实际的项目开发中有很多是有用到动态树,所谓的动态树就是可以支持无限级子节点。今天我就去给大家实际演示一下动态树如何实现。
    2009-04-04

最新评论