真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

java寫一段死鎖代碼,java死鎖的簡單例子

java線程死鎖

// 我不想分析你的問題,但是我發(fā)一段我寫的死鎖代碼

我們提供的服務(wù)有:網(wǎng)站設(shè)計制作、做網(wǎng)站、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、榆林ssl等。為超過千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的榆林網(wǎng)站制作公司

package com.demo;

public class DeadLock implements Runnable{

//測試死鎖的例子;

//聲明兩個KEY;用于加鎖使用;

private static final String KEY1="KEY1";

private static final String KEY2="KEY2";

private boolean lock;

public DeadLock(boolean lock){

this.lock = lock;

//調(diào)用boolean true|false 賦值給lock進行判斷key1和key2;

}

public void run(){

if(lock){

synchronized(KEY1){//第一次鎖KEY1

try{

Thread.sleep(3000);

}catch(Exception e){

}

System.out.println("給我KEY2我要使用!");

synchronized(KEY2){//第二次鎖KEY2

System.out.println("我拿到KEY2運行結(jié)束!");

}

}

}else{

synchronized(KEY2){//第一次鎖KEY2

try{

Thread.sleep(3000);

}catch(Exception e){

}

System.out.println("Give me KEY1,I will use!");

synchronized(KEY1){//第二次鎖KEY1

System.out.println("我拿到KEY1運行結(jié)束!");

}

}

}

}

public static void main(String args[]){

new Thread(new DeadLock(true)).start();

new Thread(new DeadLock(false)).start();

}

}

java 死鎖

死鎖

死鎖是這樣一種情形:多個線程同時被阻塞,它們中的一個或者全部都在等待某個資源被釋放。由于線程被無限期地阻塞,因此程序不可能正常終止。

導(dǎo)致死鎖的根源在于不適當(dāng)?shù)剡\用“synchronized”關(guān)鍵詞來管理線程對特定對象的訪問。“synchronized”關(guān)鍵詞的作用是,確保在某個時刻只有一個線程被允許執(zhí)行特定的代碼塊,因此,被允許執(zhí)行的線程首先必須擁有對變量或?qū)ο蟮呐潘缘脑L問權(quán)。當(dāng)線程訪問對象時,線程會給對象加鎖,而這個鎖導(dǎo)致其它也想訪問同一對象的線程被阻塞,直至第一個線程釋放它加在對象上的鎖。

由于這個原因,在使用“synchronized”關(guān)鍵詞時,很容易出現(xiàn)兩個線程互相等待對方做出某個動作的情形。代碼一是一個導(dǎo)致死鎖的簡單例子。

//代碼一

class Deadlocker {

int field_1;

private Object lock_1 = new int[1];

int field_2;

private Object lock_2 = new int[1];

public void method1(int value) {

“synchronized” (lock_1) {

“synchronized” (lock_2) {

field_1 = 0; field_2 = 0;

}

}

}

public void method2(int value) {

“synchronized” (lock_2) {

“synchronized” (lock_1) {

field_1 = 0; field_2 = 0;

}

}

}

}

參考代碼一,考慮下面的過程:

◆ 一個線程(ThreadA)調(diào)用method1()。

◆ ThreadA在lock_1上同步,但允許被搶先執(zhí)行。

◆ 另一個線程(ThreadB)開始執(zhí)行。

◆ ThreadB調(diào)用method2()。

◆ ThreadB獲得lock_2,繼續(xù)執(zhí)行,企圖獲得lock_1。但ThreadB不能獲得lock_1,因為ThreadA占有l(wèi)ock_1。

◆ 現(xiàn)在,ThreadB阻塞,因為它在等待ThreadA釋放lock_1。

◆ 現(xiàn)在輪到ThreadA繼續(xù)執(zhí)行。ThreadA試圖獲得lock_2,但不能成功,因為lock_2已經(jīng)被ThreadB占有了。

◆ ThreadA和ThreadB都被阻塞,程序死鎖。

當(dāng)然,大多數(shù)的死鎖不會這么顯而易見,需要仔細分析代碼才能看出,對于規(guī)模較大的多線程程序來說尤其如此。好的線程分析工具,例如JProbe Threadalyzer能夠分析死鎖并指出產(chǎn)生問題的代碼位置。

