Java 5.0 新特性

package com.fish.jdk15;
import java.util.ArrayList;
import java.util.Collections;
/*
 jdk1.5新特性之-------静态导入
 
 静态导入的作用: 简化书写。
 
静态导入可以作用一个类的所有静态成员(静态方法和静态成员变量)。 
 
 静态导入的格式:
 import static 包名.类名.静态的成员;
 
 
静态导入要注意的事项: 
 1. 如果静态导入的成员与本类的成员存在同名的情况下,那么默认使用本类的静态成员,如果需要指定使用静态导入的成员,那么需要在静态成员前面加上类名
 
 
 */
import static java.util.Collections.sort;
import static java.util.Collections.binarySearch;
import static java.util.Collections.max;
import static java.util.Collections.*;
import static java.lang.System.out;
public class Demo1 {
    public static void main(String[] args) {
        ArrayList<Integer> list = new ArrayList<Integer>();
        list.add(13);
        list.add(9);
        list.add(10);
        list.add(19);
        //排序
        sort(list);
        Collections.sort(list);
        out.println("集合的元素:"+ list);
        out.println("索引值:"+ binarySearch(list,13));
        out.println("最大值:"+ max(list));
    }
    public static void sort(ArrayList<Integer> list){
        System.out.println("本类 的sort方法.....");
    }
}
package com.fish.jdk15;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
/*
jdk1.5出现的新特性---->增强for循环
增强for循环的作用: 简化迭代器的书写格式。(注意:增强for循环的底层还是使用了迭代器遍历。)
增强for循环的适用范围: 如果是实现了Iterable接口的对象或者是数组对象都可以使用增强for循环。
增强for循环的格式:
 
 for(数据类型  变量名  :遍历的目标){
 
 }
增强for循环要注意的事项:
1. 增强for循环底层也是使用了迭代器获取的,只不过获取迭代器由jvm完成,不需要我们获取迭代器而已,所以在使用增强for循环变量元素的过程中不准使用集合
对象对集合的元素个数进行修改。
2. 迭代器遍历元素与增强for循环变量元素的区别:使用迭代器遍历集合的元素时可以删除集合的元素,而增强for循环变量集合的元素时,不能调用迭代器方的法
3. 普通for循环与增强for循环的区别:普通for循环可以没有变量的目标,而增强for循环一定要有变量的目标。
4、增强for循环不能控制循环的次数
 
 */
 
public class Demo2 {
    public static void main(String[] args) {
        HashSet<String> set = new HashSet<String>();
        
        //添加元素
        set.add("狗娃");
        set.add("狗剩");
        set.add("铁蛋");
        /*
        
        //使用迭代器遍历Set的集合.
        Iterator<String> it  = set.iterator();
        
        while(it.hasNext()){
            String temp = it.next();
            System.out.println("元素:"+ temp);
            it.remove();
        }
        
        //使用增强for循环解决
        for(String item : set){
            System.out.println("元素:"+ item);
            set.remove("狗剩"); //不能对集合的元素进行修改
        }
        
        int[] arr = {12,5,6,1};
         
         //普通for循环的遍历方式
        for(int i =  0 ; i<arr.length ; i++){
            System.out.println("元素:"+ arr[i]);
        }
        
        //使用增强for循环实现
        for(int item :arr){
            System.out.println("元素:"+ item);
        }
        
        //需求: 在控制台打印5句hello world.
        for(int i = 0 ; i < 5; i++){
            System.out.println("hello world");
        }
        
        */
        
        //注意: Map集合没有实现Iterable接口,所以map集合不能直接使用增强for循环,如果需要使用增强for循环需要借助于Collection
        // 的集合。
        HashMap<String, String> map = new HashMap<String, String>();
        map.put("001","张三");
        map.put("002","李四");
        map.put("003","王五");
        map.put("004","赵六");
        Set<Map.Entry<String, String>> entrys = map.entrySet();
        
        for(Map.Entry<String, String> entry  :entrys){
            System.out.println("键:"+ entry.getKey()+" 值:"+ entry.getValue());
        }
    }
}
package com.fish.jdk15;
import java.util.Iterator;
//自定一个类使用增强for循环
class MyList implements Iterable<String>{
    Object[] arr = new Object[10];
    int index = 0 ;//当前的指针
   
    public void add(Object o){
        arr[index++] = o;  // 1
    }
   
    public int size(){
        return index;
    }
    
    @Override
    public Iterator<String> iterator() {
        return new Iterator<String>() {
            int cursor  = 0;
            @Override
            public boolean hasNext() {
                return cursor<index;
            }
            @Override
            public String next() {
                return (String) arr[cursor++];
            }
            @Override
             public void remove() {
            }
        };
    }
}

