zoukankan      html  css  js  c++  java
  • 第一章 Java常用的并发类

    注:本系列博客主要参考于《分布式Java应用:基础与实践》,林昊 著

    1、常用的并发集合类

    • ConcurrentHashMap:线程安全的HashMap的实现
    • CopyOnWriteArrayList:线程安全且在读操作时无锁的ArrayList
    • CopyOnWriteArraySet:基于CopyOnWriteArrayList,不添加重复元素
    • ArrayBlockingQueue:基于数组、先进先出、线程安全,可实现指定时间的阻塞读写,并且容量可以限制
    • LinkedBlockingQueue:基于链表实现,读写各用一把锁,在高并发读写操作都多的情况下,性能优于ArrayBlockingQueue

    2、原子类

    • AtomicInteger:线程安全的Integer,基于CAS(无阻塞,CPU原语),优于使用同步锁的Integer

    3、线程池

    • ThreadPoolExecutor:一个高效的支持并发的线程池,可以很容易的讲一个实现了Runnable接口的任务放入线程池执行,但要用好这个线程池,必须合理配置corePoolSize、最大线程数、任务缓冲队列,以及队列满了+线程池满时的回绝策略,一般而言对于这些参数的配置,需考虑两类需求:高性能和缓冲执行
    • Executor:提供了一些方便的创建ThreadPoolExecutor的方法。
    • FutureTask:可用于异步获取执行结果或取消执行任务的场景,基于CAS,避免锁的使用

    4、锁

    • ReentrantLock:与synchronized效果一致,但是又更加灵活,支持公平/非公平锁、支持可中断的锁、支持非阻塞的tryLock(可超时)、支持锁条件等,需要手工释放锁,基于AbstractQueueSynchronizer
    • ReentrantReadWriteLock:与ReentrantLock没有关系,采用两把锁,用于读多写少的情形
  • 相关阅读:
    kotlin,短小精悍
    最近把Vue又看了下
    https://docs.spring.io/spring-framework/docs/current/reference/html/web-reactive.html#webflux-cors
    os模块——获取上层目录
    启动flask服务:flask run -h 0.0.0.0 -p 5000
    22端口和3389端口之我竟然用3389连接linux服务器,关键是我之前用22端口连接过linux!!!
    datetime 模块
    查看公网ip
    字典——删除元素
    docker端口映射
  • 原文地址:https://www.cnblogs.com/faunjoe88/p/7909668.html
Copyright © 2011-2022 走看看