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向他的左边靠,他们还是阻塞了对方。 

目录
相关文章
|
5天前
|
SQL Oracle 安全
免费 Oracle 各版本 离线帮助使用和介绍
免费 Oracle 各版本 离线帮助使用和介绍
15 2
|
Oracle 架构师 Java
80%的Oracle JDK用户正在寻找免费的替代品!!!
在 2019 年,Oracle 决定更改许可模式,从提供免费的 Java 更新转变为要求付费订阅(见:JDK 11 是发布了,但收费吗?),这一重大变化无疑在市场上掀起了一片波澜。
|
Oracle 关系型数据库 索引
ORACLE常见问题一千问(提供下载)(不怕学不成、就怕心不诚!)
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/chinahuyong/article/details/6543516 ORACLE常见问题一千问(提供下载) (不怕学不成、就怕心不诚!) ——通过知识共享树立个人品牌。
1341 1
|
存储 Oracle 关系型数据库
《Oracle达人修炼秘籍:Oracle 11g数据库管理与开发指南 》一1.7 数据库系统设计步骤
本节书摘来自华章出版社《Oracle达人修炼秘籍:Oracle 11g数据库管理与开发指南 》一书中的第1章,第1.7节,作者孙风栋 王澜,更多章节内容可以访问云栖社区“华章计算机”公众号查看
1968 0
|
Oracle 关系型数据库
|
Oracle Java 关系型数据库
|
Oracle 关系型数据库 Java

推荐镜像

更多