zoukankan      html  css  js  c++  java
  • java concurrent包的学习(转)

    java concurrent包的学习(转)

    http://my.oschina.net/adwangxiao/blog/110188

     我们都知道,在JDK1.5之前,Java中要进行业务并发时,通常需要有程序员独立完 成代码实现,当然也有一些开源的框架提供了这些功能,但是这些依然没有JDK自带的功能使用起来方便。而当针对高质量Java多线程并发程序设计时,为防 止死蹦等现象的出现,比如使用java之前的wait()、notify()和synchronized等,每每需要考虑性能、死锁、公平性、资源管理以 及如何避免线程安全性方面带来的危害等诸多因素,往往会采用一些较为复杂的安全策略,加重了程序员的开发负担.万幸的是,在JDK1.5出现之后,Sun 大神(Doug Lea)终于为我们这些可怜的小程序员推出了java.util.concurrent工具包以简化并发完成。开发者们借助于此,将有效的减少竞争条件 (race conditions)和死锁线程。concurrent包很好的解决了这些问题,为我们提供了更实用的并发程序模型。


    Executor                  :具体Runnable任务的执行者。
    ExecutorService           :一个线程池管理者,其实现类有多种,我会介绍一部分。我们能把Runnable,Callable提交到池中让其调度。
    Semaphore                 :一个计数信号量
    ReentrantLock             :一个可重入的互斥锁定 Lock,功能类似synchronized,但要强大的多。
    Future                    :是与Runnable,Callable进行交互的接口,比如一个线程执行结束后取返回的结果等等,还提供了cancel终止线程。
    BlockingQueue             :阻塞队列。
    CompletionService         : ExecutorService的扩展,可以获得线程执行结果的
    CountDownLatch            :一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待。
    CyclicBarrier             :一个同步辅助类,它允许一组线程互相等待,直到到达某个公共屏障点
    Future                    :Future 表示异步计算的结果。
    ScheduledExecutorService :一个 ExecutorService,可安排在给定的延迟后运行或定期执行的命令。 

    定制并发类(五)在一个Executor对象中使用我们的ThreadFactory

    http://ifeve.com/customizing-concurrency-classes-5/

    【签名→→→】【****知其然知其所以然****】 工具只能帮助我们解决我们认识到的问题,解决不了我们都没理解的问题。 不能再把一切扔给框架、容器、工具! 首先理解你的业务逻辑,理解你要实现的功能, 然后搞清楚框架、容器、工具会帮助我们做什么。 只有理解了自己的业务逻辑,理解了自己的代码,理解了自己要用到的第三方代码, 才能真正完美地实现我们需要的功能!
  • 相关阅读:
    [HNOI2002]营业额统计
    HDU 1374
    HDU 3345
    HDU 2089
    Graham扫描法
    Codeforces 1144D Deduction Queries 并查集
    Codeforces 916E Jamie and Tree 线段树
    Codeforces 1167F Scalar Queries 树状数组
    Codeforces 1167E Range Deleting
    Codeforces 749E Inversions After Shuffle 树状数组 + 数学期望
  • 原文地址:https://www.cnblogs.com/yaowukonga/p/3488531.html
Copyright © 2011-2022 走看看