zoukankan      html  css  js  c++  java
  • jdk678910新特性地址

    jdk678910新特性地址

    https://blog.csdn.net/f641385712/article/details/81289401

    每篇一句:
    每个人受到的尊重从来都不是应得的,而是赢得的

    截止稿前,java10都已经发布了,现在我们来讨论一下java8(2014年3月发布)。
    本文的讨论,只是一个简述,更加具体的,各位可以参照各自的专题讲解

    说在前面
    你真的开始用JDK8了吗? 如果你没有用上一些新特性,请别说自己使用了Java8。

    Java 8可谓是自Java 5以来最具革命性的版本了,她在语言、编译器、类库、开发工具以及Java虚拟机等方面都带来了不少新特性。我们来一一回顾一下这些特性。

    一、Lambda表达式
    Lambda表达式可以说是Java 8最大的卖点,她将函数式编程引入了Java。Lambda允许把函数作为一个方法的参数,或者把代码看成数据。

    一个Lambda表达式可以由用逗号分隔的参数列表、–>符号与函数体三部分表示。例如:

    Arrays.asList( "p", "k", "u","f", "o", "r","k").forEach( e -> System.out.println( e ) );
    1
    为了使现有函数更好的支持Lambda表达式,Java 8引入了函数式接口的概念。函数式接口就是只有一个方法的普通接口。java.lang.Runnable与java.util.concurrent.Callable是函数式接口最典型的例子。为此,Java 8增加了一种特殊的注解@FunctionalInterface

    二、接口的默认方法与静态方法
    我们可以在接口中定义默认方法,使用default关键字,并提供默认的实现。所有实现这个接口的类都会接受默认方法的实现,除非子类提供的自己的实现。例如:

    public interface DefaultFunctionInterface {
    default String defaultFunction() {
    return "default function";
    }
    }
    1
    2
    3
    4
    5
    我们还可以在接口中定义静态方法,使用static关键字,也可以提供实现。例如:

    public interface StaticFunctionInterface {
    static String staticFunction() {
    return "static function";
    }
    }
    1
    2
    3
    4
    5
    接口的默认方法和静态方法的引入,其实可以认为引入了C++中抽象类的理念,以后我们再也不用在每个实现类中都写重复的代码了。

    三、方法引用(含构造方法引用)
    通常与Lambda表达式联合使用,可以直接引用已有Java类或对象的方法。一般有四种不同的方法引用:

    构造器引用。语法是Class::new,或者更一般的Class< T >::new,要求构造器方法是没有参数;
    静态方法引用。语法是Class::static_method,要求接受一个Class类型的参数;
    特定类的任意对象方法引用。它的语法是Class::method。要求方法是没有参数的;
    特定对象的方法引用,它的语法是instance::method。要求方法接受一个参数,与3不同的地方在于,3是在列表元素上分别调用方法,而4是在某个对象上调用方法,将列表元素作为参数传入;
    四、重复注解
    在Java 5中使用注解有一个限制,即相同的注解在同一位置只能声明一次。Java 8引入重复注解,这样相同的注解在同一地方也可以声明多次。重复注解机制本身需要用@Repeatable注解。Java 8在编译器层做了优化,相同注解会以集合的方式保存,因此底层的原理并没有变化。

    五、扩展注解的支持(类型注解)
    Java 8扩展了注解的上下文,几乎可以为任何东西添加注解,包括局部变量、泛型类、父类与接口的实现,连方法的异常也能添加注解。

    private @NotNull String name;
    1
    六、Optional
    Java 8引入Optional类来防止空指针异常,Optional类最先是由Google的Guava项目引入的。Optional类实际上是个容器:它可以保存类型T的值,或者保存null。使用Optional类我们就不用显式进行空指针检查了。

    七、Stream
    Stream API是把真正的函数式编程风格引入到Java中。其实简单来说可以把Stream理解为MapReduce,当然Google的MapReduce的灵感也是来自函数式编程。她其实是一连串支持连续、并行聚集操作的元素。从语法上看,也很像linux的管道、或者链式编程,代码写起来简洁明了,非常酷帅!

    八、Date/Time API (JSR 310)
    Java 8新的Date-Time API (JSR 310)受Joda-Time的影响,提供了新的java.time包,可以用来替代 java.util.Date和java.util.Calendar。一般会用到Clock、LocaleDate、LocalTime、LocaleDateTime、ZonedDateTime、Duration这些类,对于时间日期的改进还是非常不错的。

    九、JavaScript引擎Nashorn
    Nashorn允许在JVM上开发运行JavaScript应用,允许Java与JavaScript相互调用。

    十、Base64
    在Java 8中,Base64编码成为了Java类库的标准。Base64类同时还提供了对URL、MIME友好的编码器与解码器。

    说在后面
    除了这十大新特性之外,还有另外的一些新特性:

    **更好的类型推测机制:**Java 8在类型推测方面有了很大的提高,这就使代码更整洁,不需要太多的强制类型转换了。

    **编译器优化:**Java 8将方法的参数名加入了字节码中,这样在运行时通过反射就能获取到参数名,只需要在编译时使用-parameters参数。

    **并行(parallel)数组:**支持对数组进行并行处理,主要是parallelSort()方法,它可以在多核机器上极大提高数组排序的速度。

    **并发(Concurrency):**在新增Stream机制与Lambda的基础之上,加入了一些新方法来支持聚集操作。

    **Nashorn引擎jjs:**基于Nashorn引擎的命令行工具。它接受一些JavaScript源代码为参数,并且执行这些源代码。

    **类依赖分析器jdeps:**可以显示Java类的包级别或类级别的依赖。

    JVM的PermGen空间被移除:取代它的是Metaspace(JEP 122)。

    Java 8是一次变化巨大的更新,耗费了工程师大量的时间,还借鉴了很多其它语言和类库。我们无法在这里一一详细列举,以后有机会一定给大家详细解读一下。
    ---------------------

    概述
    Base64是一种字符串编码格式,采用了A-Z,a-z,0-9,“+”和“/”这64个字符来编码原始字符(还有垫字符“=”)。一个字符本身是一个字节,也就是8位,而base64编码后的一个字符只能表示6位的信息。也就是原始字符串中的3字节的信息编码会变成4字节的信息。Base64的主要作用是满足MIME的传输需求。
    在Java8中Base64编码已经成为Java类库的标准,且内置了Base64编码的编码器和解码器。

    看个例子
    public static void main(String[] args) {
    String orig = "hello world!";
    //编码加密
    String desc = Base64.getEncoder().encodeToString(orig.getBytes(StandardCharsets.UTF_8));
    System.out.println("加密后的字符串为:"+desc);

    //解码解密
    String unDecodeStr=new String(Base64.getDecoder().decode(desc),StandardCharsets.UTF_8);
    System.out.println("解密后的字符串为"+unDecodeStr);
    }
    输出:
    加密后的字符串为:aGVsbG8gd29ybGQh
    解密后的字符串为hello world!
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    将文件File转换为Base64

    public static String fileToBase64(String path) {
    File file = new File(path);
    FileInputStream inputFile;
    try {
    inputFile = new FileInputStream(file);
    byte[] buffer = new byte[(int) file.length()];
    inputFile.read(buffer);
    inputFile.close();
    return Base64.getEncoder().encodeToString(buffer);
    } catch (Exception e) {
    throw new RuntimeException("文件路径无效 " + e.getMessage());
    }
    }
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    将Base64转换为file文件

    public static boolean base64ToFile(String base64, String path) {
    byte[] buffer;
    try {
    buffer = Base64.getDecoder().decode(base64);
    FileOutputStream out = new FileOutputStream(path);
    out.write(buffer);
    out.close();
    return true;
    } catch (Exception e) {
    throw new RuntimeException("base64字符串异常或地址异常 " + e.getMessage());
    }
    }
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Base64的原理
    为什么会有Base64编码呢?因为有些网络传送渠道并不支持所有的字节,例如传统的邮件只支持可见字符的传送,像ASCII码的控制字符就 不能通过邮件传送。这样用途就受到了很大的限制,比如图片二进制流的每个字节不可能全部是可见字符,所以就传送不了。最好的方法就是在不改变传统协议的情 况下,做一种扩展方案来支持二进制文件的传送。把不可打印的字符也能用可打印字符来表示,问题就解决了。Base64编码应运而生,Base64就是一种 基于64个可打印字符来表示二进制数据的表示方法。

    有一个数组,里面有“A-Z, a-z, 0-9 , + , /”一共64个字符。然后对需要处理的的二进制数据做处理:每3个字节(24bit)一组,因此按照6bit一组为Base64的规则可以划为4组,每组6bit,刚好64位(对应数组的64个值)

    Base64的码表只有64个字符, 如果要表达64个字符的话,使用6的bit即可完全表示(2的6次方为64)。
    如果是字符串转换为Base64码, 会先把对应的字符串转换为ascll码表对应的数字, 然后再把数字转换为2进制, 比如a的ascll码味97, 97的二进制是:01100001, 把8个二进制提取成6个,剩下的2个二进制和后面的二进制继续拼接, 最后再把6个二进制码转换为Base64对于的编码

    所以,Base64编码会把3字节的二进制数据编码为4字节的文本数据,长度增加33%,好处是编码后的文本数据可以在邮件正文、网页等直接显示。

    如果要编码的二进制数据不是3的倍数,最后会剩下1个或2个字节怎么办?Base64用x00字节在末尾补足后,再在编码的末尾加上1个或2个=号,表示补了多少字节,解码的时候,会自动去掉。

    java8的Api提供了Basic编码、URL编码、MIME编码、对流的支持
    ---------------------
    作者:_YourBatman
    来源:CSDN
    原文:https://blog.csdn.net/f641385712/article/details/81289401
    版权声明:本文为博主原创文章,转载请附上博文链接!

  • 相关阅读:
    swift基本数据类型的使用
    宏定义单例类
    开发必备宏定义大全
    GUI02
    GUI01
    浅谈代码块的加载顺序
    Java里的多态
    在java中this和super的使用
    冒泡排序的简单优化
    命令行传参和不定传参
  • 原文地址:https://www.cnblogs.com/wuer888/p/10038522.html
Copyright © 2011-2022 走看看