JDK1.5-JDK1.8的新特性
来源:互联网 发布:什么是最优化 编辑:程序博客网 时间:2024/04/24 15:26
JDK5新特性
- 1,自动拆装箱
- 2,泛型
- 3,可变参数
- 4,静态导入
- 5,增强for循环
- 6,互斥锁
- 7,枚举
7、枚举
- A:枚举概述
- 是指将变量的值一一列出来,变量的值只限于列举出来的值的范围内。举例:一周只有7天,一年只有12个月等。
- B:回想单例设计模式:单例类是一个类只有一个实例
- 那么多例类就是一个类有多个实例,但不是无限个数的实例,而是有限个数的实例。这才能是枚举类。
- C:案例演示
- 自己实现枚举类
- 代码如下
- 自己实现枚举类
public abstract class Week3 { //此处使用了匿名内部类实现抽象方法 public static final Week3 MON = new Week3("星期一") { public void show() { System.out.println("星期一"); } }; public static final Week3 TUE = new Week3("星期二"){ public void show() { System.out.println("星期二"); } }; public static final Week3 WED = new Week3("星期三"){ public void show() { System.out.println("星期三"); } }; private String name; //私有构造,不让其他类创建本类对象 private Week3(String name){ this.name = name; } public String getName() { return name; } public abstract void show();}
枚举类常用创建方法
- A:案例演示
- 定义枚举类要用关键字enum
- 所有枚举类都是Enum的子类
- 枚举类的第一行上必须是枚举项,最后一个枚举项后的分号是可以省略的,但是如果枚举类有其他的东西,这个分号就不能省略。建议不要省略
- 枚举类可以有构造器,但必须是private的,它默认的也是private的。
- 枚举类也可以有抽象方法,但是枚举项必须重写该方法
- 枚举在switch语句中的使用
方式一:
public enum Week { MON,TUE,WED;}
方式二:
public enum Week2 { MON("星期一"),TUE("星期二"),WED("星期三"); private String name; private Week2(String name) { this.name = name; } public String getName() { return name; } public String toString() { return name; }}
方式三:
public enum Week3 { MON("星期一"){ public void show() { System.out.println("星期一"); } },TUE("星期二"){ public void show() { System.out.println("星期二"); } },WED("星期三"){ public void show() { System.out.println("星期三"); } }; private String name; private Week3(String name) { this.name = name; } public String getName() { return name; } public abstract void show();}
JDK1.7新特性
JDK7新特性
- A:二进制字面量
- B:数字字面量可以出现下划线
- C:switch 语句可以用字符串
- D:泛型简化,菱形泛型
- E:异常的多个catch合并,每个异常用或|
- F:try-with-resources 语句
JDK1.8新特性
JDK8新特性(JDK8的新特性)
- 接口中可以定义有方法体的方法,如果是非静态,必须用default修饰
如果是静态的就不用了
class Test { public void run() { final int x = 10; class Inner { public void method() { System.out.println(x); } } Inner i = new Inner(); i.method(); }}
局部内部类在访问他所在方法中的局部变量必须用final修饰,为什么?
因为当调用这个方法时,局部变量如果没有用final修饰,他的生命周期和方法的生命周期是一样的,当方法弹栈,这个局部变量也会消失,那么如果局部内部类对象还没有马上消失想用这个局部变量,就没有了,如果用final修饰会在类加载的时候进入常量池,即使方法弹栈,常量池的常量还在,也可以继续使用。
0 0
- JDK1.5-JDK1.8的新特性
- JDK1.5到JDK1.8增加的新特性
- JDK各个版本的新特性jdk1.5-jdk1.8
- JDK1.5,JDK1.6,JDK1.7 各自的新特性
- jdk1.8的新特性
- jdk1.5的新特性
- JDK1.5的新特性
- JDK1.5的新特性
- JDK1.5的新特性
- JDK1.5的新特性
- jdk1.5的新特性
- JDK1.5的新特性
- JDK1.5的新特性
- JDK1.5的新特性
- jdk1.5的新特性
- jdk1.5的新特性
- jdk1.5的新特性
- JDK1.5的新特性
- Sublime Text 3 配置java运行环境
- IOS开发笔记4-C语言基础复习
- python-matplotlib
- Vue.js 学习(三)
- lightoj 1006 - Hex-a-bonacci (FOR循环)
- JDK1.5-JDK1.8的新特性
- 王朝 第十四周 用数组表示进制转化
- 周易六十四卦——震为雷卦
- 关于大龄程序员的谣言 新手必读
- 鸟瞰大数据hive学习从入门到精通路线图(包含知识点)(初级)
- 电容滤波
- java Socket通信使用BufferedReader和BufferedWriter的注意事项
- python之文件操作
- STL中的set容器的一点总结