javaSE_8系列博客——重要的基础Java类——多线程--1--宏观把控

来源:互联网 发布:数据公司 编辑:程序博客网 时间:2024/05/22 13:58

引言:

计算机用户认为他们的系统一次可以做一件以上的事情。他们假设他们可以继续在文字处理器中工作,而其他应用程序下载文件,管理打印队列和流音频。

通常,单个应用程序通常也会一次做一件事情。例如,流式音频应用程序必须同时从网络读取数字音频,解压缩,管理播放和更新其显示。即使文字处理器也应该随时准备好响应键盘和鼠标事件,无论重新格式化文本或更新显示器多么忙碌。可以做这些事情的软件被称为并发软件。

Java平台从根本上设计为支持并行编程,Java编程语言和Java类库中的基本并发支持。自5.0版本以来,Java平台还包括高级并发API。本课介绍了平台的基本并发支持,并总结了java.util.concurrent包中的一些高级API。

进程和线程

在并发编程中,有两个基本的执行单元:进程和线程。在Java编程语言中,并发编程主要关心线程。但是,进程也很重要。这个模块中,我们会介绍进程、线程以及他们之间的关系。

线程对象

每个线程与Thread类的实例相关联。我们将在该章节中深入了解Thread对象

线程的同步问题

线程主要通过共享对字段的访问和对象引用字段进行通信。这种形式的通信是非常有效的,但是使两种错误成为可能:线程干扰和内存一致性错误。防止这些错误所需的工具是同步。

活跃度

并发应用程序及时执行的能力被称为其活动。本节描述了最常见的活动问题,死锁,并简要介绍了另外两个活动问题,悲观锁和乐观锁

守卫块

线程通常必须协调他们的行动。最常见的协调成语是守卫块。这样的块通过轮询在块可以继续之前必须为真的条件开始。为了正确执行,需要遵循以下步骤。

不变对象

一个对象被认为是不可变的,如果它的状态在构造之后不能改变。对不可变对象的最大依赖被广泛接受为创建简单可靠的代码的良好策略。本章节,主要探讨咱们的不可变对象

高阶多线程

到目前为止,这一课已经集中在从一开始就是Java平台一部分的低级API。这些API对于非常基本的任务是足够的,但是对于更高级的任务,需要更高级的构建块。对于充分利用当今多处理器和多核系统的大规模并发应用程序尤其如此。

阅读全文
0 0