隱性死鎖

隱性死鎖由于不規(guī)范的編程方式引起,但不一定每次測試運行時都會出現(xiàn)程序死鎖的情形。由于這個原因,一些隱性死鎖可能要到應(yīng)用正式發(fā)布之后才會被發(fā)現(xiàn),因此它的危害性比普通死鎖更大。下面介紹兩種導(dǎo)致隱性死鎖的情況:加鎖次序和占有并等待。

加鎖次序

當(dāng)多個并發(fā)的線程分別試圖同時占有兩個鎖時,會出現(xiàn)加鎖次序沖突的情形。如果一個線程占有了另一個線程必需的鎖,就有可能出現(xiàn)死鎖??紤]下面的情形,ThreadA和ThreadB兩個線程分別需要同時擁有l(wèi)ock_1、lock_2兩個鎖,加鎖過程可能如下:

◆ ThreadA獲得lock_1;

◆ ThreadA被搶占,VM調(diào)度程序轉(zhuǎn)到ThreadB;

◆ ThreadB獲得lock_2;

◆ ThreadB被搶占,VM調(diào)度程序轉(zhuǎn)到ThreadA;

◆ ThreadA試圖獲得lock_2,但lock_2被ThreadB占有,所以ThreadA阻塞;

◆ 調(diào)度程序轉(zhuǎn)到ThreadB;

◆ ThreadB試圖獲得lock_1,但lock_1被ThreadA占有,所以ThreadB阻塞;

◆ ThreadA和ThreadB死鎖。

必須指出的是,在代碼絲毫不做變動的情況下,有些時候上述死鎖過程不會出現(xiàn),VM調(diào)度程序可能讓其中一個線程同時獲得lock_1和lock_2兩個鎖,即線程獲取兩個鎖的過程沒有被中斷。在這種情形下,常規(guī)的死鎖檢測很難確定錯誤所在。

占有并等待

如果一個線程獲得了一個鎖之后還要等待來自另一個線程的通知,可能出現(xiàn)另一種隱性死鎖,考慮代碼二。

//代碼二

public class queue {

static java.lang.Object queueLock_;

Producer producer_;

Consumer consumer_;

public class Producer {

void produce() {

while (!done) {

“synchronized” (queueLock_) {

produceItemAndAddItToQueue();

“synchronized” (consumer_) {

consumer_.notify();

}

}

}

}

public class Consumer {

consume() {

while (!done) {

“synchronized” (queueLock_) {

“synchronized” (consumer_) {

consumer_.wait();

}

removeItemFromQueueAndProcessIt();

}

}

}

}

}

}

在代碼二中,Producer向隊列加入一項新的內(nèi)容后通知Consumer,以便它處理新的內(nèi)容。問題在于,Consumer可能保持加在隊列上的鎖,阻止Producer訪問隊列,甚至在Consumer等待Producer的通知時也會繼續(xù)保持鎖。這樣,由于Producer不能向隊列添加新的內(nèi)容,而Consumer卻在等待Producer加入新內(nèi)容的通知,結(jié)果就導(dǎo)致了死鎖。

在等待時占有的鎖是一種隱性的死鎖,這是因為事情可能按照比較理想的情況發(fā)展—Producer線程不需要被Consumer占據(jù)的鎖。盡管如此,除非有絕對可靠的理由肯定Producer線程永遠不需要該鎖,否則這種編程方式仍是不安全的。有時“占有并等待”還可能引發(fā)一連串的線程等待,例如,線程A占有線程B需要的鎖并等待,而線程B又占有線程C需要的鎖并等待等。

要改正代碼二的錯誤,只需修改Consumer類,把wait()移出“synchronized”()即可。

java 多線程 死鎖

