`
kangsg219
  • 浏览: 123112 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

JDK5.0的11个主要新特征及简单例子

阅读更多

1 泛型(Generic)

1.1 说明

增强了java的类型安全,可以在编译期间对容器内的对象进行类型检查,在运行期不必进行类型的转换。而在j2se5之前必须在运行期动态进行容器内对象的检查及转换减少含糊的容器,可以定义什么类型的数据放入容器

ArrayList<Integer> listOfIntegers; // <TYPE_NAME> is new to the syntax

Integer integerObject;

listOfIntegers = new ArrayList<Integer>(); // <TYPE_NAME> is new to the syntax

listOfIntegers.add(new Integer(10)); // 只能是Integer类型

integerObject = listOfIntegers.get(0); // 取出对象不需要转换

1.2 用法

声明及实例化泛型类:

HashMap<String,Float> hm = new HashMap<String,Float>();

//不能使用原始类型

GenList<int> nList = new GenList<int>(); //编译错误

J2SE 5.0目前不支持原始类型作为类型参数(type parameter)

定义泛型接口:

public interface GenInterface<T> {

void func(T t);

}

定义泛型类:

public class ArrayList<ItemType> { ... }

public class GenMap<T, V> { ... }

例1:

public class MyList<Element> extends LinkedList<Element>

{

public void swap(int i, int j)

{

Element temp = this.get(i);

this.set(i, this.get(j));

this.set(j, temp);

}

public static void main(String[] args)

{

MyList<String> list = new MyList<String>();

list.add("hi");

list.add("andy");

System.out.println(list.get(0) + " " + list.get(1));

list.swap(0,1);

System.out.println(list.get(0) + " " + list.get(1));

}

}

例2:

public class GenList <T>{

private T[] elements;

private int size = 0;

private int length = 0;

public GenList(int size) {

elements = (T[])new Object[size];

this.size = size;

}

public T get(int i) {

if (i < length) {

return elements[i];

}

return null;

}

public void add(T e) {

if (length < size - 1)

elements[length++] = e;

}

}

泛型方法:

public class TestGenerics{

public <T> String getString(T obj) { //实现了一个泛型方法

return obj.toString();

}

public static void main(String [] args){

TestGenerics t = new TestGenerics();

String s = "Hello";

Integer i = 100;

System.out.println(t.getString(s));

System.out.println(t.getString(i));

}

}

1.3 受限泛型

受限泛型是指类型参数的取值范围是受到限制的. extends关键字不仅仅可以用来声明类的继承关系, 也可以用来声明类型参数(type parameter)的受限关系.例如, 我们只需要一个存放数字的列表, 包括整数(Long, Integer, Short), 实数(Double, Float), 不能用来存放其他类型, 例如字符串(String), 也就是说, 要把类型参数T的取值泛型限制在Number极其子类中.在这种情况下, 我们就可以使用extends关键字把类型参数(type parameter)限制为数字

示例

public class Limited<T extends Number> {

public static void main(String[] args) {

Limited<Integer> number; //正确

Limited<String> str; //编译错误

}

}

1.4 泛型与异常

类型参数在catch块中不允许出现,但是能用在方法的throws之后。例:

import java.io.*;

interface Executor<E extends Exception> {

void execute() throws E;

}

public class GenericExceptionTest {

public static void main(String args[]) {

try {

Executor<IOException> e = new Executor<IOException>() {

public void execute() throws IOException{

// code here that may throw an

// IOException or a subtype of

// IOException

}

};

e.execute();

} catch(IOException ioe) {

System.out.println("IOException: " + ioe);

ioe.printStackTrace();

}

}

}

1.5 泛型的通配符"?"

"?"可以用来代替任何类型, 例如使用通配符来实现print方法。

public static void print(GenList<?> list) {})

1.6 泛型的一些局限型

不能实例化泛型

T t = new T(); //error

不能实例化泛型类型的数组

T[] ts= new T[10]; //编译错误

不能实例化泛型参数数

Pair<String>[] table = new Pair<String>(10); // ERROR

类的静态变量不能声明为类型参数类型

public class GenClass<T> {

private static T t; //编译错误

}

泛型类不能继承自Throwable以及其子类

public GenExpection<T> extends Exception{} //编译错误

不能用于基础类型int等

Pair<double> //error

Pair<Double> //right

2 增强循环(Enhanced for Loop)

旧的循环

LinkedList list = new LinkedList();

list.add("Hi");

list.add("everyone!");

list.add("Was");

list.add("the");

list.add("pizza");

list.add("good?");

for (int i = 0; i < list.size(); i++)

System.out.println((String) list.get(i));

//或者用以下循环

//for(Iterator iter = list.iterator(); iter.hasNext(); ) {

//Integer stringObject = (String)iter.next();

// ... more statements to use stringObject...

//}

新的循环

LinkedList<String> list = new LinkedList<String>();

list.add("Hi");

list.add("everyone!");

list.add("Was");

list.add("the");

list.add("pizza");

list.add("good?");

for (String s : list)

System.out.println(s);

很清晰、方便,一看便知其用法

3 可变参数(Variable Arguments)

实现了更灵活的方法参数传入方式,System.out.printf是个很好的例子

用法:void test(Object … args)

一个很容易理解的例子

public static int add(int ... args){

int total = 0;

for (int i = 0; i < args.length; i++)

total += args[i];

return total;

}

public static void main(String[] args){

int a;

a = Varargs.add(1, 2, 3, 4, 5, 6, 7, 8, 9, 10);

System.out.println(a);

}

4 自动实现装箱和解箱操作(Boxing/Unboxing Conversions)

说明:实现了基本类型与外覆类之间的隐式转换。基本类型至外覆类的转换称为装箱,外覆类至基本类型的转换为解箱。这些类包括

Primitive Type Reference Type

boolean Boolean

byte Byte

char Character

short Short

int Integer

long Long

float Float

double Double

例如,旧的实现方式

Integer intObject;

int intPrimitive;

ArrayList arrayList = new ArrayList();

intPrimitive = 11;

intObject = new Integer(intPrimitive);

arrayList.put(intObject); // 不能放入int类型,只能使Integer

新的实现方式

int intPrimitive;

ArrayList arrayList = new ArrayList();

intPrimitive = 11;

//在这里intPrimitive被自动的转换为Integer类型

arrayList.put(intPrimitive);

5 静态导入(Static Imports)

很简单的东西,看一个例子:

没有静态导入

Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2));

有了静态导入

import static java.lang.Math.*;

sqrt(pow(x, 2) + pow(y, 2));



其中import static java.lang.Math.*;就是静态导入的语法,它的意思是导入Math类中的所有static方法和属性。这样我们在使用这些方法和属性时就不必写类名。

需要注意的是默认包无法用静态导入,另外如果导入的类中有重复的方法和属性则需要写出类名,否则编译时无法通过。

6 枚举类(Enumeration Classes)

用法:public enum Name {types, ….}

简单的例子:

public enum Colors {Red, Yellow, Blue, Orange, Green, Purple, Brown, Black}

public static void main(String[] args){

Colors myColor = Colors.Red;

System.out.println(myColor);

}

又一个简单例子:

import java.util.*;

enum OperatingSystems {windows, unix, linux, macintosh}

public class EnumExample1 {

public static void main(String args[]) {

OperatingSystems os;

os = OperatingSystems.windows;

switch(os) {

case windows:

System.out.println(“You chose Windows!”);

break;

case unix:

System.out.println(“You chose Unix!”);

break;

case linux:

System.out.println(“You chose Linux!”);

break;

case macintosh:

System.out.println(“You chose Macintosh!”);

break;

default:

System.out.println(“I don’t know your OS.”);

break;

}

}

}

应运enum简写的例子:

import java.util.*;

public class EnumTest

{
public static void main(String[] args)

{

Scanner in = new Scanner(System.in);

System.out.print("Enter a size: (SMALL, MEDIUM, LARGE, EXTRA_LARGE) ");

String input = in.next().toUpperCase();

Size size = Enum.valueOf(Size.class, input);

System.out.println("size=" + size);

System.out.println("abbreviation=" + size.getAbbreviation());

if (size == Size.EXTRA_LARGE)

System.out.println("Good job--you paid attention to the _.");

}

}

enum Size

{

SMALL("S"), MEDIUM("M"), LARGE("L"), EXTRA_LARGE("XL");

private Size(String abbreviation) { this.abbreviation = abbreviation; }

public String getAbbreviation() { return abbreviation; }

private String abbreviation;

}

enum类中拥有方法的一个例子:

enum ProgramFlags {

showErrors(0x01),

includeFileOutput(0x02),

useAlternateProcessor(0x04);

private int bit;

ProgramFlags(int bitNumber) {

bit = bitNumber;

}

public int getBitNumber() {

return(bit);

}

}

public class EnumBitmapExample {

public static void main(String args[]) {

ProgramFlags flag = ProgramFlags.showErrors;

System.out.println(“Flag selected is: “ +

flag.ordinal() +

“ which is “ +

flag.name());

}

}

7 元数据(Meta data)

请参考

http://www-900.ibm.com/developerWorks/cn/java/j-annotate1/

http://www-900.ibm.com/developerworks/cn/java/j-annotate2.shtml

8 Building Strings(StringBuilder类)

在JDK5.0中引入了StringBuilder类,该类的方法不是同步(synchronized)的,这使得它比StringBuffer更加轻量级和有效。

9 控制台输入(Console Input)

在JDK5.0之前我们只能通过JOptionPane.showInputDialog进行输入,但在5.0中我们可以通过类Scanner在控制台进行输入操作

例如在1.4中的输入

String input = JOptionPane.showInputDialog(prompt);

int n = Integer.parseInt(input);

double x = Double.parseDouble(input);

s = input;

在5.0中我们可以

Scanner in = new Scanner(System.in);

System.out.print(prompt);

int n = in.nextInt();

double x = in.nextDouble();

String s = in.nextLine();

10 Covariant Return Types(不晓得怎么翻译,大概是 改变返回类型)

JDK5之前我们覆盖一个方法时我们无法改变被方法的返回类型,但在JDK5中我们可以改变它

例如1.4中我们只能

public Object clone() { ... }

...

Employee cloned = (Employee) e.clone();

但是在5.0中我们可以改变返回类型为Employee

public Employee clone() { ... }

...

Employee cloned = e.clone();

11 格式化I/O(Formatted I/O)

增加了类似C的格式化输入输出,简单的例子:

public class TestFormat{

public static void main(String[] args){

int a = 150000, b = 10;

float c = 5.0101f, d = 3.14f;

System.out.printf("%4d %4d%n", a, b);

System.out.printf("%x %x%n", a, b);

System.out.printf("%3.2f %1.1f%n", c, d);

System.out.printf("%1.3e %1.3e%n", c, d*100);

}

}

输出结果为:

150000 10

249f0 a

5.01 3.1

5.010e+00 3.140e+02

分享到:
评论

相关推荐

    JDK5.0的11个主要新特征.doc

    ### JDK5.0 的 11 个主要新特性 #### 1. 泛型 (Generics) **1.1 说明** Java 5.0 引入了泛型的概念,这大大增强了 Java 语言的类型安全性。通过泛型,开发人员可以在编译阶段而不是运行时对容器内的对象进行类型...

    JDK 5.0的新特性

    JDK 5.0是Java开发工具包的一个重要版本,引入了许多创新特性和改进,极大地提升了开发效率和代码质量。其中最引人注目的新特性之一就是Annotations(注解),它为元数据提供了新的编程模型,使得开发者可以更加便捷...

    JAVA5.0新特性讲解与例子

    Java 5.0,也被称为Java 1.5,是Java发展历程中的一个重要里程碑,它引入了许多创新特性,显著提升了代码的可读性、安全性和效率。以下是对这些新特性的详细讲解: 1. **泛型(Generics)** 泛型是Java 5.0最显著...

    全新java初学者实践教程(J2SE5.0版)

    - 安装JDK到一个合适的目录,例如`C:\Program Files\Java\jdk1.5.0_11`。 2. **设置环境变量**: - 打开环境变量设置界面,新建或编辑以下三个环境变量: - `JAVA_HOME`:设置为JDK的安装路径。 - `PATH`:添加...

    Java-jdk1.5安装包

    JDK1.5,也称为Java 5.0,是一个重要的版本,它引入了许多新的特性和改进,对Java语言的发展产生了深远影响。 一、泛型(Generics) 在Java 5.0中,最重要的特性之一就是泛型的引入。泛型允许开发者在定义类、接口...

    详细描述jdk1.5新特性

    Java 5.0(也称为 JDK 1.5)引入了一系列重要的新特性,这些特性极大地提高了开发者的编程效率和代码质量。其中最显著的特性之一便是泛型(Generics)。本文将详细介绍泛型的概念、使用方式以及它如何帮助开发者编写...

    java 一个关于泛型的简单例子

    泛型是Java编程语言中的一个重要特性,它引入于JDK 5.0,极大地提高了代码的类型安全性和可读性。泛型允许我们在类、接口和方法中使用类型参数,这样我们可以在编译时检查类型,避免了运行时类型转换的麻烦和潜在的...

    多jdk多tomcat配置

    在软件开发过程中,不同的项目可能对Java运行环境有着不同的需求,比如一个项目需要使用JDK 1.4 和 Tomcat 5.0,而另一个项目则需要使用JDK 1.5 和 Tomcat 6.0。这种情况下,单一的Java Home配置显然无法满足所有...

    JDK5一些新特性关于枚举泛型等

    Java JDK 5.0引入了许多重要的新特性,极大地提升了编程的效率和代码的健壮性。其中,枚举(enum)类型和泛型(Generic)是两个显著的改进。 1. 枚举类型: 在JDK 5之前,我们通常使用常量接口或静态常量来表示一...

    使用Struts+Spring+Hibernate整合开发例子

    环境:jdk5.0 eclipse3.2 struts1.1 spring1.2 hibernate3.1 mysql5.0 1. 新建一个starssh的web工程 2. 添加struts框架包。 3. 添加spring框架包。注意spring的配置文件要放到WEB-INF下。 4. 添加hibernate框架...

    Beginning.Java.2.JDK.5.Edition

    《Beginning Java 2 JDK 5 Edition》是一本针对初学者的Java编程指南,专注于JDK 5.0版本。这本书详细介绍了如何从零开始学习Java编程语言,利用JDK 5.0的新特性进行开发。以下是一些核心知识点: 1. **Java语言...

    适用jdk1.8的freemarker

    尽管Freemarker本身对JDK版本的要求并不高,通常支持J2SE 5.0及更高版本,但使用Java 1.8可以充分利用其新特性,如 Lambda表达式 和 Stream API,提高代码的简洁性和效率。 2. Freemarker基本概念: - 模板...

    精通Java:JDK、数据库系统开发Web开发(实例代码)

    第1篇 认识Java及其环境配置 第1章 认识Java 第2章 下载和安装JDK5.0 第3章 选择开发工具IDE 第2篇 Java语言基础 第4章 Java基本语法 第5章 Java面向对象程序设计(上) 第6章 Java面向...

    1-Java介绍及JDK配置

    JDK 1.5,也被称为Java 5.0,是一个重要的版本升级,引入了许多新特性和改进,如泛型、枚举、注解(Annotations)和自动装箱/拆箱等,这些都极大地提高了代码的可读性和可维护性。 首先,让我们详细讨论JDK的安装和...

    java学习笔记JDK6课件之三

    // printf() 是 J2SE5.0 的新功能,必须安裝 JDK5.0 才能编译 System.out.printf("%s ! 这是您的第 %d 个 Java 程序! \n", "C 语言 Fan", 3); } } ``` 在J2SE 5.0中,Java引入了`java.util.Scanner`类,方便...

    TongWeb5.0用户使用手册.pdf

    TongWeb5.0是一款由东方通科技开发的企业级应用服务器,它支持Java EE 5规范,并提供了丰富的特性和工具来帮助开发者构建、部署和管理应用程序。 #### Java EE 5的新特性 Java EE 5在前一代的基础上引入了许多新...

    JAVA5.0API_CN

    这个文档详尽地介绍了Java 5.0版本中的各种类库、接口、方法以及异常,帮助开发者理解和使用Java语言的新特性和功能。以下将对其中的关键知识点进行详细的阐述。 1. **泛型(Generics)** Java 5.0引入了泛型,...

    Java JDK1.5 生产消费者模式解决方案

    在Java编程语言中,生产者消费者模式是一种经典的多线程设计模式,用于处理并发问题。在JDK 1.5及以后的版本中...在JDK 5.0提供的生产者消费者模式示例中,我们可以深入理解这些新特性的应用,提高我们的并发编程能力。

    ajax调用servlet_test_可以运行的例子,是一个完整的工程

    总之,这个示例工程提供了一个实用的学习平台,帮助开发者掌握如何在JDK5.0环境中使用Ajax与Servlet进行交互,这对于开发现代Web应用来说是非常重要的技能。通过研究并运行这个工程,你可以更直观地了解Ajax异步通信...

Global site tag (gtag.js) - Google Analytics