Java8高中并发

Java8高中并发

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

Java8中学并发

本文翻译自:http://jaxenter.com/lean-concurrency-in-java-8-49924.html

转载请注明出处:http://blog.csdn.net/kingviker/article/details/27057473

有人以前说过(非常不幸,我们没有原话了):

0基础程序猿觉得并发非常难。
中级程序猿觉得并发非常easy。
高级程序猿觉得并发非常难。

这说的非常对。可是从好的方面来看,通过lambda表达式和非常多改进的API使编写并发代码更easy,Java8并发开发至少能得到改善。让我们来详细的看看(Java8的改进):

Java8对JDK 1.0 API的改进。

java.lang.Thread早在JDK 1.0版本号中就已经存在。在java8中被注解为功能性接口java.lang.Runnable也是。

从如今起。差点儿不须要动大脑我们就能够提交Runnables给一个线程。让我们如果我们有一个非常耗时的操作:

public static int longOperation() {
    System.out.println("Running on thread #"
    + Thread.currentThread().getId());

    // [...]
    return 42;
}

我们能够用多种方法把这个操作传递给线程,比如:

Thread[] threads = {

    // Pass a lambda to a thread
    new Thread(() -> {
    longOperation();
    }),

    // Pass a method reference to a thread
    new Thread(ThreadGoodies::longOperation)
};

// Start all threads
Arrays.stream(threads).forEach(Thread::start);

// Join all threads
Arrays.stream(threads).forEach(t -> {
    try { t.join(); }
    catch (InterruptedException ignore) {}
});

就像我们在之前的博文里提到的一样。lambda表达式没有一个简洁的方式来处理被检异常实在是一大憾事。在java.util.function包中新增的功能性接口没有一个涉及到抛出被检异常。把这项工作留给了调用端。

在上一篇博文中。我们已经因此而公布了jOOλ(also jOOL,jOO-Lambda)包,该包包装了JDK中的每个功能性接口,据有同样功能并且也同意抛出被检异常。

这在使用老的JDK API时特别实用,比如JDBC,或者上面提到的Thread API。使用jOOλ,我们能够这么写:

// Join all threads
Arrays.stream(threads).forEach(Unchecked.consumer(
    t -> t.join()
));

Java8中改进的Java5 API

Java的多线程在Java5的非常好的ExecutorService公布之前一直非常沉寂。管理多线程是一个负担,人们须要额外的库或者一个J2EE/JEE容器来管理线程池。

这些用Java5来处理已经easy了非常多。我们如今能够提交一个Runnable对象或者一个Callable对象到ExcutorService。它管理自己的线程池。

以下是一个我们怎样在Java8中利用这些Java5的并发API的样例:

ExecutorService service = Executors
    .newFixedThreadPool(5);

Future[] answers = {
    service.submit(() -> longOperation()),
    service.submit(ThreadGoodies::longOperation)
};

Arrays.stream(answers).forEach(Unchecked.consumer(
    f -> System.out.println(f.get())
));

注意看。我们是怎样再次使用jOOλ中的UncheckedConsumer来包装在执行期调用get()方法抛出的被检异常。

Java8中的并行和ForkJoinPool

如今,Java8的Streams API在并发和并行方面有了非常大改进。 在Java8中你能够写出例如以下的代码:

Arrays.stream(new int[]{ 1, 2, 3, 4, 5, 6 })
  .parallel()
  .max()
  .ifPresent(System.out::println);

尽管在这个特殊的样例中不是非常必要,但看到只调用了parallel()就执行IntStream.max()来启用ForkJoinPool而你不必操心包括的ForkJoinTasks还是非常有趣的。这是非常实用的。由于不是每一个人都可以接受JDK7该复合物的引入JorkJoin API

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117284.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Lombok插件的简介「建议收藏」

    Lombok插件的简介「建议收藏」Lombok插件的简介1Lombok引入2Lombok常见注解使用1@Data2@AllArgsConstructor3@NoArgsConstructor4@ToString5@EqualsAndHashCode6@Getter/@Setter7@Slf4j8@NonNull9@Value10@Builder11@Synchronized12@SneakyThrows13@Cleanup3Lombok原理4关于Lombok总结官网:https://projectlom

    2022年9月8日
    0
  • linux mysql 查看默认端口号和修改端口号

    linux mysql 查看默认端口号和修改端口号

    2021年10月19日
    45
  • 学习shiro框架记的一次随笔

    学习shiro框架记的一次随笔

    2021年7月12日
    67
  • 让人“眼前一亮、不明觉厉”的互联网技术PPT「建议收藏」

    让人“眼前一亮、不明觉厉”的互联网技术PPT「建议收藏」为什么选择分享一起如此“鸡肋”的博文呢?我一直有个习惯:理论和实践,两手抓两手也要硬,最近一直搞技术,手里很多的新技术资料还未来得及消化,遂学习总结,加以分享。在做互联网产品功能介绍、互联网产品技术路线、技术人年度总结、互联网教育培训、互联网技术宣讲、技术人毕业答辩等场合时,可以参照以下PPT,让你思如泉涌,格调升级,瞬间征服观众~

    2022年6月1日
    40
  • 程序化交易入门_程序化交易的经验之谈

    程序化交易入门_程序化交易的经验之谈这里会分享最新的个人新文章及转载不错的程序化交易文章!![在这里插入图片描述](https://img-blog.csdnimg.cn/20190520205748924.jpg?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3lpc2h1aW…

    2022年10月8日
    0
  • caffe中常用层: BatchNorm层详解

    caffe中常用层: BatchNorm层详解Batchnorm原理详解前言:Batchnorm是深度网络中经常用到的加速神经网络训练,加速收敛速度及稳定性的算法,可以说是目前深度网络必不可少的一部分。 本文旨在用通俗易懂的语言,对深度学习的常用算法–batchnorm的原理及其代码实现做一个详细的解读。本文主要包括以下几个部分。Batchnorm主要解决的问题Batchnorm原理解读Batchnorm的优点Batchnorm的源码解读第一…

    2022年5月2日
    52

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号