public class Demo3 {
    public static void main(String[] args) {
        MyList list = new MyList();
        list.add("张三");
        list.add("李四");
        list.add("王五");
        for(String item :list){
            System.out.println(item);
        }
    }
}
package com.fish.jdk15;
/*
jdk1.5新特性之------->可变参数
需求: 定义一个函数做加法功能(函数做几个数据 的加法功能是不确定)。
可变参数的格式:
数据类型... 变量名(只能是三个点)
可变参数要 注意的细节: 
1. 如果一个函数 的形参使用上了可变参数之后,那么调用该方法的时候可以传递参数也可以不传递参数。
2. 可变参数实际上是一个数组对象。
3. 可变参数必须位于形参中的最后一个参数。
4. 一个函数最多只能有一个可变 参数,因为可变参数要位于形参中最后一个位置上。
 
 */
public class Demo4 {
  public static void main(String[] args) {
            int[] arr = {1,2,45,6,7};
            /*System.out.println(arr);
            add(arr);*/
            add();
   }
        
   public static void add(int... arr){ //长度是0
        System.out.println(arr);
        System.out.println("arr是一维数组吗?"+(arr instanceof int[]));
        System.out.println("长度"+arr.length);
        int result = 0;
        
        for(int item : arr){
            result+=item;
        }
        System.out.println("总和:"+ result);
   }
   
   public static void add1(int[] arr){ //长度是0
        int result = 0;
        for(int item : arr){
            result+=item;
        }
        System.out.println("总和:"+ result);
    }
}
package com.fish.jdk15;
import java.util.ArrayList;
/*
 jdk1.5新特性之-----自动装箱与自动拆箱。
 
 java是面向对象 的语言,任何事物都可以使用类进行描述,sun就使用了
 一些类描述java中八种基本数据类型数据
 
 基本数据类型            包装类型
 byte       Byte
short        Short
int           Integer
long          Long 
float          Float
double         Double 
boolean        Boolean 
char          Character
基本数据类型数据有了对应 的包装 类型的好处:
1、能使用方法,变得更加的强大
 */
 
 
 
public class Demo5 {
    public static void main(String[] args) {
        String str = "12";
        //字符串转换成int类型数据。 可以把字符串转换成对应的数字
        int i = Integer.parseInt(str);
        System.out.println(i+1);
        
        //把数字转换成字符串
        System.out.println("把整数转换成对应 的字符串:"+Integer.toString(i));
        
        //把整数转换成对应的进制形式
        System.out.println("10的二进制:"+ Integer.toBinaryString(10));
        System.out.println("10的二进制:"+ Integer.toBinaryString(10));
        System.out.println("10的十六进制:"+ Integer.toHexString(10));
        
        //可以把字符串当成对应的进行数据帮你转换
        String data = "10";
        int a = Integer.parseInt(data, 2);
        System.out.println("a="+a);
        
        //集合: 集合是可以存储任意对象类型数据的容器。
        ArrayList list = new ArrayList();
        list.add(1);
        list.add(2);
        list.add(3);
        
        //自动装箱: 自动把java的基本数据类型数据转换成对象类型数据。
        int temp = 10;  //基本数据类型
        Integer b =temp; //把a存储的值赋予给b变量,自动装箱
        Integer b1 =new Integer(temp); //手动装箱
        
        //自动拆箱: 把引用类型的数据转换成基本类型的数据
        Integer c = new Integer(13);
        int d = c; //自动拆箱
        int d1=c.intValue(); //手动拆箱
        System.out.println(d);
        
        //引用的数据类型
        Integer e = 128;
        Integer f = 128; 
        
        //==用来比较内存地址
        System.out.println("同一个对象吗?"+(e==f)); // Integer类内部维护了缓冲数组,该缓冲数组存储的-128~127 这些数据在一个数组中。如果你获取的数据是落入到这个范围之内的,那么就直接从该缓冲区中获取对应的数据。
    }
}
package com.fish.jdk15;
/*
 jdk1.5新特性之-----枚举
 
 问题:某些方法所接收的数据必须是在固定范围之内的, 
 
解决方案: 这时候我们的解决方案就是自定义一个类,然后是私有化构造函数,在自定义类中创建本类的对象对外使用。
jdk1.5对以上问题提出了新的解决方案: 就是使用枚举类解决。
一些方法在运行时,它需要的数据不能是任意的,而必须是一定范围内的值,Java5以后可以直接使用枚举予以解决。
 比如: 方向 , 性别 、 季节 、 星期......
 
 
 */
