自问自答

本文介绍了Java并发编程中常用的并发类,包括ConcurrentHashMap、CopyOnWriteArrayList等,并对比了同步与异步的区别,还涉及数据库优化、大型网站架构及多线程等内容。

1. 常用并发类:

    util.concurrent中容器在迭代时,可以不封装在synchronized中,可以保证不抛异常,但是未必每次看到的都是"最新的、当前的"数据。

    1). ConcurrentHashMap代替同步的Map(Collections.synchronized(new HashMap())),众所周知,HashMap是根据散列值分段存储的,同步Map在同步的时候锁住了所有的段,而ConcurrentHashMap

         加锁的时候根据散列值锁住了散列值锁对应的那段,因此提高了并发性能。ConcurrentHashMap也增加了对常用复合操作的支持,比如"若没有则添加":putIfAbsent(),替换:replace()。这2个操作都是原子操作。

  2). CopyOnWriteArrayList和CopyOnWriteArraySet分别代替List和Set,主要是在遍历操作为主的情况下来代替同步的List和同步的Set,这也就是上面所述的思路:迭代过程要保证不出错,除了加锁,另外一种方法就是"克隆"容器对象。

    3). ConcurrentLinkedQuerue是一个先进先出的队列。它是非阻塞队列。

    4). ConcurrentSkipListMap可以在高效并发中替代SoredMap(例如用Collections.synchronzedMap包装的TreeMap)。

    5). ConcurrentSkipListSet可以在高效并发中替代SoredSet(例如用Collections.synchronzedSet包装的TreeMap)。

    6). AtomicLong、AtomicInteger

    7). Lock

    8). volatile关键字解析

    9). ThreadLocal

    10). 同步容器

     11). Java ConcurrentModificationException异常原因和解决方法

     12). 阻塞队列

     13). 线程池的使用

     14). CountDownLatch、CyclicBarrier和Semaphore

     15). Callable、Future和FutureTask

     16). Timer和TimerTask

2. 多线程:

    1). 同步和异步着重点在于多个任务的执行过程中,一个任务的执行是否会导致整个流程的暂时等待;而阻塞和非阻塞着重点在于发出一个请求操作时,如果进行操作的条件不满足是否会返会一个标志信息告知条件不满足。

    2). 线程池比较适合大量的短连接应用。

    3). 多路复用IO就是采用Reactor模式。注意,上面的图中展示的 是顺序处理每个事件,当然为了提高事件处理速度,可以通过多线程或者线程池的方式来处理事件。

         在Proactor模式中,当检测到有事件发生时,会新起一个异步操作,然后交由内核线程去处理,当内核线程完成IO操作之后,发送一个通知告知操作已完成,可以得知,异步IO模型采用的就是Proactor模式。

    详见:http://www.cnblogs.com/dolphin0520/p/3916526.html

3. 数据库优化,SQL优化

4. 大型网站架构

5. Spring

6. Spring MVC

7. Struts

8. mybatis

9. redis

10. 多线程

11. NIO

 

转载于:https://www.cnblogs.com/Jtianlin/p/5235082.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值