JAVA線程同步執行個體教程_java

來源:互聯網
上載者:User

線程是Java程式設計裡非常重要的概念,本文就以執行個體形式對此加以詳細解讀。具體分析如下:

首先,線程加鎖有什麼用處呢?舉個例子:比如你現在有30000塊大洋在銀行存著,現在你到銀行取錢,當你輸入密碼完成後,已經輸入取款金額,比如你輸入的是20000,就是在銀行給你拿錢這個時刻,你老婆也去銀行取這筆錢,你老婆同樣取20000,因為此時你的賬上仍然是30000,所以銀行同樣的操作在你老婆那端又進行了一遍,這樣當你們兩個完成各自操作後,銀行記錄的你賬上還應該有10000塊存款,這樣是不是很爽。解決這個問題就用到了線程加鎖的知識,下面就讓我們一起來學習一下吧。

一、未處理線程同步的一個例子:

public class TextSync implements Runnable{  /**未處理線程同步   * @param args   */  Time time = new Time();  public static void main(String[] args) {    TextSync text = new TextSync();    Thread t1 = new Thread(text);    Thread t2 = new Thread(text);    t1.setName("t1");    t2.setName("t2");    t1.start();    t2.start();  }  @Override  public void run() {    time.add(Thread.currentThread().getName());  }}class Time {  private static int num = 0;  public void add(String name){    try {      num++;      //當第一個線程執行到此時,num變成了1,第一個線程暫停一秒,      //第二個線程開始執行,當第二個線程執行到此時,num變成了2,第二個線程暫停一秒,      //第一個線程此時的num同樣變成了2,所以最終的結果均為2;      Thread.sleep(1000);    } catch (InterruptedException e) {      e.printStackTrace();    }    System.out.println(name+"是第"+num+"個執行的線程。");  }}

輸出結果:

t2是第2個執行的線程。t1是第2個執行的線程。

二、線程同步

public class TextSynctwo implements Runnable{  /**線程同步   * @param args   */  Time1 time = new Time1();  public static void main(String[] args) {    TextSynctwo text = new TextSynctwo();    Thread t1 = new Thread(text);    Thread t2 = new Thread(text);    t1.setName("t1");    t2.setName("t2");    t1.start();    t2.start();  }  @Override  public void run() {    time.add(Thread.currentThread().getName());  }}class Time1 {  private static int num = 0;    //synchronized鎖定當前線程,可以在方法定義時進行聲明,或採用在方法中進行設定。  public synchronized void add(String name){    //synchronized (this) {//鎖定當前線程,防止此時被別的線程執行      try {        num++;        Thread.sleep(1000);      } catch (InterruptedException e) {        e.printStackTrace();      }      System.out.println(name+"是第"+num+"個執行的線程。");    //}  }}

輸出結果:

t1是第1個執行的線程。t2是第2個執行的線程。

三、死結

public class TestDeadLock implements Runnable{  /**死結   * @param args   */  private int flag = 0 ;   static Object o1 = new Object();  static Object o2 = new Object();  public static void main(String[] args) {    TestDeadLock td1 = new TestDeadLock();     TestDeadLock td2 = new TestDeadLock();     td1.flag = 1;    td2.flag = 2;    Thread t1 = new Thread(td1);     Thread t2 = new Thread(td2);    t1.setName("t1");    t2.setName("t2");    t1.start();    t2.start();  }  @Override  public void run() {    System.out.println(Thread.currentThread().getName());    if(flag == 1){      synchronized(o1){        try {          Thread.sleep(5000);        } catch (InterruptedException e) {          e.printStackTrace();        }        synchronized(o2){          System.out.println("1");        }      }    }    if(flag == 2){      synchronized(o2){        try {          Thread.sleep(5000);        } catch (InterruptedException e) {          e.printStackTrace();        }        synchronized(o1){          System.out.println("2");        }      }    }  }}

四、鎖定

public class TT implements Runnable{  /**鎖定   * @param args   */  int b = 100;  public static void main(String[] args) {    TT tt = new TT();    Thread th = new Thread(tt);    th.start();    try {      tt.m2();    } catch (Exception e) {      e.printStackTrace();    }    System.out.println(tt.b);  }  @Override  public void run() {    try {      m1();    } catch (Exception e) {      e.printStackTrace();    }  }  private synchronized void m1() throws Exception{    b = 1000;    Thread.sleep(5000);    System.out.println("b="+b);  }  private synchronized void m2() throws Exception{    Thread.sleep(2500);    b = 2500;  } }

現在的輸出結果是:

1000b=1000

可見這裡m2先執行,m1要等m2執行完畢後方可執行。

希望本文所述對大家的Java程式設計有所協助

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.