zoukankan      html  css  js  c++  java
  • Java 8 和 Java 9部分区别

    Java 8 和 Java 9中 concurrent 包有了一些改变, 本文对这些改变做了汇总。
    Java 8 中 Concurrent package的改变
    java.util.concurrent中新的类和接口
    增加了两个新接口和4个新类:
    接口 CompletableFuture.AsynchronousCompletionTask
    接口 CompletionStage
    类 CompletableFuture
    类 ConcurrentHashMap.KeySetView
    类 CountedCompleter
    类 CompletionException
    java.util.concurrent.ConcurrentHashMap的新方法
    集合框架 在Java 8中做了修订,基于 stream 和 lambda表达式 添加了很多聚合方法。因此 ConcurrentHashMap 也引入了30几个新方法,包括各种 foreach 方法(forEach , forEachKey , forEachValue , 和 forEachEntry )、搜索方法( search , searchKeys , searchValues , 和 searchEntries )和reduction方法( reduce ,reduceToDouble , reduceToLong 等)。
    也添加了一些其它方法,比如 mappingCount 和 newKeySet 。并且当前版本的 ConcurrentHashMap 的更适合做cache,因为增加了当键值不存在的时候的检查方法。
    java.util.concurrent.atomic中的新类
    为了并发计算count、sum, 新引入了 DoubleAccumulator , DoubleAdder , LongAccumulator , LongAdder 类,比Atomic提供更高的吞吐率。
    java.util.concurrent.ForkJoinPool的新方法
    静态的 commonPool() 新加入,可以为ForkJoinTask提供通用池。
    两个方法 getCommonPoolParallelism() 和 commonPool() 提供不同的配置。
    新类 java.util.concurrent.locks.StampedLock
    新类 StampedLock 提供三种模式(写,读,乐观读),用来提高性能。
    Java 9 中 Concurrent package的改变
    主要是 JEP 266: More Concurrency Updates , 包括publish-subscribe, CompletableFuture 接口的加强等。
    支持Reactive Streams publish-subscribe框架,四个接口 Processor 、 Publisher 、 Subscriber 、 Subion ,容器类 java.util.concurrent.Flow 、java.util.concurrent.SubmissionPublisher
    CompletableFuture类加强,支持delays, timeout, subclassing 以及其它方法
    调优以及修改javadoc
  • 相关阅读:
    MySQL——视图/触发器/事务/存储过程/函数/流程控制
    python连接MySQL/redis/mongoDB数据库的简单整理
    docker安装和使用
    【Python】Django2.0集成Celery4.1详解
    django-haystack全文检索详细教程
    ubuntu16.04安装FastDFS-5.08
    redis之django-redis
    uva 1152 4 Values whose Sum is 0
    2015暑假acm短训小结
    Uva 12569 Planning mobile robot on Tree (EASY Version)
  • 原文地址:https://www.cnblogs.com/xiaoshen666/p/10898730.html
Copyright © 2011-2022 走看看