Oracle官方并发教程之活跃度

简介:

原文地址译文地址,译者:李任,郑旭东 校对:蘑菇街-小宝

一个并发应用程序能及时执行的能力称为活跃性。本节将介绍最常见的活跃性问题:死锁(deadlock),以及另外两个活跃性问题:饥饿(starvation)和活锁(livelock)。

死锁

原文地址

死锁描述了这样一种情景,两个或多个线程永久阻塞,互相等待对方释放资源。下面是一个例子。

Alphone和Gaston是朋友,都很讲究礼节。礼节有一个严格的规矩,当你向一个朋友鞠躬时,你必须保持鞠躬的姿势,直到你的朋友有机会回鞠给你。不幸的是,这个规矩没有算上两个朋友相互同时鞠躬的可能。

下面的应用例子,DeadLock,模拟了这个可能性。

01    static class Friend {
02         private final String name;
03         public Friend(String name) {
04             this.name = name;
05         }
06         public String getName() {
07             return this.name;
08         }
09         public synchronized void bow(Friend bower) {
10             System.out.format("%s: %s"
11                 "  has bowed to me!%n",
12                 this.name, bower.getName());
13             bower.bowBack(this);
14         }
15         public synchronized void bowBack(Friend bower) {
16             System.out.format("%s: %s"
17                 " has bowed back to me!%n",
18                 this.name, bower.getName());
19         }
20     }
21  
22     public static void main(String[] args) {
23         final Friend alphonse =
24             new Friend("Alphonse");
25         final Friend gaston =
26             new Friend("Gaston");
27         new Thread(new Runnable() {
28             public void run() { alphonse.bow(gaston); }
29         }).start();
30         new Thread(new Runnable() {
31             public void run() { gaston.bow(alphonse); }
32         }).start();
33     }
34 }

当DeadLock运行后,两个线程极有可能阻塞,当它们尝试调用bowBack方法时。没有哪个阻塞会结束,因为每个线程都在等待另一个线程退出bow方法。

饥饿和活锁

原文地址

饥饿和活锁并不如死锁一般普遍,但它仍然是每个并发程序设计者可能会遇到的问题。

饥饿

饥饿是指当一个线程不能正常的访问共享资源并且不能正常执行的情况。这通常在共享资源被其他“贪心”的线程长期时发生。举个例子,假设一个对象提供了一个同步方法,这个方法通常需要执行很长一段时间才返回。如果一个线程经常调用这个方法,那么其他需要同步的访问这个对象的线程就经常会被阻塞。

活锁

一个线程通常会有会响应其他线程的活动。如果其他线程也会响应另一个线程的活动,那么就有可能发生活锁。同死锁一样,发生活锁的线程无法继续执行。然而线程并没有阻塞——他们在忙于响应对方无法恢复工作。这就相当于两个在走廊相遇的人:Alphonse向他自己的左边靠想让Gaston过去,而Gaston向他的右边靠想让Alphonse过去。可见他们阻塞了对方。Alphonse向他的右边靠,而Gaston向他的左边靠,他们还是阻塞了对方。

文章转自 并发编程网-ifeve.com

目录
相关文章
|
1月前
|
Oracle 关系型数据库 数据库
|
6月前
|
Oracle 关系型数据库 数据库
百度搜索:蓝易云【docker部署并配置oracle12c的cdb和pdb教程!】
以上是使用Docker部署和配置Oracle 12c CDB和PDB的简要教程。请注意,这只是一个概述,并且可能需要根据你的实际情况进行适当的调整和配置。建议参考Oracle官方文档和相关资源,以获得更详细和全面的指导。
104 2
|
2月前
|
Oracle 关系型数据库 数据处理
某教程学习笔记(一):10、oracle数据库注入
某教程学习笔记(一):10、oracle数据库注入
17 0
|
4月前
|
Oracle 关系型数据库 数据库
windows Oracle Database 19c 卸载教程
打开任务管理器 ctrl+Shift+Esc可以快速打开任务管理器,找到oracle所有服务然后停止。 停止数据库服务 在开始卸载之前,确保数据库服务已经停止。你可以使用以下命令停止数据库服务: net stop OracleServiceORCL Universal Installer 卸载Oracle数据库程序 一般情况运行Oracle自带的卸载程序,如使用Universal Installer 工具卸载。 点击开始菜单找到Oracle,然后点击Oracle安装产品,再点击Universal Installer。 点击之后稍等一会然后会进入进入下图界面,点击卸载产品。 选中要删除的Orac
118 1
|
8月前
|
SQL Oracle 关系型数据库
Win11虚拟机安装Oracle 19c(保姆教程)
Oracle学习笔记 Oracle19c Windows11 instant client配置 远程连接 虚拟机
Win11虚拟机安装Oracle 19c(保姆教程)
|
9月前
|
Oracle 关系型数据库 数据库连接
Oracle 11g安装配置完美教程 - Windows(下)
Oracle 11g安装配置完美教程 - Windows(下)
154 0
|
9月前
|
SQL Oracle 安全
Oracle 11g安装配置完美教程 - Windows(上)
Oracle 11g安装配置完美教程 - Windows
739 0
|
Oracle 关系型数据库 Java
|
关系型数据库 Oracle
|
Oracle 关系型数据库 Java

推荐镜像

更多