首页 > 学院 > 开发设计 > 正文

探索JDK1.5高级编码特征

2019-11-18 15:39:28
字体:
来源:转载
供稿:网友

    本文中,我们将讨论几个在JDK1.5中新的语言特征,包括:

泛型(Generics)--为集合(collections)提供编译时类型安全,无需每刻从Collections取得一个对象就进行强制转换(cast)
增强的“for”循环(Enhanced For loop)--减少迭代器(iterator)的潜在错误(error-PRoneness)
自动置入/自动取出(Autoboxing/unboxing)--无需在基本类型(primitive types)(例如double)和包装类型(wrapper types)(例如Double)之间人工地进行转换。
类型安全的枚举(Typesafeenums)--提供类型安全枚举模式的各项好处。
静态导入(Static import)--无需在使用其他类的静态成员变量前缀其类名.这将使得代码更为简洁。
元数据(Metadata)--使编程人员避免编写样板化代码(boiler plate code),并提供机会进行宣告式程式设计(declarative programming)。


    让我们具体讨论每个新特性,并看一些例子。

    泛型(Generics)

    泛型是JDK1.5中一个最“酷”的特征。通过引入泛型,我们将获得编译时类型的安全和运行时更小地抛出ClassCastExceptions的可能。在JDK1.5中,你可以声明一个集合将接收/返回的对象的类型。在JDK1.4中,创建雇员名字的清单(List)需要一个集合对象,像下面的语句:

    List listOfEmployeeName = new ArrayList();

    在JDK1.5中,你将使用下面语句

    List listOfEmployeeName = new ArrayList();

    最“酷”的是,假如你试图插入非string类型的值,你将在编译时发现并且修正这类问题。没有泛型,你会发现这样一个bug,当你的客户调用后会告诉你,你所编写的程序抛出ClassCastException异常而崩溃。

    另外,当你从集合中得到一个元素时你无需进行强制转换。故原先为:

    String employeeName = ((String) listOfEmployee.get(i));

    而下面的语句将比上面的更加简单:

    String employeeName = listOfEmployee.get(i);

    不清楚对象的类型而强制转换对象是不合理的,并且更重要的是,它将在运行时失败。假使用户无意间传入一个包含string buffers类型而非string类型的集合,那结果会怎样呢。在Listing A中,客户被要求传入一个编译器无法强制的strings类型集合。Listing B中显示了同样的方法使用泛型是如何实现的。

    Listing A

    staticbooleancheckName(Collection employeeNameList, String name) {

    for (Iteratori = employeeNamList.iterator(); i.hasNext(); ) {

    String s = (String) i.next();

    if(s.equals(name)){

    return true;

    //print employee name here ......

    }

    }

    return false;

    }

 

    Listing B

    staticbooleancheckName(Collection employeeNameList, String name) {

    for (Iteratori = employeeNamList.iterator(); i.hasNext(); ) {

    if(i.next().equals(name)){



发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表