zoukankan      html  css  js  c++  java
  • java.util.concurrent包的分析

           我们都知道java并发包下的一些东西总是包含着许多比较有意思的东西。但是其实有很多人还是很少用到其中的一些东西。而且有时,某些企业的招聘就要求掌握java.util.concurrent包下的类。下面,我将本人今天截的图片作为线索,带领大家一步一步了解这块神秘的知识。

           



    图片纯手工制作比较简陋,大体如上。下面从concurrent父目录下的东西开始介绍。concurrent包下东西给我感觉就是有点杂乱五章,信号量的类也放在里面,还有ConcurrentHashMap.class,个人感觉应该把信号量的类归入Lock目录下。在这个类里面有一个平常听得比较多的是BlockingQueue这个类,我们看看他是怎么实现。


    真正实现的的核心为下


    很灵活的调用了await()和signal()方法对换成区的读写做控制。好然后再看一下CopyOnWriteArrayList的实现,这个估计很多人已经猜到了,无非就是加个锁嘛,


    最后提一下在这个父母下有2个被人们遗忘的类,分别为CountDownLatch, CyclicBarrir,java.util.concurrent的下面的一些其他类如下:



    下面我们来介绍java,util.concurrent下的atomic包下的一些东西,这个包下的东西都比较清一色,所以我简单介绍其中的一个,其他的类基本是一样的。


    执行操作的时的关键看清楚了,


    其他类同上,就不介绍了。最后将一下Concurrent下的Lock目录下的一些锁相关的东西:

    我们主要看一下其中重入锁的实现是怎么样的,

    重入锁的Sync变量时一个很让人难以理解的变量,个人看了源代码之后的理解是,只要调用了类似tryLock()等申请锁的方法,首先判断是否是当前线程,不是怎么不改变状态,如果是当前线程则,调用CompareAndSwapState()底层方法,并且状态的值是上次的累加上这次的传入的,下面给出代码,不知道我的理解对不对。

    这确实让我很难理解。

    好了以上就是我对Concurrent包的简单分析,下午做图片到时搞了很长时间,文字到写的不是很多。


  • 相关阅读:
    bzoj3505 数三角形 组合计数
    cogs2057 殉国 扩展欧几里得
    cogs333 荒岛野人 扩展欧几里得
    bzoj1123 BLO tarjan求点双连通分量
    poj3352 road construction tarjan求双连通分量
    cogs1804 联合权值 dp
    cogs2478 简单的最近公共祖先 树形dp
    cogs1493 递推关系 矩阵
    cogs2557 天天爱跑步 LCA
    hdu4738 Caocao's Bridge Tarjan求割边
  • 原文地址:https://www.cnblogs.com/bianqi/p/12184322.html
Copyright © 2011-2022 走看看