java--JDK1.5新特性

原创 2015年07月09日 14:07:04

一、静态导入

1、写法:

        import staticjava.util.Arrays.*;//导入的是Arrays这个类中的所以静态成员。

        import staticjava.lang.System.*//导入了Ssytem类中所以静态成员。

        没加static导入的是类,加上static导入的全是某一个类中所以的静态成员。这样写在调用该类的静态方法时可以不用再写类名。如:Arrays.sort(数组);就可以直接写sort(数组);

2、注意:

         当导入的两个类中有同名成员时,需要在成员前加上相应的类名。

        当类名重名时,需要指定具体的包名。当方法重名时,指定具体所属的对象或者类。

示例:

  1. import java.util.*;    
  2. import static java.util.Arrays.*;    
  3. import static java.lang.System.*;    
  4.     
  5. class  StaticImport //extends Object     
  6. {    
  7.     public static void main(String[] args)     
  8.     {    
  9.         out.println("haha");//打印输出时就可以直接省略书写System.     
  10.         int[] arr = {3,1,5};    
  11.     
  12.         sort(arr);//使用Arrays工具类的方法sort时就可以省略书写Array.     
  13.     
  14.         int index = binarySearch(arr,1);//半分查找也是一样可以省略     
  15.         out.println("Index="+index);    
  16.     
  17.         //当没有指定继承时,所以类默认继承了Object,     
  18.        //因为toString方法都具备,所以为了区分,必须写上具体调用者     
  19.        out.println(Arrays.toString(arr));    
  20.     }    
  21. }    
import java.util.*; import static java.util.Arrays.*; import static java.lang.System.*; class StaticImport //extends Object { public static void main(String[] args) { out.println("haha");//打印输出时就可以直接省略书写System. int[] arr = {3,1,5}; sort(arr);//使用Arrays工具类的方法sort时就可以省略书写Array. int index = binarySearch(arr,1);//半分查找也是一样可以省略 out.println("Index="+index); //当没有指定继承时,所以类默认继承了Object, //因为toString方法都具备,所以为了区分,必须写上具体调用者 out.println(Arrays.toString(arr)); } } 
  1. 二、增强for循环  
  2. 1、格式:  
  3.         for(数据类型变量名 :被遍历的集合(collection)或者数组) {执行语句}  
  4. 2、说明  
  5.         a、对集合进行遍历。只能获取集合元素。但是不能对集合进行操作。可以看作是迭代器的简写形式。  
  6.         b、迭代器除了遍历,还可以进行remove集合中元素的动作。如果使用ListIterator,还可以在遍历过程中对集合进行增删改查的操作。  
  7. 3、传统for和高级for的区别:  
  8.        高级for有一个局限性。必须有被遍历的目标(集合或数组)。  
  9.        传统for遍历数组时有索引。  
  10. 建议在遍历数组的时候,还是希望使用传统for。因为传统for可以定义角标。  
  11. 注意:变量类型前可加修饰符,如final(可被局部内部类访问到)。  
  12. 示例:   
