Java中间件(2)--分布式系统&中间件从入门到精通(六)

本文涉及的产品
Serverless 应用引擎 SAE,800核*时 1600GiB*时
注册配置 MSE Nacos/ZooKeeper,118元/月
性能测试 PTS,5000VUM额度
简介: Java中间件(2)--分布式系统&中间件从入门到精通(六)

上篇文章介绍了线程池使用的优点,synchronized和reentrantLock的区别,reentrantlock又有读写锁,适用于读多写少的场景,可以用tryLock获取锁,并且在构造器可以指定布尔值,来当做公平锁来使用。

Java中间件(1)--分布式系统&中间件从入门到精通(五)


前面说了synchronized除了有互斥性的作用外,还有可见性的作用,synchronized保证了代码块中变量的可见性,Volatile则保证了所修饰变量的可见性,是实现轻量级变量可见性方法。直接在变量前面加个volatile关键字就行。

需要注意的是,与锁相比,这里只操作了线程的可见性,绝对没有保证原子性,可见性和多个线程操作变量保证互斥性是两件事,如果volatile修饰的变量,在多线程的情况下来操作数据,并不能保证线程安全问题。


Atomics是jdk1.5之后引入的,这里面会有一些atomic开头的类,比如int在这里会显示AtomicInteger来提供相关原子性的操作,不光保证原子性,性能也能得到提升,主要因为atomicInteger内部通过JNI的方式使用硬件支持cas指令。


而wait、notify、notifyAll则是java的Object对象上的三个方法,这三个的调用都必须写在synchronized代码块里,顾名思义wait是等待的,后面两个则会唤醒它,notify是单个唤醒,notifyAll则是唤醒所有。

在代码实践中,wait的使用一般嵌在循环中,当达到一定值的时候,会判断是否到达,如果没有则继续等待,这么做主要为了防止虚假唤醒。


countdownLatch也是current包里的一个类,主要是当多个线程达到预期状态,多个线程这里指的是初始化countDownLatch里的参数,其他线程才可以从等待状态继续运行,即是可以唤醒多个等待的线程,达到自己的预期会调用countDown方法,而等待的线程则会调用await()方法,当参数一直到0的时候,则会调用notifyAll()方法,让等待线程不再等待。

 

