本文中,我们将讨论几个在JDK1.5中新的语言特征,包括:<o:p></o:p>
- 泛型(Generics)--为集合(collections)提供编译时类型安全,无需每刻从Collections取得一个对象就进行强制转换(cast) <o:p></o:p>
- 增强的“for”循环(Enhanced For loop)--减少迭代器(iterator)的潜在错误(error-proneness) <o:p></o:p>
- 自动置入/自动取出(Autoboxing/unboxing)--无需在基本类型(primitive types)(例如double)和包装类型(wrapper types)(例如Double)之间人工地进行转换。 <o:p></o:p>
- 类型安全的枚举(Typesafeenums)--提供类型安全枚举模式的各项好处。 <o:p></o:p>
- 静态导入(Static import)--无需在使用其他类的静态成员变量前缀其类名.这将使得代码更为简洁。 <o:p></o:p>
- 元数据(Metadata)--使编程人员避免编写样板化代码(boiler plate code),并提供机会进行宣告式程式设计(declarative programming)。 <o:p></o:p>
让我们详细讨论每个新特性,并看一些例子。<o:p></o:p>
泛型(Generics)<o:p></o:p>
泛型是JDK1.5中一个最“酷”的特征。通过引入泛型,我们将获得编译时类型的安全和运行时更小地抛出ClassCastExceptions的可能。在JDK1.5中,你可以声明一个集合将接收/返回的对象的类型。在JDK1.4中,创建雇员名字的清单(List)需要一个集合对象,像下面的语句:<o:p></o:p>
List listOfEmployeeName = new ArrayList(); <o:p></o:p>
在JDK1.5中,你将使用下面语句<o:p></o:p>
List<String> listOfEmployeeName = new ArrayList<String>();<o:p></o:p>
最“酷”的是,如果你试图插入非string类型的值,你将在编译时发现并且修正这类问题。没有泛型,你会发现这样一个bug,当你的客户调用后会告诉你,你所编写的程序抛出ClassCastException异常而崩溃。<o:p></o:p>
另外,当你从集合中得到一个元素时你无需进行强制转换。故原先为:<o:p></o:p>
String employeeName = ((String) listOfEmployee.get(i));
而下面的语句将比上面的更加简单:<o:p></o:p>
String employeeName = listOfEmployee.get(i);<o:p></o:p>
不清楚对象的类型而强制转换对象是不合理的,并且更重要的是,它将在运行时失败。假使用户无意间传入一个包含string buffers类型而非string类型的集合,那结果会怎样呢。在Listing A中,客户被要求传入一个编译器无法强制的strings类型集合。Listing B中显示了同样的方法使用泛型是如何实现的。<o:p></o:p>
Listing A <o:p></o:p>
staticbooleancheckName(Collection employeeNameList, String name) {<o:p></o:p>
for (Iteratori = employeeNamList.iterator(); i.hasNext(); ) {<o:p></o:p>
String s = (String) i.next();<o:p></o:p>
if(s.equals(name)){<o:p></o:p>
return true;<o:p></o:p>
//print employee name here ......<o:p></o:p>
}<o:p></o:p>
}<o:p></o:p>
return false;<o:p></o:p>
}<o:p></o:p>
<o:p></o:p>
Listing B <o:p></o:p>
staticbooleancheckName(Collection<String> employeeNameList, String name) {<o:p></o:p>
for (Iteratori = employeeNamList.iterator(); i.hasNext(); ) {<o:p></o:p>
if(i.next().equals(name)){<o:p></o:p>
return true;<o:p></o:p>
//print employee name here ......<o:p></o:p>
}<o:p></o:p>
}<o:p></o:p>
return false;<o:p></o:p>
}<o:p></o:p>
现在,通过方法签名可以清楚知道输入集合必须只能包含strings。如果客户试图传入一个包含string buffers的集合,程序将不会编译。同时注意,该方法不包含任何强制转换。它只需要短短一行,一旦你习惯泛型后,它也更加清晰。<o:p></o:p>
在JDK当前版本下的For循环语法如下:<o:p></o:p>
void printAll(Collection c) {
for (Iteratori = c.iterator(); i.hasNext(); ) {
Employee emp = (Employee)i.next();
System.out.println(emp.getName());
}
}
<o:p></o:p>
现在,用增强的For语句实现相同方法:<o:p></o:p>
voidprintAll(Collection c) {
for (Object o : c)
System.out.println((TimerTask)o).getName());
} <o:p></o:p>
在这类For循环中,你应该将":"看成"in",所以,在该例中可以看成"for Object o in c"。你可以发现这种For循环更具可读性。<o:p></o:p>
自动置入/自动取出(Autoboxing/unboxing)<o:p></o:p>
Java有基本数据类型,在这些基本数据类型周围又有包装类。通常,编程人员需要将一种类型转换成另一种。看看Listing C.中的代码片断。<o:p></o:p>
Listing C <o:p></o:p>
public class Employee {<o:p></o:p>
private static final Integer CHILD = new Integer(0);<o:p></o:p>
public static void main(String args[]) {<o:p></o:p>
//code for adding n to an Integer<o:p></o:p>
int n=10;<o:p></o:p>
Integer age= new Integer(30);<o:p></o:p>
Integer ageAfterTenYear= new Integer(age.intValue +10);<o:p></o:p>
}<o:p></o:p>
}<o:p></o:p>
请注意,用于计算ageAfterTenYear的内循环代码看上去是多么杂乱。现在,在Listing D.中看看相同的程序使用autoboxing重写后的样子。<o:p></o:p>
Listing D <o:p></o:p>
public class Employee {<o:p></o:p>
public static void main(String args[]) {<o:p></o:p>
int n=10;<o:p></o:p>
Integer age= new Integer(30);<o:p></o:p>
Integer ageAfterTenYear= age +10;<o:p></o:p>
}<o:p></o:p>
}<o:p></o:p>
有一件事值得注意的:在先前,如果你取出(unbox)Null值,它将变为0。在次代码中,编译器将自动地转换Integer为int然后加上10,接着将其转换回Integer.。<o:p></o:p>
类型安全的枚举(Typesafeenums)<o:p></o:p>
类型安全枚举提供下列特性:<o:p></o:p>
- 他们提供编译时类型安全。 <o:p></o:p>
- 他们都是对象,因此你不需要将他们放入集合中。 <o:p></o:p>
- 他们作为一种类的实现,因此你可以添加一些方法。 <o:p></o:p>
- 他们为枚举类型提供了合适的命名空间。 <o:p></o:p>
- 他们打印的值具有情报性(informative)— 如果你打印一个整数枚举(intenum),你只是看见一个数字,它可能并不具有情报性。 <o:p></o:p>
例一:<o:p></o:p>
enum Season { winter, spring, summer, fall } <o:p></o:p>
例二:<o:p></o:p>
public enum Coin {
penny(1), nickel(5), dime(10), quarter(25);
Coin(int value) { this.value = value; }
private final int value;
public int value() { return value; }
}<o:p></o:p>
静态导入(Static import)<o:p></o:p>
静态导入使代码更易读。通常,你要使用定义在另一个类中的常量(constants),像这样:<o:p></o:p>
importorg.yyy.pkg.Increment;
class Employee {
public Double calculateSalary(Double salary{
return salary + Increment.INCREMENT * salary;
}
} <o:p></o:p>
当时使用静态导入,我们无需为常量名前缀类名就能使用这些常量,像这样:<o:p></o:p>
import static org.yyy.pkg.Increment;
class Employee {
public Double calculateSalary(Double salary{
return salary + INCREMENT * salary;
}
}<o:p></o:p>
注意,我们可以调用INCREMENT这一常量而不要使用类名Increment.。<o:p></o:p>
元数据(Metadata)<o:p></o:p>
元数据特征志于使开发者们借助厂商提供的工具可以进行更简易的开发。看一看Listing E.中的代码。<o:p></o:p>
Listing E <o:p></o:p>
importorg.yyy.hr;<o:p></o:p>
public interface EmployeeI extends Java.rmi.Remote {<o:p></o:p>
public String getName()<o:p></o:p>
throwsJava.rmi.RemoteException;<o:p></o:p>
public String getLocation ()<o:p></o:p>
throwsJava.rmi.RemoteException;<o:p></o:p>
}<o:p></o:p>
public class EmployeeImpl implements EmployeeI {<o:p></o:p>
public String getName(){<o:p></o:p>
<o:p></o:p>
}<o:p></o:p>
public String getLocation (){<o:p></o:p>
<o:p></o:p>
}<o:p></o:p>
}<o:p></o:p>
通过元数据的支持,你可以改写Listing E中的代码为:<o:p></o:p>
importorg.yyy.hr;
public class Employee {
@Remote public String getName() {
...
}
@Remote public public String getLocation() {
...
}
}<o:p></o:p>
正像你所看到的,所有样板化的代码都不见了。<o:p></o:p>
这些新特性和规格说明将在JDK1.5中实现。它将提供Java编程社区更多的选择以编写鲁棒的、可扩展的代码。认真的Java编程人员将感到着手去熟悉这一Java编程语言的新版本是很有益的。<o:p></o:p>
相关推荐
JDK1.5是Java的一个重要版本,它在2004年9月30日正式发布,也被称为Java 5.0。这个版本引入了大量的新特性,对Java平台进行了重大改进,提升了开发效率和性能。 首先,JDK1.5引入了类型安全的枚举(enum),这是对...
标题:“jdk1.5 windows版本 64位” 描述:“jdk1.5 windows版本 64位,Java开发依赖环境” 标签:“windows” 在这个主题中,我们聚焦的是Oracle JDK 1.5(也被称为Java Development Kit,简称JDK)在Windows...
Linux系统中的JDK1.5是Java开发工具包的一个早期版本,主要针对Java语言的编译、运行和调试提供支持。这个版本在今天已经相对较为罕见,因为Java已经有了多个后续版本,包括JDK7、JDK8、JDK9直至最新的JDK17等。然而...
### JDK 1.5 中新的语言特征分类介绍 #### 泛型(Generics) 泛型是Java Development Kit (JDK) 1.5 版本中最显著的新特性之一,它为开发者提供了强大的类型安全机制。在Java早期版本中,集合(如`List`或`Set`)...
JDK1.5,也称为Java 5.0,是一个重要的版本,它引入了许多新的特性和改进,对Java语言的发展产生了深远影响。 一、泛型(Generics) 在Java 5.0中,最重要的特性之一就是泛型的引入。泛型允许开发者在定义类、接口...
JDK1.5,全称Java Development Kit 1.5,是Java平台标准版(Java SE)的一个重要版本,由Sun Microsystems在2004年9月30日正式发布。这个版本引入了大量的新特性,对Java编程语言进行了重大改进,极大地提升了开发...
JDK1.5,全称Java Development Kit 1.5,是Java编程语言的一个重要版本,由Oracle公司发布。这个版本在Java的历史上具有里程碑意义,因为它引入了许多新特性和改进,大大提升了开发效率和代码质量。在本文中,我们将...
jdk1.5.exe jdk1.5 jdk1.5下载
**Java Development Kit (JDK) 1.5 Windows 64位官方正式版** JDK 1.5,也称为Java SE 5.0(Java Standard Edition 5.0),是Oracle公司(前身为Sun Microsystems)发布的一个重要的Java开发工具包。这个版本于2004...
绝版jdk1.5,非常不错的资源。用起来很好。是 Java语言对Bean类属性、事件的一种缺省处理方法。例如类A中有属性name,那我们可以通过getName,setName来得到其值或者设置新 的值。通过getName/setName来访问name属性,...
这个压缩包包含了三个不同版本的JDK:JDK 1.5、JDK 1.6和JDK 1.8,其中1.5和1.6是早期版本,而1.8是最流行且广泛使用的版本之一。 **JDK 1.5(也称为Java 5.0)** JDK 1.5在2004年发布,引入了许多重要的新特性,如...
前几天上传过这个资源,因为是在jdk1.6上开发的, 测试了一下在jdk1.5上不能用, 今天重新用jdk1.5编译了一下, 这个是可以支持jdk1.5+的 将 pu-xlscommon-1.0.0.jar 添加到工程的 /lib 目录下 用法在附件中 XlsTest....
JDK1.5 全平台安装包下载 百度网盘资源 jdk-1_5_0_22-linux-amd64-rpm.bin jdk-1_5_0_22-linux-amd64.bin jdk-1_5_0_22-linux-i586-rpm.bin jdk-1_5_0_22-linux-i586.bin jdk-1_5_0_22-solaris-amd64...
在"IBM_jdk1.5_Guide.pdf"这个文档中,很可能是IBM JDK 1.5的官方指南或开发者手册,它将详细阐述如何安装、配置和使用IBM JDK 1.5,以及如何在AIX环境下进行Java开发。而"www.pudn.com.txt"可能是下载资源的来源...
标题中的"window JDK1.5 32位 绿色免安装版"指的是适用于Windows操作系统的32位版本的JDK 1.5,它是一个便携式版本,无需正式安装即可使用。这种绿色免安装版通常是为了方便开发者在不同机器间快速切换工作环境,或...
测试可用的linux版jdk1.5,jdk-1_5_0_19-linux-i586-rpm.bin
**JDK1.5**,又称为Java Development Kit的第5个主要版本,标志着Java语言的一个重大里程碑。这个版本引入了一系列创新性特性和改进,极大地提升了开发效率和代码的可读性,为Java编程带来了全新的体验。以下是JDK...
总的来说,JDK1.5对Java语言做了大量的优化和增强,使得Java更适合于现代软件开发的需求,提升了代码质量和开发效率。这个版本的JDK1.5.0.22是64位的,适用于Windows操作系统,能够充分利用64位系统的优势,提供更好...
本资源提供的是JDK 1.5版本的32位安装包,适用于那些仍然需要支持较旧系统或者特定项目需求的开发者。 JDK 1.5,也被称为Java SE 5.0,于2004年9月30日正式发布,是Java发展历程中的一个重要里程碑。这个版本引入了...
本文将深入探讨Linux下JDK1.5的相关知识点,帮助用户更好地理解和使用这个版本的Java开发环境。 首先,安装JDK1.5在Linux系统中通常涉及以下步骤: 1. **下载**:你需要从Oracle官方网站或者第三方镜像站点下载...