个人简介

Echo Blog


江湖无名 安心练剑
  • JUC-05-Unsafe
    Unsafe类详解 Unsafe类就和它的名字一样,是一个比较危险的类,它主要用于执行低级别、不安全的方法。 尽管这个类和所有的方法都是公开的(public),但是这个类的使用仍然受限,你无法在自己的java程序中直接使用该类,因为只有授信的代码才能获得该类的实例。 方法分类 Unsafe API的大部分方法都是native实现,它由105个方法组成,主要包括以下几类: (1)In...
    2019-01-20 06:10:12 | Concurrency
  • JUC-04-Striped64
    数据 striping 在计算机数据存储中,数据条带化是分割逻辑顺序数据(例如文件)的技术,以便连续的段存储在不同的物理存储设备上。 当处理设备比单个存储设备提供数据更快地请求数据时,条带化非常有用。 通过在可以同时访问的多个设备上分布段,增加了总数据吞吐量。 它也是平衡磁盘阵列中I/O负载的有用方法。 条带化用于独立磁盘冗余阵列(RAID)存储中的磁盘驱动器,网络接口控制器,集群文...
    2019-01-20 06:10:12 | Concurrency
  • JUC-03-LongAdder
    LongAdder LongAdder中会维护一个或多个变量,这些变量共同组成一个long型的“和”。当多个线程同时更新(特指“add”)值时,为了减少竞争,可能会动态地增加这组变量的数量。“sum”方法(等效于longValue方法)返回这组变量的“和”值。 当我们的场景是为了统计技术,而不是为了更细粒度的同步控制时,并且是在多线程更新的场景时,LongAdder类比AtomicLon...
    2019-01-20 06:10:12 | Concurrency
  • JUC-02-AtomicLong 使用入门及源码详解
    AtomicLong 介绍 可以原子更新的 Long 值。 AtomicLong用于诸如原子递增的序列号之类的应用程序中,并且不能用作Long的替代品。 但是,此类确实扩展了Number,以允许通过处理基于数字的类的工具和实用程序进行统一访问。 API 直接查阅 JDK Doc AtomicLong 与 Long 的区别 这两个对象之间存在显着差异,虽然最终结果是相同的,但...
    2019-01-20 06:10:12 | Concurrency
  • JUC-02-AtomicInterger 原子性整型源码详解
    AtomicInterger 介绍 可以原子性更新的 Integer 值,当然这个类并不能完全替代 Integer 对象。 使用 使用起来还是很方便的。 比如说我们定义一个计数器,使用 AtomicInteger 可以同时兼顾性能与并发安全。 import java.util.concurrent.atomic.AtomicInteger; /** * @author bi...
    2019-01-20 06:10:12 | Concurrency
  • JUC-02-AtomicReference 对象原子性更新
    AtomicReference 介绍 可以原子性更新的引用值。 源码学习 类定义 AtomicReference 和 AtomicInteger 比较类似。 都有 Unsafe 属性,和一个对应的值偏移量。 区别就是此处的 value 是通过 volatile 关键字修饰的变量。 public class AtomicReference<V> implements ...
    2019-01-20 06:10:12 | Concurrency
  • JUC-01-Atomic 原子性
    原子性 原子是世界上的最小单位,具有不可分割性。 比如 a=0;(a非long和double类型) 这个操作是不可分割的,那么我们说这个操作时原子操作。 再比如:a++; 这个操作实际是a = a + 1;是可分割的,所以他不是一个原子操作。非原子操作都会存在线程安全问题,需要我们使用同步技术(sychronized)来让它变成一个原子操作。一个操作是原子操作,那么我们称它具有原子性。...
    2019-01-20 06:10:12 | Concurrency
  • JUC-00-JUC 目录,java 集合汇总
    JUC java.util.concurrent 是 java 为并发提供的强大的工具包。 本文将整理学习常见的类,API,适用场景,源码。 重点是类本身,并发和 jmm 将在其他系列学习。 Arrays Array是Java特有的数组。在你知道所要处理数据元素个数的情况下非常好用。java.util.Arrays 包含了许多处理数据的实用方法: Arrays.asList:可以...
    2019-01-20 06:10:12 | Concurrency