public class TestDeadLock implements Runnable {

public int flag = 1;

static Object o1 = new Object(), o2 = new Object();

public void run() {

System.out.println("flag=" + flag);

if(flag == 1) {

synchronized(o1) {

try {

Thread.sleep(500);

} catch (Exception e) {

e.printStackTrace();

}

synchronized(o2) {

System.out.println("1");

}

}

}

if(flag == 0) {

synchronized(o2) {

try {

Thread.sleep(500);

} catch (Exception e) {

e.printStackTrace();

}

synchronized(o1) {

System.out.println("0");

}

}

}

}

public static void main(String[] args) {

TestDeadLock td1 = new TestDeadLock();

TestDeadLock td2 = new TestDeadLock();

td1.flag = 1;

td2.flag = 0;

Thread t1 = new Thread(td1);

Thread t2 = new Thread(td2);

t1.start();

t2.start();

}

}

這個夠簡約吧,兩個對象互相依賴,所以死鎖!

java -線程 -演示死鎖的代碼 main函數(shù)里面要怎么寫 具體如下:

大概寫了一個例子,給你看看,你的那個例子來搞死鎖比較難搞,主要你是只有一個鎖,沒有所謂的請求不釋放的問題,一般死鎖都需要有兩個鎖或以上的。

public class TestT {

public static void main(String[] args) {

for (int i = 0; i 10; i ++) {

NumThread nt = new NumThread(1,2);

NumThread nt2 = new NumThread(2,1);

nt.start();

nt2.start();

}

}

}

class NumThread extends Thread{

private int a;

private int b;

public NumThread(int a,int b) {

this.a = a;

this.b = b;

}

public void run() {

synchronized(Integer.valueOf(a)) {

System.out.println("xxx" + Thread.currentThread().getName());

synchronized(Integer.valueOf(b)) {

System.out.println("yyy" + Thread.currentThread().getName());

}

}

}

}

這個例子首先需要先了解Integer類的機制,再進行Integer類實例化或轉(zhuǎn)換時,它會緩存-128-127之間的所有對象,因此在這里我們,調(diào)用的1,2至始至終都只有兩個對象。

下面就是死鎖的分析:

當(dāng)我們執(zhí)行NumThread(1,2)時,鎖的取得沒問題(Integer.valueOf(a)的鎖肯定沒問題),接下來用NumThread(2,1),如果此時NumThread(1,2)已經(jīng)取得了兩個鎖,這里沒問題,執(zhí)行完后可以繼續(xù)取得鎖,但如果NumThread(1,2)只取得a的鎖,而此時NumThread(2,1)取得了b的鎖,這時問題就來了。NumThread(1,2)會等待NumThread(2,1)釋放b鎖,而NumThread(2,1)會等等NumThread(1,2)釋放a鎖。

我用了一個循環(huán)啟動線程是因為發(fā)生的機率不大。

可以引伸到你那個例子,用兩個相同的對象作為鎖。

public class TestT {

public static void main(String[] args) {

S s = new S();

S s2 = new S();

for (int i = 0; i 10; i ++) {

TestSleep ts = new TestSleep(s,s2);

TestSleep ts2 = new TestSleep(s2,s);

ts.start();

ts2.start();

}

}

}

class S{public int i=0;}

class TestSleep extends Thread {

/**

* @param args

*/

private S s=null;

private S s2 = null;

public TestSleep(S s,S s2){

this.s=s;

this.s2=s2;

}

public void run(){

System.out.println("Now is begin Thread-A");

synchronized(s){

System.out.println("Now is begin "+Thread.currentThread().getName());

synchronized(s2) {

System.out.println(s.i);

}

}

}

}

java產(chǎn)生死鎖原因,代碼如下。

你這個不是死鎖,就是flag的判斷有問題,每個線程都是自己把自己鎖住了,當(dāng)flag為true時,看以下兩段代碼:

public synchronized void set(String name) {

if (flag)

try {

wait();

public synchronized void out() {

if (flag)

try {

wait();

兩個線程都在wait,當(dāng)然卡住不動了。

看你的代碼,把set那段改成這樣應(yīng)該就好了:

public synchronized void set(String name) {

if (!flag)

try {

wait();


新聞標(biāo)題:java寫一段死鎖代碼,java死鎖的簡單例子
URL地址:http://weahome.cn/article/hdcsih.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部