二、增强for循环1、格式: for(数据类型变量名 :被遍历的集合(collection)或者数组) {执行语句}2、说明 a、对集合进行遍历。只能获取集合元素。但是不能对集合进行操作。可以看作是迭代器的简写形式。 b、迭代器除了遍历,还可以进行remove集合中元素的动作。如果使用ListIterator,还可以在遍历过程中对集合进行增删改查的操作。3、传统for和高级for的区别: 高级for有一个局限性。必须有被遍历的目标(集合或数组)。 传统for遍历数组时有索引。建议在遍历数组的时候,还是希望使用传统for。因为传统for可以定义角标。注意:变量类型前可加修饰符,如final(可被局部内部类访问到)。示例: 
  1. import java.util.*;    
  2. class For    
  3. {    
  4.     public static void main(String[] args)     
  5.     {    
  6.         //定义一个ArrayList集合     
  7.         ArrayList<String> al = new ArrayList<String>();    
  8.         al.add("abc1");    
  9.         al.add("abc2");    
  10.         al.add("abc3");    
  11.     
  12.         for(String s : al)    
  13.         {    
  14.             System.out.println(s);//用高级for遍历集合     
  15.         }    
  16.     
  17.         //传统for与高级for遍历数组     
  18.         int[] arr = {3,5,1};    
  19.     
  20.         for(int x=0; x<arr.length; x++)    
  21.         {    
  22.             System.out.println(arr[x]);    
  23.         }    
  24.         for(int i : arr)    
  25.         {    
  26.             System.out.println("i:"+i);    
  27.         }    
  28.     
  29.         //定义一个HashMap集合     
  30.         HashMap<Integer,String> hm = new HashMap<Integer,String>();    
  31.     
  32.         hm.put(1,"a");    
  33.         hm.put(2,"b");    
  34.         hm.put(3,"c");    
  35.     
  36.         //keySet取出方式的高级for遍历     
  37.         Set<Integer> keySet = hm.keySet();    
  38.         for(Integer i : keySet)    
  39.         {    
  40.             System.out.println(i+"::"+hm.get(i));    
  41.         }    
  42.     
  43.         //entrySet取出方式的高级for遍历     
  44.         for(Map.Entry<Integer,String> me : hm.entrySet())    
  45.         {    
  46.             System.out.println(me.getKey()+"------"+me.getValue());    
  47.         }    
  48.     
  49.     }    
  50. }    