/*//自定义一个性别类
class Gender{
String value; //持有变量,但是这个变量只能自己来复制,那构造方法就不能公开给别人
public static final Gender man = new Gender("男");
public static final Gender woman = new Gender("女");
private Gender(String value) { //不能new
this.value = value;
}
}*/
enum Gender{
    //man,woman  //重写了toString方法,Gender.man 返回的是man
    
    man("男"),woman("女"); //重写了toString方法,Gender.man 返回的是man
    private String value;
    
    private Gender(String value){
        this.value = value;
    }
   
    public String getValue(){
        return value;
    }
    
 }
 
class Person{
    private String name;
    private Gender sex;
    
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public Gender getSex() {
        return sex;
    }
    public void setSex(Gender sex) {
        this.sex = sex;
    }
}

public class Demo6 {
    public static void main(String[] args) {
        Person p = new Person();
        p.setName("狗娃");
        p.setSex(Gender.woman);
       
        System.out.println("名字:"+ p.getName()+" 性别:"+ p.getSex()); //调用Gender 枚举    --> 名字:狗娃 性别:woman
        //System.out.println("名字:"+ p.getName()+" 性别:"+ p.getSex().value); //调用Gender类  --> 名字:狗娃 性别:女
        System.out.println("名字:"+ p.getName()+" 性别:"+ p.getSex().getValue()); //调用Gender 枚举   --> 名字:狗娃 性别:女
        System.out.println(Sex.man); //sex.man 类重写了toString方法
    }
}
package com.fish.jdk15;
/*
枚举:一些方法在运行时,它需要的数据不能是任意的,而必须是一定范围内的值,可以直接使用枚举予以解决。
枚举类的定义格式:
enum 类名{
//枚举值
}
枚举要注意的细节:
1. 枚举类也是一个特殊的类。
2. 枚举值默认的修饰符是public static final。 javap -c -l -private Sex 可以查看源代码
3. 枚举值就是是枚举值所属的类的类型, 然后枚举值是指向了本类的对象的。
4. 枚举类的构造方法默认的修饰符是private的。
5. 枚举类可以定义自己的成员变量与成员函数。
6. 枚举类可以自定义构造函数,但是构造函数的修饰符必须是private。
7. 枚举类可以存在抽象 的方法,但是枚举值必须要实现抽象 的方法。
8. 枚举值必须要位置枚举类 的第一个语句。
 */
//自定义一个枚举类
enum Sex{
    //dog,pig;
    
    //public static final Sex dog= new Sex();
    
    man("男"){
        @Override
        public void run() {
            System.out.println("男人在跑...");
        }
    },woman("女"){
        @Override
        public void run() {
            System.out.println("女人在跑...");
        }
    }; //枚举值
    
    String value; //成员 变量
    
    //public static final Sex man = new Sex();
    
    
    //构造函数
    private Sex(String  value){
        this.value = value;
    }
    
    
    //成员函数
    public void getValue(){
        System.out.println("value :"+ value);
    }
   
    public abstract void run(); //可以定义抽象函数
}

public class Demo7 {
    public static void main(String[] args) {
        Sex sex = Sex.man; //获取到了枚举类的对象
        sex.value = "男";
        sex.getValue();
        sex.run();
    }
}
package com.fish.jdk15;
/*
 switch适用的数据类型: byte \ char \short \ int \ String\枚举类型
 
 注意: 
 case语句后面跟的枚举值,只需要单写枚举值即可,不需要再声明该 枚举值是属于哪个枚举类的。
 
 
 
 */
//季节枚举类

enum Season{
    spring,summer,autumn,winter;
}

enum Person2{
    student,worker;
}

public class Demo8 {
    public static void main(String[] args) {
        Season season = Season.summer;
        switch(season){
            case spring:
                System.out.println("春天...");
                break;
            case summer:
                System.out.println("夏天...");
                break;
            case autumn:
                System.out.println("秋天...");
                break;
            case winter:
                System.out.println("冬天...");
                break;
        }
    }
}
时间: 2024-11-08 19:23:57

Java 5.0 新特性的相关文章

Java JDK5.0新特性

JDK5.0新特性 虽然JDK已经到了1.8 但是1.5(5.0)的变化是最大的 1. 增强for循环 foreach语句 foreach简化了迭代器 作用: 对存储对象的容器进行迭代 (数组, collection, map) 1> 格式 增强for循环括号里写两个参数 第一个是声明一个变量 第二个就是需要迭代的容器 for( 元素类型 变量名 : Collection集合 & 数组 ) { ... } 2> 增强for循环和传统for循环的区别 a. 增强for循环在使用时 必须要

