zoukankan      html  css  js  c++  java
  • (14)jdk1.5开始的一些新特性:静态导入,增强for循环,可变参数,自动装箱/拆箱,枚举类型

    Jdk1.5新特性之静态导入

    jdk1.5新特性值静态导入

    静态导入的作用:简化缩写

    静态导入的作用:可以作用一个类的所有静态成员。

    静态导入的格式:import static 包名.类名.静态的成员

    import static java.util.Collections.sort; //静态导入指定的某个静态成员方法

    import static java.util.Collections.*;  导入所有的静态成员

    除了可以导入静态的成员方法,也可以静态的导入成员变量,比如System.out就是一个典型的静态成员,每次都写那么多的System是多么的麻烦,可以向下面这样静态导入:

    Import static java.lang.System.out; 以后输出的时候可以直接使用out

    注意事项:如果本类中有个方法和静态导入的方法,完全一样的时候,那么本类的方法将将会覆盖静态导入的方法,这个简记为就近原则。如果需要使用静态导入的成员,需要在静态成员前面加上类名。

    Jdk1.5新特性之增强for循环

    Iterable

    |——Collection 单例集合的跟接口

     之前说Collection是单例集合的根接口,其实上面还有一个超级接口Iterable,实现这个接口的主要目的为类拥有增强for循环的功能。

     jdk1.5新个性值增强for循环

     增强for循环的而作用:简化迭代器的书写格式。之所以这样说,事实上,增强for循环底层还是用迭代器实现的,所以,在增强for循环的过程中也是不能使用集合来修改元素的个数,慎之,慎之。

     增强for循环的适用范围:如果使用增强for循环必须要实现Iterable接口的对象或者是数组对象。

     增强for循环的格式:

      for(变量类型 变量类型 : 遍历的目标)

      {

      }

    通过实例可以很明显的看出来,增强for循环就是比迭代器用起来更简便一些

    增强for循环的注意事项:

    1、增强for循环的底层也是使用了迭代器获取的,只不过获取迭代器是有jvm来完成的,不需要我们获取迭代器而已,所以在使用增强for循环的时候,不允许改变集合的元素的个数。

    2、迭代器遍历元素与增强for循环遍历元素的区别是:使用迭代器遍历结合的元素时可以删除集合的元素,当我们使用增强for循环时是不能做增删操作的,因为增强for循环中维护的迭代器对象在jvm手中。

    3、普通的for循环和增强for循环的区别:普通for循环不需要遍历的目标,但是增强for循环一定要有遍历的目标,有时相当是一宗对空间的浪费。到底使用哪种方式(普通foriterator,增强for),视实际情况

    4、注意了,注意Map集合没有实现Iterable接口,所以不能直接使用增强for循环,如果要使用增强for循环要现借助于Collection的集合,先取出到Set

    Jdk1.5新特性之 可变参数

    可变参数格式:

    数据类型... 变量名

    可变参数需要注意的细节:

    1、如果一个函数的形参使用了可变参数之后,那么调用该方法的时候可以传递参数也可以不传递参数。

    2、可变参数实际上是一个数组对象

    3、可变参数必须位于形参中的最后一个。

    4、一个方法最多只能有一个可变参数,很明显参数列表只有一个最后位置。

    Jdk1.5新特性之 自动装箱与自动拆箱

    java是面向对象 的语言,任何事物都可以用类来解决,sun就使用了

    一些描述java中八种基本数据类型的数据类型

    基本数据类型 基本类型的包装类型

    byte Byte

    short Short

    int Integer

    long Long

    float Float

    double Double

    boolean Boolean

    char Character

    基本数据类型对应包装类型的好处:

    1、 包装类型,基本数据类型的数据也可以使用一些方法。

    //整数变成字符串

    System.out.println("整数转换成对应的字符串:"+Integer.toString(1));

    //把整数转换成对应的禁止形式

    System.out.println("转成二进制:"+Integer.toBinaryString(10));

    System.out.println("十进制到八进制:"+Integer.toOctalString(10));

    System.out.println("10到十六进制:"+Integer.toHexString(10));

    //可以把字符串当成对应的禁止数据帮你转换

    String data = "10";

    int a = Integer.parseInt(data, 11); //进制的范围最大不超过36

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

    //自动装箱:自动把java的基本数据类型的数据转成对象数据类型

    int tmp = 10;

    Integer b = tmp;

    //自动拆箱:把引用类型的数据转换成基本类型的数据

    Integer c = new Integer(13);

    int d = c;

    System.out.println(d);

    //引用的数据类型

    Integer e = 127;

    Integer f = 128;

    System.out.println("e == f:"+(e==f)); syso true

    //Integer类内部维护了一个缓冲数组存储了-128~+127这些数据在一个数组中,如果你获取的数据失落在这个范围之内的,

    //就直接从该缓冲区内获取对应的数据 这个完全可以查看Integer的源码

    Jdk1.5新特性之枚举类型

    有关枚举可以参见另一篇文章,讲的很详细,地址:http://www.cnblogs.com/OliverZhang/p/6003178.html

    说说从网上和javacore上看的有关枚举的一句经典的介绍,你看 enum Sez{man, woman;}就这么简简单单的一句都做了写什么呢?在java类库中存在这么一个类Enum这个类叫做枚举类,一旦使用enum关键字修饰Sex,那么Sex就变成了Enum的子类......

    问题:某些方法所接受的数据必须是在固定范围之内的。

    解决方案:自定义一个类,然后是私有化函数,在自定义类中创建类的对象。

    Jdk1.5之后对以上问题提供了新的解决方案。

    枚舉解決的問題:一些方法在運行時,他需要的數據不是任意的,而是在一定的範圍內的。

    枚舉類的定義格式:

    enum 類名

    {

    }

    枚舉要注意的細節:(結合反編譯 javap -c -l -private Sex

    1、枚舉也是一個特殊的類

    2、枚舉值默認的修飾符是public static final day19.Sex man;

    3、枚舉值所屬的類的數據類型,枚舉值是指向了本類的對象。本例中是一個Sex型的。

    4、枚举类的构造方法默认是private型的。

    5、枚举类可以定义自己的成员变量与成员函数。

    6、枚举类可以自定义构造函数,但是构造函数的修饰符必须是private

    7、枚举类可以存在抽象的方法,但是枚举值必须要实现抽象的方法。

    8、枚举值必须要位于枚举类的第一个语句,否则报错。

    枚举使用的范围:

    方向,性别,季节,星期,尺码,,,,,,

    switch 语句适用的数据类型:bytecharshortintString、枚举

    注意:case语句后面的枚举值,只需要但写枚举值,不要声明这个枚举值属于哪个枚举类,否则报错。为什么呢?1因为在进switch(season)

    语句的时候,这个时候就已经判断了枚举类型,2你不小心可能会传入别的枚举值比如Sex.man

  • 相关阅读:
    第 33课 C++中的字符串(下)
    第 33课 C++中的字符串(上)
    第32课 初探C++标准库
    第31课 完善的复数类
    第30课 操作符重载
    第29课 类中的函数重载
    C++和C的相互调用
    函数重载遇上函数指针
    函数重载分析
    第2课 算法的效率问题
  • 原文地址:https://www.cnblogs.com/OliverZhang/p/6020973.html
Copyright © 2011-2022 走看看