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

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 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天前
|
Java 开发工具 Windows
Java入门及环境变量
Java入门及环境变量
|
3天前
|
Java API 调度
[AIGC] 深入理解Java并发编程:从入门到进阶
[AIGC] 深入理解Java并发编程:从入门到进阶
|
3天前
|
Java Nacos 开发者
Java从入门到精通:4.2.1学习新技术与框架——以Spring Boot和Spring Cloud Alibaba为例
Java从入门到精通:4.2.1学习新技术与框架——以Spring Boot和Spring Cloud Alibaba为例
|
3天前
|
前端开发 Java 测试技术
Java从入门到精通:4.1.1参与实际项目,锻炼编程与问题解决能力
Java从入门到精通:4.1.1参与实际项目,锻炼编程与问题解决能力
|
3天前
|
Java 程序员 数据库连接
Java从入门到精通:3.3.2性能优化与调优——内存管理篇
Java从入门到精通:3.3.2性能优化与调优——内存管理篇
Java从入门到精通:3.3.2性能优化与调优——内存管理篇
|
3天前
|
Dubbo Java 应用服务中间件
Java从入门到精通:3.2.2分布式与并发编程——了解分布式系统的基本概念,学习使用Dubbo、Spring Cloud等分布式框架
Java从入门到精通:3.2.2分布式与并发编程——了解分布式系统的基本概念,学习使用Dubbo、Spring Cloud等分布式框架
|
3天前
|
SQL Java 数据库连接
Java从入门到精通:2.3.2数据库编程——了解SQL语言,编写基本查询语句
Java从入门到精通:2.3.2数据库编程——了解SQL语言,编写基本查询语句
|
8月前
|
NoSQL Java Redis
阿里Java高级岗中间件二面:GC+IO+JVM+多线程+Redis+数据库+源码
虽然“钱多、事少、离家近”的工作可能离技术人比较远,但是找到一份合适的工作,其实并不像想象中那么难。但是,有些技术人确实是认真努力工作,但在面试时表现出的能力水平却不足以通过面试,或拿到高薪,其实不外乎以下 2 个原因:
|
8月前
|
算法 NoSQL Java
2023年阿里高频Java面试题:分布式+中间件+高并发+算法+数据库
又到了一年一度的金九银十,互联网行业竞争是一年比一年严峻,作为工程师的我们唯有不停地学习,不断的提升自己才能保证自己的核心竞争力从而拿到更好的薪水,进入心仪的企业(阿里、字节、美团、腾讯.....)
|
8月前
|
算法 NoSQL Java
2021年阿里高频Java面试题:分布式+中间件+高并发+算法+数据库
又到了一年一度的金九银十,互联网行业竞争是一年比一年严峻,作为工程师的我们唯有不停地学习,不断的提升自己才能保证自己的核心竞争力从而拿到更好的薪水,进入心仪的企业(阿里、字节、美团、腾讯.....)