- 浏览: 484046 次
- 性别:
- 来自: 武汉
最新评论
-
zyzyzy123:
请问有工程吗,我现在正在实现打电话的功能,但是一直不通,怀疑是 ...
实用的java 串口通信程序 -
wuhaitong:
引用[img][/img][*][url][/url] ...
jbpm -
迷糊_le:
maven命令, 蛮好的,谢谢
maven eclipse -
Wuaner:
不错的文章 , 谢谢分享!
Hadoop -
yuqihengsheng:
strong 很细
HighLighter
1、泛型(Generic)
可以在编译的时候检测出类型错误,编译后和没有使用泛型的效果是相同的,但是使用泛型可以让你在编译时就发现错误,例如:
- import java.util.ArrayList;
- import java.util.Collection;
- import java.util.Iterator;
- public class GenericTest {
- public static void main(String[] args) {
- Collection c = new ArrayList();
- c.add(new Integer(1));
- c.add("123");
- for(Iterator i=c.iterator();i.hasNext();){
- String s = (String) i.next();
- System.out.println(s);
- }
- }
- }
- 运行结果:
- Exception in thread "main" java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String
- at GenericTest.main(GenericTest.java:12)
import java.util.ArrayList; import java.util.Collection; import java.util.Iterator; public class GenericTest { public static void main(String[] args) { Collection c = new ArrayList(); c.add(new Integer(1)); c.add("123"); for(Iterator i=c.iterator();i.hasNext();){ String s = (String) i.next(); System.out.println(s); } } } 运行结果: Exception in thread "main" java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String at GenericTest.main(GenericTest.java:12)
Collection应该只存放String对象,但是我们“不小心”添加了一个Integer类型的对象,编译正常进行,程序在运行时才发现错误。
下面是使用了泛型后的程序
- import java.util.ArrayList;
- import java.util.Collection;
- import java.util.Iterator;
- public class GenericTest {
- public static void main(String[] args) {
- Collection<String> c = new ArrayList<String>();
- c.add(new Integer(1));
- c.add("123");
- for(Iterator<String> i=c.iterator();i.hasNext();){
- String s = i.next();
- System.out.println(s);
- }
- }
- }
- 运行结果
- D:\test>javac GenericTest.java
- GenericTest.java:8: 无法将 java.util.Collection<java.lang.String> 中的 add(java.lang.String) 应用于 (java.lang.Integer)
- c.add(new Integer(1));
- ^
- 1 错误
- D:\test>
import java.util.ArrayList; import java.util.Collection; import java.util.Iterator; public class GenericTest { public static void main(String[] args) { Collection<String> c = new ArrayList<String>(); c.add(new Integer(1)); c.add("123"); for(Iterator<String> i=c.iterator();i.hasNext();){ String s = i.next(); System.out.println(s); } } } 运行结果 D:\test>javac GenericTest.java GenericTest.java:8: 无法将 java.util.Collection<java.lang.String> 中的 add(java.lang.String) 应用于 (java.lang.Integer) c.add(new Integer(1)); ^ 1 错误 D:\test>
使用了泛型之后在编译时就发现了错误,可以增强程序的健壮性,而其i.next();也不用使用强制类型转换了。
2、增强for循环(For-Each)
For-Each的内部是用Iterator实现的,但是使用起来更简单,例如使用For-Each实现1-2如下
- import java.util.ArrayList;
- import java.util.Collection;
- public class GenericTest {
- public static void main(String[] args) {
- Collection<String> c = new ArrayList<String>();
- c.add("aa");
- c.add("bb");
- for(String s:c){
- System.out.println(s);
- }
- }
- }
- 运行结果:
- aa
- bb
import java.util.ArrayList; import java.util.Collection; public class GenericTest { public static void main(String[] args) { Collection<String> c = new ArrayList<String>(); c.add("aa"); c.add("bb"); for(String s:c){ System.out.println(s); } } } 运行结果: aa bb
比Integer方便多了吧?可以使程序员更加注重逻辑,而不是代码本身。
3、自动装箱拆箱(Autoboxing/unboxing)
- Integer i = new Integer(2);
- //i自动拆箱为int类型
- System.out.println(i==2);
- //3自动装箱为Integer类型
- System.out.println(i.equals(3));
Integer i = new Integer(2); //i自动拆箱为int类型 System.out.println(i==2); //3自动装箱为Integer类型 System.out.println(i.equals(3));
4、静态导入(static import)
- //静态导入Math的random方法
- import static java.lang.Math.random;
- public class StaticImportTest {
- public static void main(String[] args){
- //类中生成随机数数可以直接使用静态引入的random方法了,而不用Math.random()这样调用了
- System.out.println(random());
- }
- }
//静态导入Math的random方法 import static java.lang.Math.random; public class StaticImportTest { public static void main(String[] args){ //类中生成随机数数可以直接使用静态引入的random方法了,而不用Math.random()这样调用了 System.out.println(random()); } }
5、格式化打印(formatted print)
C语言中printf()风格的格式化输出。
这里只举一个thinking in java的一个例子:
- public class SimpleFormat {
- public static void main(String[] args) {
- int x = 5;
- double y = 5.332542;
- //The old way
- System.out.println("Row 1: ["+x+" "+y+"]");
- //The new way
- System.out.format("Row 1: [%d %f]\n", x,y);
- //or
- System.out.printf("Row 1: [%d %f]\n", x, y);
- }
- }
- 运行结果:
- Row 1: [5 5.332542]
- Row 1: [5 5.332542]
- Row 1: [5 5.332542]
public class SimpleFormat { public static void main(String[] args) { int x = 5; double y = 5.332542; //The old way System.out.println("Row 1: ["+x+" "+y+"]"); //The new way System.out.format("Row 1: [%d %f]\n", x,y); //or System.out.printf("Row 1: [%d %f]\n", x, y); } } 运行结果: Row 1: [5 5.332542] Row 1: [5 5.332542] Row 1: [5 5.332542]
可以看到,format和printf是等价的,他们只需要一个简单的格式化字符串,加上一串参数即可,每个参数对应一个格式修饰符
6、枚举(Enum)
当每一类型可取值范围是有限的时候,可以使用枚举,例如每个学生登记只能用ABCD表示,如果直接用E的话,那么编译不会出错,但是却不符合输入要求,而使用枚举增加程序的易读性和健壮性?
- public class GradeTest {
- public static void main(String[] args) {
- Student stu = new Student();
- stu.setName("wasw100");
- stu.setGrade(Grade.A);
- //输出学生信息
- System.out.println(stu);
- }
- }
- /**
- * 枚举:Grader 学生考试等级
- * @author wasw100
- */
- enum Grade{
- A,B,C,D
- }
- class Student {
- private String name;
- private Grade grade;
- //重写toString()方法
- public String toString(){
- return "name:+"+name+"\ngrader:"+grade;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public Grade getGrade() {
- return grade;
- }
- public void setGrade(Grade grade) {
- this.grade = grade;
- }
- }
public class GradeTest { public static void main(String[] args) { Student stu = new Student(); stu.setName("wasw100"); stu.setGrade(Grade.A); //输出学生信息 System.out.println(stu); } } /** * 枚举:Grader 学生考试等级 * @author wasw100 */ enum Grade{ A,B,C,D } class Student { private String name; private Grade grade; //重写toString()方法 public String toString(){ return "name:+"+name+"\ngrader:"+grade; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Grade getGrade() { return grade; } public void setGrade(Grade grade) { this.grade = grade; } }
7、可变长参数(varargs)
方法的参数是不固定的我们一般会使用重载或者使用数组参数。重载需要些更多写更多的方法,数组需要在使用时先声明。
可能参数是一个不错的解决方案。
下面是网上一个 唐僧 给 悟空 将佛经的例子
- public class VarargsTest {
- public void speak(String name, Object... arguments) {
- System.out.print(name+": ");
- for (Object object : arguments) {
- System.out.print(object);
- }
- System.out.println();
- }
- public static void main(String[] args) {
- VarargsTest vt = new VarargsTest();
- vt.speak("悟空", "人和妖精都是妈生的,");
- vt.speak("悟空", "不同的人是人他妈生的,", "妖是妖他妈生的,");
- }
- }
- 运行结果:
- 悟空: 人和妖精都是妈生的,
- 悟空: 不同的人是人他妈生的,妖是妖他妈生的,
public class VarargsTest { public void speak(String name, Object... arguments) { System.out.print(name+": "); for (Object object : arguments) { System.out.print(object); } System.out.println(); } public static void main(String[] args) { VarargsTest vt = new VarargsTest(); vt.speak("悟空", "人和妖精都是妈生的,"); vt.speak("悟空", "不同的人是人他妈生的,", "妖是妖他妈生的,"); } } 运行结果: 悟空: 人和妖精都是妈生的, 悟空: 不同的人是人他妈生的,妖是妖他妈生的,
可变长参数只能作为最后一个参数。
发表评论
-
安装和使用memcached
2014-04-16 16:24 641如何将 memcached 融入到 ... -
applicationContext.xml
2013-08-09 09:05 942<?xml version="1.0&quo ... -
注释驱动的 Spring cache 缓存介绍
2013-08-08 07:04 659概述 Spring 3.1 引入了激动人心的基于注释(an ... -
Spring2.5 Annotations
2013-08-08 06:33 854完成setXxxx功能,即配置文件的 <propert ... -
Spring基于注解的缓存配置--EHCache AND OSCache
2013-08-07 23:21 1026本文将构建一个普通工程来说明spring注解缓存的使用方式, ... -
Ehcache 整合Spring 使用页面、对象缓存
2013-08-07 22:51 893Ehcache 整合Spring 使用页面、对象缓存 ... -
javassist教程和示例
2013-05-18 08:57 2008Javassist是一个执行字节 ... -
ZooKeeper官方文档
2013-05-16 17:09 1559介绍(源自ZooKeeper官方文档) 学习HBase过程 ... -
ZooKeeper -例子
2013-05-16 17:08 1207ZooKeeper ZooKeepe ... -
Spring整合Hessian访问远程服务
2013-05-15 13:44 854Spring整合Hessian访问远程服务 目录 1.1 ... -
redis
2013-05-14 11:44 767redis是一个key-value存储系统。和Memcach ... -
spring 资源访问
2013-05-13 08:26 997spring在java基础上封装了资源访问,简单易用。 R ... -
ZooKeeper——入门
2013-05-08 16:12 909ZooKeeper——入门 博客分类: ZooK ... -
分布式服务框架 Zookeeper -- 管理分布式环境中的数据(IBM)
2013-05-08 14:07 784安装和配置详解 本文 ... -
分布式协调服务---Zookeeper
2013-05-08 14:05 7751、Zookeeper overview Zookee ... -
Hibernate
2013-03-28 13:04 923一、简述 Hibernate 和 JD ... -
Apache+Tomcat集群配置详解
2013-02-01 10:52 890Apache + Tomcat集群配置详解(1) 一、 ... -
Apache+Jboss集群基于反向代理的负载均衡
2013-02-01 10:40 2490假设三台机器IP分别为172.29.128.100、172. ... -
spring + ibatis 多数据源事务(分布式事务)管理配置方法
2012-12-17 15:18 1265spring + ibatis 多数据源事务(分布式事务 ... -
Hessian序列化不设SerializerFactory性能问题
2012-10-31 09:47 1492Hessian序列化不设SerializerFactor ...
相关推荐
标题:“jdk1.5 windows版本 64位” 描述:“jdk1.5 windows版本 64位,Java开发依赖环境” 标签:“windows” 在这个主题中,我们聚焦的是Oracle JDK 1.5(也被称为Java Development Kit,简称JDK)在Windows...
JDK1.5,也称为Java 5.0,是一个重要的版本,它引入了许多新的特性和改进,对Java语言的发展产生了深远影响。 一、泛型(Generics) 在Java 5.0中,最重要的特性之一就是泛型的引入。泛型允许开发者在定义类、接口...
### JDK 1.5 新特性介绍 #### 一、JDK 概述 JDK(Java Development Kit),即Java开发工具包,是用于编写Java applet和应用程序的主要平台。它包含了一个位于操作系统之上、用于执行Java applet和应用程序的运行...
### JDK1.5新特性泛型深入研究 #### 一、引言 随着软件工程的发展,类型安全成为了程序设计中的一个重要考量因素。Java作为一种广泛使用的编程语言,在其发展历程中不断引入新的特性以满足日益增长的需求。JDK1.5...
总结来说,JDK1.5是Java发展历程中的一个重要节点,它的泛型、自动装箱/拆箱、枚举、变长参数和增强for循环等特性极大地提升了开发效率和代码质量。同时,了解不同操作系统对应的JDK版本是进行Java开发的基础知识。...
JDK 1.5,也称为 Java SE 5.0,是 Java 开发工具包的一个重要版本,它引入了许多新特性,如泛型(Generics)、枚举类型(Enums)、可变参数方法(Varargs)等,这些特性极大地提高了 Java 程序的开发效率和可维护性...
3. **更好的工具支持**: JDK1.5的许多特性都得到了IDE的广泛支持,如Eclipse和IntelliJ IDEA,使得开发环境更加友好。 4. **面向服务架构(SOA)准备**: JDK1.5的发布为后来的Java EE 5和SOA提供了坚实的基础,是...
JDK 1.5的中文API文档详细列出了所有这些新特性的使用方法和示例,是Java开发者不可或缺的参考资源。通过深入学习和应用这些特性,开发者可以编写出更安全、更高效的代码,同时也能更好地理解和利用Java平台的潜力。...
总结来说,jxl.jar在JDK1.5和JDK1.6环境下都可以使用,但每个新版本的JDK都可能带来性能差异和潜在的兼容性问题。因此,进行详尽的测试和评估是确保项目稳定运行的关键。同时,开发者也需要关注和考虑更新的库和技术...
总结,JDK1.5的引入为Java开发者带来了许多便利,提高了代码质量和开发效率。在Windows环境下安装并使用JDK1.5,需要理解其主要特性,按照规范设置环境变量,并掌握基本的编译和运行流程。了解和掌握这些基础知识,...
JDK 1.5.0.06作为Java发展历程中的一个重要版本,引入了众多对后续版本有深远影响的语言特性和改进,极大地提升了Java的开发效率和代码质量。虽然现在已经有更新的JDK版本,但了解这些历史版本有助于理解Java的发展...
在Java发展史上,JDK1.5(也称为Java 5)的发布标志着一个重要的里程碑,它引入了许多新特性,其中最引人注目的当属泛型(Generics)。泛型的出现极大地提升了Java编程语言的类型安全性和代码复用性,使得开发者能够...
总结来说,JDK 1.5_22是Java发展史上的一个重要里程碑,它的特性不仅极大地提高了开发者的生产力,也为Java应用程序的稳定性和安全性奠定了基础。对于那些需要在Java 5环境中开发和维护项目的人来说,这个版本的JDK...
而JDK1.5,也被称为Java SE 5.0,发布于2004年9月,带来了更多重大的变化,例如泛型(Generics)、枚举类型(Enums)、可变参数(Varargs)等,这些特性极大地增强了Java语言的灵活性和可用性。 ### 在操作系统中...
在Java的发展历程中,JDK 1.5到1.7版本引入了许多重要的新特性,极大地提升了开发效率和代码质量。下面将详细讲解这些版本中的关键特性。 **1. 自动装箱与拆箱** 自动装箱是JDK 1.5引入的一个重要特性,它使得基本...
【JDK1.5新特性】 1. 泛型(Generic) JDK1.5引入了泛型,这是对类型安全的重要改进。泛型允许在集合类中指定元素的类型,确保了在编译时就能进行类型检查,避免了运行时的强制类型转换和可能的ClassCastException...
根据给定文件的信息,本文将详细介绍JDK 1.5中的五大新特性,这些特性显著...总结来说,JDK 1.5 的这些新特性极大地提升了 Java 语言的开发效率和代码质量,使得开发者能够编写出更清晰、更安全、更易于维护的程序。
总结,JDK 1.5作为Java历史上的一个里程碑,它的诸多新特性不仅提升了开发者的生产力,还为后来的Java版本奠定了坚实的基础。即便在JDK 1.8等新版本广泛应用的今天,了解和掌握JDK 1.5的相关知识仍然是理解和维护老...
在JDK 1.5版本中,引入了一些重要的新特性: 1. **泛型(Generics)**:泛型允许在类、接口和方法中使用类型参数,提高了代码的类型安全性和重用性。 2. **自动装箱/拆箱(Autoboxing and Unboxing)**:自动将...