jdk1.5与jdk1.8的新特性

tech2023-05-20  105

jdk1.5新特性

1.静态导入

可以导入静态方法,可以直接使用 静态导入信息会优先加载

package cn.tedu.jdk.jdk5; //静态导入 import static java.lang.Math.*; public class StaticImportDemo { public static void main(String[] args) { // System.out.println(random()); System.out.println(abs(12)); } }

2.可变参数

参数类型… 可以接受任意多个参数 底层是有数组来实现的,参数值都是存放在对应的数组元素中 可变参数值只能出现在参数列表的最右边,最多只能出行一次

package cn.tedu.jdk.jdk5; public class VariableDemo { public static void main(String[] args) { System.out.println(sum(1)); System.out.println(sum(1,2)); System.out.println(sum(1,2,34,4)); } //定义方法求和 //参数类型...---可变参数 //可以接受任意多个参数 //可变参数底层是一个大大的数组,把参数值赋值给对应的数组元素 //可变参数只能出现在参数列表的最右边(最多只能出现一次) public static int sum(int... i){ //return i; int sum=0; for (int j=0;j<i.length;j++){ sum+=i[j]; } return sum; } /*public static int sum(int i,int j){ return i+j; } public static int sum(int i,int j,int z){ return i+j+z; } public static int sum(int[] arr){ int m=0; for (int a:arr){ m+=a; } return m; }*/ }

3.枚举

把值一一列举 列举是枚举常量且在首行,并且在一行 构造方法一定要私有化 定义属性和方法 定义抽象方法 switch表达式类型支持枚举类型

package cn.tedu.reflect; public class EnumDemo { public static void main(String[] args) { Season spring=Season.spring; switch (spring){ case spring: System.out.println("春游"); break; case summer: System.out.println("游泳"); break; case autumn: System.out.println("爬山"); break; case winter: System.out.println("冬泳"); break; } } } //枚举 enum Season{ //列举值 //spring等效public final static Season spring=new Season(); //枚举常量--要在同一行,首行 spring{ @Override public void n() { } },summer{ @Override public void n() { } },autumn{ @Override public void n() { } },winter{ @Override public void n() { } }; // int i=1; //方法 public void m(){} //构造方法--只能私有化 private Season(){} //抽象方法 public abstract void n(); } //定义类---代表季节的类,类产生的对象就是具体的季节 //只有四个季节,类只能产生四个对象 /*class Season{ //构造方法私有化,保证外部不能调用构造方法来创建对象 private Season(){} //创建四个对象---四个季节 public final static Season spring=new Season(); public final static Season summer=new Season(); public final static Season autumn=new Season(); public final static Season winter=new Season(); }*/

jdk1.8新特性

接口里可以定义实体方法(默认方法、静态方法) Lambda表达式用于重写函数式接口的抽象方法 函数式接口里只含有一个抽象方法

public class LambdaDemo1 { public static void main(String[] args) { //创建实现类对象 //CalcImpl c=new CalcImpl(); //调用接口里的实体类方法---默认方法 /*System.out.println(c.sum(1,2));*/ /* //由接口名称直接调用实体类方法---静态方法 Calc.cj(2,3);*/ /*//创建实现类对象 //调用接口重写方法 c.max(1,2);*/ /*//匿名内部类 //c是匿名内部类的对象 Calc c=new Calc() { @Override public int max(int x, int y) { return x>y?x:y; } }; //调用匿名内部类(接口的实现类)的重写方法 c.max(1,2);*/ //Lambda表达式(针对函数式接口) //(参数列表)->{抽象方法的重写的方法体}; //Calc c=(int x,int y)->{return x>y?x:y;}; //由前面的抽象方法参数类型推导出此时的参数类型,不用写参数类型 //如果重写方法的方法体只有一句话就可以把return以及{}省略 Calc c=(x,y)->x>y?x:y; c.max(1,2); } } //接口---计算器 //接口里只有一个抽象方法---函数式接口(函数式编程) @FunctionalInterface interface Calc{ //求最大值 int max(int x,int y); //实体方法---默认方法 public default int sum(int x,int y){return x+y;} // public static int cj(int x,int y){return x*y;} } //实现类 class CalcImpl implements Calc{ @Override public int max(int x, int y) { return x>y?x:y; } } public class LambdaDemo2 { public static void main(String[] args) { /* //Lambda表达式 SortArray s=(arr )-> Arrays.sort(arr);*/ //当参数只有一个时可以省略() //SortArray s=arr -> Arrays.sort(arr); //::传递静态方法 前后只使用一个参数就可以省略 //SortArray s=Arrays::sort; //比较器是函数式接口 //new ArrayList<String>().sort(new Comparator<String>() //FileFilter()---函数式接口 //new File("").listFiles(new FileFilter() //FilenameFilter() ---函数式接口 //new File("").list(new FilenameFilter() } } interface SortArray{ //排序---抽象方法 void sort(int[] arr); }

Stream—流式结构

操作集合元素 提供大量的函数式接口

public class StreamDemo { public static void main(String[] args) { //创建集合对象 List<String> list=new ArrayList<>(); //添加元素 list.add("C"); list.add("Python"); list.add("Java"); list.add("PHP"); list.add("C++"); list.add("C#"); list.add("GO"); //筛选出以C开头的元素 /*for (String s:list){ // if (s.startsWith("c")){ System.out.println(s); } }*/ // Stream<String> s=list.stream(); /*s.filter(new Predicate<String>() { //指定过滤规则 @Override public boolean test(String s) { return s.startsWith("C"); } }).forEach(new Consumer<String>() { @Override public void accept(String s) { System.out.println(s); } });*/ //用lambda表达式 //筛选出以C开头的元素并且排序--升序 s.filter(str1->str1.startsWith("C")).sorted((s1,s2)->s1.compareTo(s2)).forEach(str2-> System.out.println(str2)); } }

time包

时间和日期可以分开操作

public static void main(String[] args) { //只有时间 //LocalTime l=LocalTime.now(); //只有日期 LocalDate l=LocalDate.now(); System.out.println(l); }
最新回复(0)