import java.util.*; class For { public static void main(String[] args) { //定义一个ArrayList集合 ArrayList<String> al = new ArrayList<String>(); al.add("abc1"); al.add("abc2"); al.add("abc3"); for(String s : al) { System.out.println(s);//用高级for遍历集合 } //传统for与高级for遍历数组 int[] arr = {3,5,1}; for(int x=0; x<arr.length; x++) { System.out.println(arr[x]); } for(int i : arr) { System.out.println("i:"+i); } //定义一个HashMap集合 HashMap<Integer,String> hm = new HashMap<Integer,String>(); hm.put(1,"a"); hm.put(2,"b"); hm.put(3,"c"); //keySet取出方式的高级for遍历 Set<Integer> keySet = hm.keySet(); for(Integer i : keySet) { System.out.println(i+"::"+hm.get(i)); } //entrySet取出方式的高级for遍历 for(Map.Entry<Integer,String> me : hm.entrySet()) { System.out.println(me.getKey()+"------"+me.getValue()); } } } 

三、可变参数:(方法的重载)VariableParameter

        如果一个方法在参数列表中传入多个参数,个数不确定,那么每次都要复写该方法。这时可以用数组作为形式参数。但是在传入时,每次都需要定义一个数组对象,作为实际参数。在JDK1.5版本后,就提供了一个新特性:可变参数。

        用…这三个点表示,且这三个点位于变量类型和变量名之间,前后有无空格皆可。

        可变参数其实就是数组参数的简写形式。不用每一次都手动的建立数组对象。只要将要操作的元素作为参数传递即可。隐式将这些参数封装成了数组。

        在使用时注意:可变参数一定要定义在参数列表的最后面。

示例:

  1. class  ParamMethodDemo    
  2. {    
  3.     public static void main(String[] args)     
  4.     {    
  5.         show("haha",2,3,4,5,6);    
  6.     }    
  7.     public static void show(String str,int... arr)//...就表示可变参数     
  8.     {    
  9.         System.out.println(arr.length);    
  10.     }    
  11. }    
class ParamMethodDemo { public static void main(String[] args) { show("haha",2,3,4,5,6); } public static void show(String str,int... arr)//...就表示可变参数 { System.out.println(arr.length); } } 

四、基本数据类型的自动拆箱与装箱

1、自动装箱:Integer iObj = 3;

2、自动拆箱:iObj + 2;

3、对于基本数据类型的说明:整数在-128 ~ 127之间的数,包装成Integer类型对象,会存入常量池中的缓存,再创建一个对象的时候,如果其值在这个范围内,就会直接到常量池中寻找,因为这些小数值使用的频率很高,所以缓存到常量池中,被调用时就方便很多。

4、享元模式(flyweight):

        1)概述:有很多个小的对象,他们有很多相同的属性,把属性相同的部分变为同一个对象,这些属性称为内部状态。那些不同的属性,把他们变成方法的参数,称之为外部的状态。这种优化内存,只创建一个对象的模式,称之为享元模式。例如:Integer对象中对象取值范围在-128~127时,其值相同的对象想等,因为这些小的数被缓存在一个池中,被调用的频率较高,所以通常在池中取,从而导致对象相同。这就是典型的享元设计模式。

        2)应用:

          (1word中输入英文字母,可创建26对象,每个对象值是出现的位置不同(坐标),所以可用一个对象调用位置的方法:如,字母ii.display(intx,inty),将高度重复使用的char类型的字母i封装成一个对象使用。

          (2)图标:window下的文件夹图标,只有名称这个属性不同,包含了很多其他相同的属性,那么可以应用享元模式。

        3valueOf(int x)Integer中静态方法,将一个整数转换为Integer,即把基本数据类型变为包装类。

java--加强之 jdk1.5简单新特性,枚举,注解

Jdk1.51新特性(静态导入,可变参数,加强for循环,自动拆装箱) 08.java5的静态导入与编译器语法设置 Jdk1.5后的新语法,如果用新语法了,eclipse中配置的javac及java必...

Java生涯——高新技术---枚举及部分JDK1.5新特性

第一讲     枚举 一、概述         这里说的枚举,不是集合vector的特有枚举迭代器,而是JDK1.5的一个新特性。之所以单独拿它开刷,是这个知识点比较重要,同时相对来说比较...

JAVA——生产者与消费者以及JDK1.5以后新特性

生产者和消费者问题是很常见的一类多线程问题。问题大致描述为: 有一个生产者在生产产品,这些产品将提供给若干个消费者去消费,为了使生产者和消费者能并发执行,在两者之间设置一个具有多个缓冲区的缓冲池,生...

黑马程序员________Java集合Map及其JDK1.5新特性泛型机制的学习笔记

------- android培训、java培训、期待与您交流! ----------         Map接口的子类特点是将对象成键值对的方式,成对存入集合,并且要保证键的唯一性...

(14)多线程与并发库之java5同步集合类的应用【包含jdk1.5新特性 ConcurrentHashMap】

第一部分: 常用的集合类ArrayList、Map等在多线程操作同一对象时会发生不同步的线程而造成数据读取和写入错误;通常都是采用synchronized修饰符或Lock将那些方法括起来来确保它们在...

JAVA学习第二十七课(多线程(六))- 多生产者多消费者问题(JDK1.5新特性)

多生产者多消费者问题 以生产馒头 消费馒头为例。 class Resource { private String name; private int count = 1; private ...

黑马程序员——java--JDK1.5新特性

------Java培训、Android培训、iOS培训、.Net培训、期待与您交流! ------- 静态导入(1.5特性,好处是不用写类名) import语句可以导入一个类或某个包中的所有类 im...

黑马程序员_java高级篇JDK1.5的新特性系列Day9

黑马程序员_java高级篇JDK1.5的新特性系列Day9   2013年12月9号,看张老师视频记录Jdk1.5的一些新特性与细节问题。同时提醒自己学习要一步一个脚印。   #杂七杂八的java细节...

黑马程序员—JAVA高新技术之JDK1.5的新特性

JDK1.5的新特性 一、自动装箱和拆箱 1、自动装箱和拆箱是由编译器帮助完成从基本数据类型和基本数据类型的包装类之间的转换。       ①基本数据类型:int,long,double,flo...
  • yxqcz
  • yxqcz
  • 2014年06月13日 22:06
  • 223

java加强之jdk1.5新特性

jdk1.5新特性: 1、静态导入 package jdk_5new; /**  * 静态导入是jdk1.5新特性,可以直接导入类中的静态方法  */ import static java...
  • nnmmbb
  • nnmmbb
  • 2012年07月18日 01:23
  • 398
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:java--JDK1.5新特性
举报原因:
原因补充:

(最多只允许输入30个字)