int max = 100;
        ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(100, 100, 60L,
            TimeUnit.SECONDS, new LinkedBlockingQueue<>(max));
        //AtomicInteger atomicInteger = new AtomicInteger();
        CountDownLatch countDownLatch = new CountDownLatch(max);
        for (int i = 0; i < max; i++) {
            threadPoolExecutor.execute(() -> {
                //atomicInteger.incrementAndGet();
                try {
                    countDownLatch.countDown();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            });
        }
        System.out.println("子线程运行中=========");
        // countDownLatch.await();
        threadPoolExecutor.shutdown();
        System.out.println("子线程运行完才会输出!!!");


cyclicBarrier使用和countDownLatch类似,但是他是可以循环使用的,而且线程池数量太少容易发生死锁一定要小心最大线程数,使用的时候,参数必须任务数+1,因为countDownLatch调用的是countDown减一,然后调用await等待,而cyclicBarrier则是所有都调用await,当所有子线程和主线程都到达那个点阻塞的时候,这时候才会进行下一步。

     

int max = 100;
        ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(100, 100, 60L,
            TimeUnit.SECONDS, new LinkedBlockingQueue<>(max));
        //AtomicInteger atomicInteger = new AtomicInteger();
        //CountDownLatch countDownLatch = new CountDownLatch(max);
        CyclicBarrier cyclicBarrier = new CyclicBarrier(max + 1);
        for (int i = 0; i < max; i++) {
            threadPoolExecutor.execute(() -> {
                //atomicInteger.incrementAndGet();
                try {
                    //countDownLatch.countDown();
                    System.out.println(Thread.currentThread().getName());
                    cyclicBarrier.await();
                } catch (Exception e) {
                    e.printStackTrace();
                }
            });
        }
        System.out.println("子线程运行中=========");
        cyclicBarrier.await();
        // countDownLatch.await();
        threadPoolExecutor.shutdown();
        System.out.println("子线程运行完才会输出!!!");
相关文章
|
2月前
|
存储 SQL 分布式数据库
OceanBase 入门:分布式数据库的基础概念
【8月更文第31天】在当今的大数据时代,随着业务规模的不断扩大,传统的单机数据库已经难以满足高并发、大数据量的应用需求。分布式数据库应运而生,成为解决这一问题的有效方案之一。本文将介绍一款由阿里巴巴集团自主研发的分布式数据库——OceanBase,并通过一些基础概念和实际代码示例来帮助读者理解其工作原理。
118 0
|
11天前
|
Dubbo Java 应用服务中间件
分布式-dubbo的入门
分布式-dubbo的入门
|
11天前
|
Java 程序员 UED
Java中的异常处理:从入门到精通
【9月更文挑战第23天】在Java编程的世界中,异常是程序执行过程中不可避免的事件,它们可能会中断正常的流程并导致程序崩溃。本文将通过浅显易懂的方式,引导你理解Java异常处理的基本概念和高级技巧,帮助你编写更健壮、更可靠的代码。我们将一起探索如何捕获和处理异常,以及如何使用自定义异常来增强程序的逻辑和用户体验。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供有价值的见解和实用的技巧。
30 4
|
2月前
|
设计模式 前端开发 Java
【前端学java】SpringBootWeb极速入门-分层解耦(03)
【8月更文挑战第13天】SpringBootWeb极速入门-分层解耦(03)
18 2
【前端学java】SpringBootWeb极速入门-分层解耦(03)
|
2月前
|
算法 Java 开发者
Java 编程入门:从零到一的旅程
本文将带领读者开启Java编程之旅,从最基础的语法入手,逐步深入到面向对象的核心概念。通过实例代码演示,我们将一起探索如何定义类和对象、实现继承与多态,并解决常见的编程挑战。无论你是编程新手还是希望巩固基础的开发者,这篇文章都将为你提供有价值的指导和灵感。
|
2月前
|
存储 Java 程序员
Java中的集合框架:从入门到精通
【8月更文挑战第30天】在Java的世界里,集合框架是一块基石,它不仅承载着数据的存储和操作,还体现了面向对象编程的精髓。本篇文章将带你遨游Java集合框架的海洋,从基础概念到高级应用,一步步揭示它的奥秘。你将学会如何选择合适的集合类型,掌握集合的遍历技巧,以及理解集合框架背后的设计哲学。让我们一起探索这个强大工具,解锁数据结构的新视角。
|
2月前
|
Java 程序员 UED
Java中的异常处理:从入门到精通
【8月更文挑战第28天】在Java编程的世界里,异常处理是一块基石,它确保了程序的健壮性和可靠性。本文将通过深入浅出的方式,带你了解Java异常处理的基本概念、分类、以及如何有效地捕获和处理异常。我们将一起探索try-catch-finally结构的奥秘,并学习如何使用throws关键字声明方法可能会抛出的异常。此外,我们还会讨论自定义异常类的创建和使用,以及最佳实践。无论你是Java新手还是有一定经验的开发者,这篇文章都将为你提供宝贵的知识,帮助你编写出更加稳定和可靠的代码。
|
2月前
|
机器学习/深度学习 并行计算 PyTorch
PyTorch与DistributedDataParallel:分布式训练入门指南
【8月更文第27天】随着深度学习模型变得越来越复杂,单一GPU已经无法满足训练大规模模型的需求。分布式训练成为了加速模型训练的关键技术之一。PyTorch 提供了多种工具来支持分布式训练,其中 DistributedDataParallel (DDP) 是一个非常受欢迎且易用的选择。本文将详细介绍如何使用 PyTorch 的 DDP 模块来进行分布式训练,并通过一个简单的示例来演示其使用方法。
37 2
|
2月前
|
编解码 网络协议 Oracle
java网络编程入门以及项目实战
这篇文章是Java网络编程的入门教程,涵盖了网络编程的基础知识、IP地址、端口、通讯协议(TCP和UDP)的概念与区别,并提供了基于TCP和UDP的网络编程实例,包括远程聊天和文件传输程序的代码实现。
java网络编程入门以及项目实战

热门文章

最新文章

下一篇
无影云桌面