Atitit..jdk&#160;java&#160;各版本新特性&#160;1.0&#160;1.1&#160;1.2&#160;1.3&#160;1.4&#160;1.5(5.0)&#160;1.6(6.0)&#160;7.0&#160;8.0&#160;9.0&#160;attilax&#160;大总结

Atitit..jdk java 各版本新特性 1.0 1.1 1.2 1.3 1.4 1.5(5.0) 1.6(6.0) 7.0 8.0 9.0 attilax 大总结 1.1. Java的编年史2 1.2. Java版本:JDK 1.02 1.3. Java版本:JDK 1.13 1.4. Java版本:JDK 1.2 (Java 2)4 1.4.1. 1999年5 1.4.2. 2000年5 1.5. Java版本:JDK 1.35 1.5.1. 2001年6 1.5.2. 2002年7

Java基础加强-(注解,类加载器,servlet3.0新特性)

1.   Annotation注解 1.1.  Annotation概述 Annotation是JDK 5.0以后提供对元数据的支持,可以在编译.加载和运行时被读取,并执行相应的处理.所谓Annotation就是提供了一种为程序元素设置元数据的方法,可用于修饰包.类.构造器.方法.成员变量.参数和局部变量的声明,这些信息被存储在Annotation的“name=value”对中. Annotation能被用来为程序元素(类.方法.成员变量等)设置元数据,比如一段代码的作者或者告诉编译器禁止一些特

java Servlet 3.0新特性例子

迟到的作业,Servlet3.0 已经出来很久了也没去关注,一直守旧于老的技术,今天抽时间学习了一下补个作业. Servlet3.0  特性: 1.Servlet.Filter.Listener无需在web.xml中进行配置,可以通过Annotation进行配置: 2.模块化编程,即将各个Servlet模块化,将配置文件也分开配置. 3.Servlet异步处理,应对复杂业务处理: 4.异步Listener,对于异步处理的创建.完成等进行监听: 5. 文件上传API简化: 备注:tomcat7.0

Day07 jdk5.0新特性&Junit&反射

day07总结 今日内容 MyEclipse安装与使用 JUnit使用 泛型 1.5新特性 自动装箱拆箱 增强for 静态导入 可变参数方法 枚举 反射 MyEclipse安装与使用(yes) 安装MyEclipse 先安装了JDK ? MyEclipse介绍 ? MyEclipse是Eclipse的一个插件: MyEclipse是需要花钱的: MyEclipse官网不在欢迎中国人登录: ? MyEclipse使用 ? 1 创建项目 选择工作空间: 工作空间路径不能有空格和中文: 工作空间以班名

Atitit.&#160;C#.net&#160;clr&#160;2.0&#160;&#160;4.0新特性

Atitit. C#.net clr 2.0  4.0新特性 1. CLR内部结构1 2. CLR 版本发展史3 3. CLR 2.0 3 4. CLR 4 新特性 概览4 4.1.1.  托管与本地代码的互操作5 4.1.2.    垃圾回收6 4.1.3.    代码约定6 4.1.4.    Corrupted state exception6 4.1.5.     新的安全模型7 4.1.6.     同一个进程,多个CLR7 4.1.7.     基本类库7 5. CLR最新发展8 6

day07 MyEclipse 安装 jdk5.0 新特性

1.myeclipse的安装和使用 * eclipse:是一个免费的开发工具    * myeclipse:是一个收费的插件,破解myeclipse,        ** 安装目录的要求: 不能有中文和空格        ** 安装完成之后,选择一个工作空间 ,这个工作空间不能有中文和空格    * 破解myeclipse        ** 运行run.bat文件,但是运行之前,必须要安装jdk,通过配置环境变量 * myeclipse的使用        * 创建一个工程          

Servlet 3.0 新特性详解

转自:https://www.ibm.com/developerworks/cn/java/j-lo-servlet30/ Servlet 3.0 新特性详解 张 建平2010 年 4 月 23 日发布 WeiboGoogle+用电子邮件发送本页面 6 Servlet 3.0 新特性概述 Servlet 3.0 作为 Java EE 6 规范体系中一员,随着 Java EE 6 规范一起发布.该版本在前一版本(Servlet 2.5)的基础上提供了若干新特性用于简化 Web 应用的开发和部署.其

Spark1.0.0新特性

Spark1.0.0 release于2014-05-30日正式公布,标志Spark正式进入1.X的时代.Spark1.0.0带来了各种新的特性,并提供了更好的API支持:Spark1.0.0添加了Spark SQL这一个新的重要组件,用于载入和操作Spark的结构化数据:Spark1.0.0增强了现有的标准库(ML,streaming,GraphX),同一时候还增强了Java和Python语言的支持:最后,Spark1.0.0在运维上做了非常大的改进,包含支持Hadoop/YARN安全机制.使