- 浏览: 194254 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
kjmmlzq19851226:
这个和排序米有关系吧
一个排好序的数组,找出两数之和为m的所有组合 -
ileson:
...
spring在web.xml中的配置
|
JavaTM Platform Standard Ed. 6 |
||||||||
上一个软件包 下一个软件包 |
软件包 java.util.concurrent
在并发编程中很常用的实用工具类。
请参见:
描述
BlockingDeque<E> |
支持两个附加操作的 空;存储元素时等待双端队列中的空间变得可用。 |
BlockingQueue<E> |
支持两个附加操作的 以及存储元素时等待空间变得可用。 |
Callable<V> | 返回结果并且可能抛出异常的任务。 |
CompletionService<V> | 将生产新的异步任务与使用已完成任务的结果分离开来的服务。 |
ConcurrentMap<K,V> | 提供其他原子 putIfAbsent、remove、replace 方法的 Map 。 |
ConcurrentNavigableMap<K,V> |
支持 |
Delayed | 一种混合风格的接口,用来标记那些应该在给定延迟时间之后执行的对象。 |
Executor | 执行已提交的 Runnable 任务的对象。 |
ExecutorService |
而生成 |
Future<V> | Future 表示异步计算的结果。 |
RejectedExecutionHandler | 无法由 ThreadPoolExecutor 执行的任务的处理程序。 |
RunnableFuture<V> | 作为 Runnable 的 Future 。 |
RunnableScheduledFuture<V> | 作为 Runnable 的 ScheduledFuture 。 |
ScheduledExecutorService | 一个 ExecutorService ,可安排在给定的延迟后运行或定期执行的命令。 |
ScheduledFuture<V> | 一个延迟的、结果可接受的操作,可将其取消。 |
ThreadFactory | 根据需要创建新线程的对象。 |
TimeUnit |
TimeUnit 表示给定单元粒度的时间段,它提供在这些单元中进行跨单元转换和执行计时及延迟操作的 实用工具方法。 |
BrokenBarrierException |
当某个线程试图等待处于断开状态的 barrier 时,或者 barrier 进入断开状态而线 程处于等待状态时,抛出该异常。 |
CancellationException |
如果某项值生成任务(如 抛出该异常。 |
ExecutionException | 当试图获取已通过抛出异常而中止的任务的结果时,抛出此异常。 |
RejectedExecutionException | 当无法执行某个任务时,由 Executor 抛出的异常。 |
TimeoutException | 阻塞操作超时时,抛出该异常。 |
软件包 java.util.concurrent 的描述
在并发编程中很常用的实用工具类。此包包括了几个小的、已标准化的可扩展框架,以及一些提供有用功能的类,没有这些
类,这些功能会很难实现或实现起来冗长乏味。下面简要描述主要的组件。另请参阅 locks 和 atomic 包。
执行程序
接口
Executor
是一个简单的标准化接口,用于定义类似于线程的自定义子系统,包括线程池、异步 IO 和轻量级任务框架。根据所使用的具体 Executor 类的不同,可能在新创建的线程中,现有的任务执行线程中,或者调用 execute() 的线程中
执行任务,并且可能顺序或并发执行。ExecutorService
提供了多个完整的异步任务执行框架。ExecutorService 管理
任务的排队和安排,并允许受控制的关闭。ScheduledExecutorService
子接口及相关的接口添加了对延迟的和定期任
务执行的支持。ExecutorService 提供了安排异步执行的方法,可执行由 Callable
表示的任何函数,结果类似于
Runnable
。Future
返回函数的结果,允许确定执行是否完成,并提供取消执行的方法。RunnableFuture
是拥有 run
方法的 Future,run 方法执行时将设置其结果。
实现
类 ThreadPoolExecutor
和 ScheduledThreadPoolExecutor
提供可调的、灵活的线程池。Executors
类提供大多
数 Executor 的常见类型和配置的工厂方法,以及使用它们的几种实用工具方法。其他基于 Executor 的实用工具包括具
体类 FutureTask
,它提供 Future 的常见可扩展实现,以及 ExecutorCompletionService
,它有助于协调对异步任
务组的处理。
队列
java.util.concurrent ConcurrentLinkedQueue
类提供了高效的、可伸缩的、线程安全的非阻塞 FIFO 队列。
java.util.concurrent 中的五个实现都支持扩展的 BlockingQueue
接口,该接口定义了 put 和 take 的阻塞版本:
LinkedBlockingQueue
、ArrayBlockingQueue
、SynchronousQueue
、PriorityBlockingQueue
和
DelayQueue
。这些不同的类覆盖了生产者-使用者、消息传递、并行任务执行和相关并发设计的大多数常见使用的上下
文。BlockingDeque
接口扩展 BlockingQueue,以支持 FIFO 和 LIFO(基于堆栈)操作。LinkedBlockingDeque
类提供一个实现。
计时
TimeUnit
类为指定和控制基于超时的操作提供了多重粒度(包括纳秒级)。该包中的大多数类除了包含不确定的等待之
外,还包含基于超时的操作。在使用超时的所有情况中,超时指定了在表明已超时前该方法应该等待的最少时间。在超时发
生后,实现会“尽力”检测超时。但是,在检测超时与超时之后再次实际执行线程之间可能要经过不确定的时间。接受超时
期参数的所有方法将小于等于 0 的值视为根本不会等待。要“永远”等待,可以使用 Long.MAX_VALUE 值。
同步器
四个类可协助实现常见的专用同步语句。Semaphore
是一个经典的并发工具。CountDownLatch
是一个极其简单但又极其
常用的实用工具,用于在保持给定数目的信号、事件或条件前阻塞执行。CyclicBarrier
是一个可重置的多路同步点,在
某些并行编程风格中很有用。Exchanger
允许两个线程在 collection 点交换对象,它在多流水线设计中是有用的。
并发 Collection
除队列外,此包还提供了设计用于多线程上下文中的 Collection 实现:ConcurrentHashMap
、
ConcurrentSkipListMap
、ConcurrentSkipListSet
、CopyOnWriteArrayList
和 CopyOnWriteArraySet
。当期
望许多线程访问一个给定 collection 时,ConcurrentHashMap 通常优于同步的 HashMap,ConcurrentSkipListMap
通常优于同步的 TreeMap。当期望的读数和遍历远远大于列表的更新数时,CopyOnWriteArrayList 优于同步的
ArrayList。
此包中与某些类一起使用的“Concurrent&rdquo前缀;是一种简写,表明与类似的“同步”类有所不同。例如,
java.util.Hashtable 和 Collections.synchronizedMap(new HashMap()) 是同步的,但 ConcurrentHashMap
则是“并发的”。并发 collection 是线程安全的,但是不受单个排他锁的管理。在 ConcurrentHashMap 这一特定情况
下,它可以安全地允许进行任意数目的并发读取,以及数目可调的并发写入。需要通过单个锁不允许对 collection 的所有
访问时,“同步”类是很有用的,其代价是较差的可伸缩性。在期望多个线程访问公共 collection 的其他情况中,通常
“并发”版本要更好一些。当 collection 是未共享的,或者仅保持其他锁时 collection 是可访问的情况下,非同步
collection 则要更好一些。
大多数并发 Collection 实现(包括大多数 Queue)与常规的 java.util 约定也不同,因为它们的迭代器提供了弱一致的,而不是快速失败的遍历。弱一致的迭代器是线程安全的,但是在迭代时没有必要冻结 collection,所以它不一定反映自迭代器创建以来的所有更新。
Java Language Specification 第 17 章定义了内存操作(如共享变量的读写)的 happen-before 关系。只有写入操作 happen-before 读取操作时,才保证一个线程写入的结果对另一个线程的读取是可视的。synchronized
和 volatile
构造 happen-before 关系,Thread.start()
和 Thread.join()
方法形成 happen-before 关系。尤其是:
- 线程中的每个操作 happen-before 稍后按程序顺序传入的该线程中的每个操作。
- 一个解除锁监视器的(
synchronized
阻塞或方法退出)happen-before 相同监视器的每个后续锁(synchronized
阻塞或方法进入)。并且因为 happen-before 关系是可传递的,所以解除锁定之前的线程的所有操作 happen-before 锁定该监视器的任何线程后续的所有操作。 - 写入
volatile
字段 happen-before 每个后续读取相同字段。volatile
字段的读取和写入与进入和退出监视器具有相似的内存一致性效果,但不 需要互斥锁。 - 在线程上调用
start
happen-before 已启动的线程中的任何线程。 - 线程中的所有操作 happen-before 从该线程上的
join
成功返回的任何其他线程。
java.util.concurrent
中所有类的方法及其子包扩展了这些对更高级别同步的保证。尤其是:
- 线程中将一个对象放入任何并发 collection 之前的操作 happen-before 从另一线程中的 collection 访问或移除该元素的后续操作。
- 线程中向
Executor
提交Runnable
之前的操作 happen-before 其执行开始。同样适用于向ExecutorService
提交Callables
。 - 异步计算(由
Future
表示)所采取的操作 happen-before 通过另一线程中Future.get()
获取结果后续的操作。 - “释放”同步储存方法(如
Lock.unlock
、Semaphore.release
和CountDownLatch.countDown
)之前的操作 happen-before 另一线程中相同同步储存对象成功“获取”方法(如Lock.lock
、Semaphore.acquire
、Condition.await
和CountDownLatch.await
)的后续操作。 - 对于通过
Exchanger
成功交换对象的每个线程对,每个线程中exchange()
之前的操作 happen-before 另一线程中对应exchange()
后续的操作。 - 调用
CyclicBarrier.await
之前的操作 happen-before 屏障操作所执行的操作,屏障操作所执行的操作 happen-before 从另一线程中对应await
成功返回的后续操作。
|
JavaTM Platform Standard Ed. 6 |
||||||||
上一个软件包 下一个软件包 |
发表评论
-
java对称加密算法的使用
2014-05-26 09:55 2822package utils; import java.io ... -
java使用ganymed-ssh2执行linux操作系统命令
2013-12-31 10:10 2069public static void main(Strin ... -
一个排好序的数组,找出两数之和为m的所有组合
2013-06-13 18:46 1544public static void main(Strin ... -
java中文API
2012-04-17 12:25 887http://www.oschina.net/home/api ... -
javase7官方API
2012-04-17 11:38 1133Java™ Platform, Standard Edit ... -
javase6中文API
2012-04-01 20:15 2499概述 软件包 类 使用 ... -
javase6官方API
2012-04-01 20:10 991Overview Package C ... -
java.util.concurrent官方API文档
2012-04-01 20:03 1958Overview Package C ... -
java.util.concurrent介绍(转)
2012-04-01 19:33 1009本文由 cnblogs 博主 ... -
JDK6下开发WebService
2012-03-17 09:06 1577周末闲来无事,在家中复习了一下JDK6下开发WebServi ... -
日期正则表达式
2012-01-13 17:58 1136一、简单的 日期判断(YYYY/MM/DD):^\d{4 ... -
使用JAVA API上传文件到FTP服务器
2011-12-02 12:41 1212private void FtpUpload() throw ... -
Java发送邮件
2011-11-04 17:24 964import java.io.UnsupportedEncod ... -
POI导入Excel
2011-11-04 16:34 1214import java.beans.BeanInfo;impo ... -
使用JAVA API从FTP服务器下载文件
2011-11-04 16:28 1784import java.io.IOException; im ... -
Java读取Properties文件
2011-11-04 16:06 795使用J2SE API读取Properties文件的六种方法 ... -
java获取服务器IP
2011-10-27 12:04 1256java.net.InetAddress.getLocalHo ... -
java 获取真实客户端IP(转载)
2011-10-27 11:33 2257原文出处:http://jun-li-leo.iteye. ... -
JDBC连接字符串
2011-10-26 11:17 21401. MySQL Class.forName(&quo ... -
java中filter的用法
2011-10-19 11:45 992filter过滤器主要使用于前台向后台传递数据是的过滤操作。程 ...
相关推荐
java.util.concurrent.Callable API介绍和简单案例
java.util.concurrent.BlockingDeque API介绍和简单案例
`java.util.concurrent.ExecutionException` 是Java并发编程中一个常见的异常,通常在执行Future对象的get()方法时抛出。这个异常表明在异步任务的执行过程中发生了异常。当我们使用ExecutorService提交任务并尝试...
Java.util.concurrent(JUC)是Java平台中的一个核心包,专门用于处理多线程并发问题。这个包包含了大量的工具类和接口,极大地简化了并发编程的复杂性,提高了程序的性能和可伸缩性。本测试源文件主要是针对JUC并发...
- [Java SE 8 文档](https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/ConcurrentHashMap.html):提供了 `ConcurrentHashMap` 的官方 API 文档。 - [Doug Lea 的个人网站]...
Java.util.concurrent包(虽然不是直接在Java.util下,但密切相关)包含了一系列线程安全的数据结构和并发工具,如Semaphore、ExecutorService、CountDownLatch等,极大地简化了多线程编程。 8. **枚举Set**: ...
Java的`java.util.concurrent`包提供了丰富的线程工具,如`ExecutorService`、`Semaphore`、`CountDownLatch`等,帮助开发者高效地管理和控制并发。 以上各个模块的知识点相互独立,但又经常协同工作,共同构成了...
java.util.concurrent.locks 为锁和等待条件提供一个框架的接口和类,它不同于内置同步和监视器。 java.util.jar 提供读写 JAR (Java ARchive) 文件格式的类,该格式基于具有可选清单文件的标准 ZIP 文件格式。 ...
5. **版本控制和兼容性**:如果是由于API升级导致的不兼容问题,考虑回滚到旧版本的API,或者更新你的客户端代码以适应新版本的API结构。 6. **日志记录**:为了调试和排查问题,确保你的应用有完善的日志记录机制...
Java 6 API中文版是Java开发人员的重要参考资料,它提供了详细的类库文档,使得开发者能够更好地理解和使用Java平台的标准类库。这个API文档是中文语言版本,方便了中文用户阅读和学习,避免了语言障碍,提高了开发...
Java API支持多线程编程,`java.lang.Thread`类和`java.util.concurrent`包提供了丰富的同步和并发工具。`Runnable`接口和`Thread`类结合可以创建并运行线程,`synchronized`关键字用于同步访问,`Semaphore`、`...
3. **多线程**:Java 支持多线程编程,通过 `java.lang.Thread` 类和 `java.util.concurrent` 包,开发者可以创建和管理并发任务。`java.util.concurrent` 包提供了一些高级并发工具,如 Executor、Semaphore 和 ...
这个"JAVA-API.rar"压缩包包含了官方的Java API中文版,是学习和理解Java语言的重要参考资料。 在Java API中,我们可以找到以下关键知识点: 1. **类库**: Java API包含了大量的类库,如`java.lang`、`java.util`...
Java API中文版是一个重要的资源,对于学习和理解Java编程语言的开发者来说,它提供了一种中文语言环境下的接口文档,帮助我们更好地理解和使用Java提供的各种类库和功能。本文将详细探讨Java API及其在编程中的关键...
6. **多线程(Multithreading)**:Java API提供了丰富的多线程支持,包括`java.lang.Thread`类和`java.util.concurrent`包中的高级并发工具。 7. **I/O流(Input/Output Stream)**:Java的I/O系统由`java.io`包...
Java API文档中文版是Java开发人员的重要参考资料,它详尽地介绍了Java平台标准版(Java SE)中的类库、接口、方法以及各种编程规范。这个文档以CHM(Compiled HTML Help)格式提供,便于离线查阅和快速检索。CHM是...
23. **`java.util.concurrent.locks.Lock`** 和 **`java.util.concurrent.locks.ReentrantLock`**: 锁机制,用于线程同步。 24. **`java.util.ArrayList`**: 用于创建堆栈、队列和双端队列的实现,如`ArrayDeque`。...
13. **功能接口**:`java.util.Function`、`java.util.Consumer`、`java.util.Predicate`等接口是函数式编程的重要组成部分,常用于Lambda表达式和流API。 14. **Stream API**:Java 8引入的Stream API是一种声明式...
这个"JAVA-API.rar"压缩包提供了官方的Java API中文文档,使得开发者在学习和使用Java时能更加方便地理解各种类、接口、方法及其用法。 Java API文档主要分为以下几个部分: 1. **类和接口**:API文档详细列出了...