Java 线程多线程编程2---线程同步
生活随笔
收集整理的這篇文章主要介紹了
Java 线程多线程编程2---线程同步
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
來模擬一個死鎖(互相等待):
TestDeadLock.java
package com.zhj.www;public class TestDeadLock implements Runnable {public int flag = 1;static Object o1 = new Object();static 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.getStackTrace();}synchronized (o2) {System.out.println("1");}}}if(flag ==0) {synchronized (o2) {try {Thread.sleep(500);}catch (Exception e) {e.getStackTrace();}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();}}運行結(jié)果:
我們發(fā)現(xiàn)程序處于已知等待的情況下。
哲學(xué)家吃飯問題(多個線程死鎖):
怎么解決?把鎖的粒度加粗,不如把整個對象鎖住,而不是只是鎖幾行。
粒度:實現(xiàn)數(shù)據(jù)庫的產(chǎn)品,鎖在行一級還是表一級。
面試題:
package com.zhj.www; public class TestInterviewQuestion1 implements Runnable {int b =100;public synchronized void m1() {try {b = 1000;Thread.sleep(5000);System.out.println("b = "+b);} catch (Exception e) {e.getStackTrace();}}public void m2() {System.out.println(b);}public void run() {try {m1();}catch (Exception e) {e.getStackTrace();}}public static void main(String[] args) throws Exception{TestInterviewQuestion1 testInterviewQuestion1 = new TestInterviewQuestion1();Thread thread = new Thread(testInterviewQuestion1);thread.start();Thread.sleep(1000);testInterviewQuestion1.m2();} }運行結(jié)果:
1000
b = 1000
修改一下:
對每個方法加不加鎖,要考慮清楚。
互斥:某個時間段,只有一個線程進入這個方法,但不保證不進入另外一個線程。
不允許多個線程同時寫,但允許多個線程讀。
總結(jié)
以上是生活随笔為你收集整理的Java 线程多线程编程2---线程同步的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 用UltraISO刻录CDDVD系统光盘
- 下一篇: Java网络编程1---基础