欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解析Java編程之Synchronized鎖住的對象

 更新時間:2017年10月23日 15:05:22   作者:zhangjk1993  
這篇文章主要介紹了解析Java編程之Synchronized鎖住的對象,具有一定參考價值,需要的朋友可以了解下。

圖片上傳 密碼修改為  synchronized是java中用于同步的關(guān)鍵字,一般我們通過Synchronized鎖住一個對象,來進(jìn)行線程同步。我們需要了解在程序執(zhí)行過程中,synchronized鎖住的到底是哪個對象,否則我們在多線程的程序就有可能出現(xiàn)問題。

看下面的代碼,我們定義了一個靜態(tài)變量n,在run方法中,我們使n增加10,然后在main方法中,我們開辟了100個線程,來執(zhí)行n增加的操作,如果線程沒有并發(fā)執(zhí)行,那么n最后的值應(yīng)該為1000,顯然下面的程序執(zhí)行完結(jié)果不是1000,因為我們沒有進(jìn)行線程同步。

import java.util.concurrent.TimeUnit; 
public class SynchronizedTest1 extends Thread { 
  public static int n = 0; 
  public void run() { 
    try { 
      //使n自加10次 
      for (int i = 0; i < 10; i++) { 
        n = n + 1; 
        TimeUnit.MILLISECONDS.sleep(10); 
      } 
    } catch (InterruptedException e) { 
      e.printStackTrace(); 
    } 
  } 
  public static void main(String[] args) throws InterruptedException { 
    Thread[] threads = new Thread[100]; 
    for (int i = 0; i < threads.length; i++) { 
      threads[i] = new SynchronizedTest1(); 
      threads[i].start(); 
    } 
    //使所有其他線程執(zhí)行完,再繼續(xù)執(zhí)行main線程,這樣得出的n是最終的結(jié)果 
    for (Thread thread : threads) { 
      thread.join(); 
    } 
    System.out.println(n); 
  } 
} 

為了實現(xiàn)同步,我們修改上面的代碼,增加一個increase方法,如下。但是當(dāng)我們執(zhí)行下面的代碼時,會發(fā)現(xiàn)n仍然不是1000.

import java.util.concurrent.TimeUnit; 
public class SynchronizedTest2 extends Thread { 
  public static int n = 0; 
  public synchronized void increase() { 
    n++; 
  } 
  public void run() { 
    try { 
      //使n自加10次 
      for (int i = 0; i < 10; i++) { 
        increase(); 
        TimeUnit.MILLISECONDS.sleep(10); 
      } 
    } catch (InterruptedException e) { 
      e.printStackTrace(); 
    } 
  } 
  public static void main(String[] args) throws InterruptedException { 
    Thread[] threads = new Thread[100]; 
    for (int i = 0; i < threads.length; i++) { 
      threads[i] = new SynchronizedTest2(); 
      threads[i].start(); 
    } 
    //使所有其他線程執(zhí)行完,再繼續(xù)執(zhí)行main線程,這樣得出的n是最終的結(jié)果 
    for (Thread thread : threads) { 
      thread.join(); 
    } 
    System.out.println(n); 
  } 
} 

其實原因很簡單,上面的多個線程在執(zhí)行時根本就沒有競爭同一個對象鎖。當(dāng)我們執(zhí)行用synchronized修飾的非靜態(tài)方法時,線程會首先獲得調(diào)用這個方法的對象的鎖,然后才能繼續(xù)執(zhí)行代碼。那么調(diào)用這個方法的到底是哪個對象,是this對象。在上面的例子中,thread[i]所代表的線程獲取的鎖對象是thread[i]對象,也就是該線程對象本身。因此上面所開辟的100個線程只要獲得自身對象就可以執(zhí)行,這樣就使同步失去了作用。

我們再次修改代碼:即將increase方法改為i靜態(tài)的,此時程序執(zhí)行完后n的值為1000。

import java.util.concurrent.TimeUnit; 
 
public class SynchronizedTest3 extends Thread { 
  public static int n = 0; 
 
  public synchronized static void increase() { 
    n++; 
  } 
  public void run() { 
    try { 
      //使n自加10次 
      for (int i = 0; i < 10; i++) { 
        increase(); 
        TimeUnit.MILLISECONDS.sleep(10); 
      } 
    } catch (InterruptedException e) { 
      e.printStackTrace(); 
    } 
  } 
 
  public static void main(String[] args) throws InterruptedException { 
    Thread[] threads = new Thread[100]; 
    for (int i = 0; i < threads.length; i++) { 
      threads[i] = new SynchronizedTest3(); 
      threads[i].start(); 
    } 
 
    //使所有其他線程執(zhí)行完,再繼續(xù)執(zhí)行main線程,這樣得出的n是最終的結(jié)果 
    for (Thread thread : threads) { 
      thread.join(); 
    } 
    System.out.println(n); 
  } 
} 

當(dāng)synchronized 修飾static方法,它鎖住的是該類的Class對象,而不是某一個具體對象。在上面的例子中,它鎖住的就是SynchronizedTest3.class對象。在程序執(zhí)行過程中,類的Class對象只有一份,所以上面線程競爭的是同一個對象鎖。

下面是對synchronized鎖住對象的總結(jié):

(1)對于同步方法,鎖當(dāng)前對象(this)
(2)對于靜態(tài)同步方法,鎖當(dāng)前類的Class對象
(3)對于同步代碼塊,鎖住的是synchronized括號中的對象

總結(jié)

以上就是本文關(guān)于解析Java編程之Synchronized鎖住的對象的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:Java編程redisson實現(xiàn)分布式鎖代碼示例、Java并發(fā)編程之重入鎖與讀寫鎖等,有什么問題可以直接留言,小編會及時回復(fù)大家的。下面推薦本站基本Java編程相關(guān)的書籍,免費下載,供朋友們學(xué)習(xí)參考。

Java初級開發(fā)工程師面試題匯總.PDF

http://www.dbjr.com.cn/books/576989.html

Java經(jīng)典實例(第三版) 完整版 ([美]達(dá)爾文) 中文pdf掃描版

http://www.dbjr.com.cn/books/577859.html

希望大家能夠喜歡。

相關(guān)文章

  • SpringBoot調(diào)用service層的三種方法

    SpringBoot調(diào)用service層的三種方法

    在Spring?Boot中,我們可以通過注入Service層對象來調(diào)用Service層的方法,Service層是業(yè)務(wù)邏輯的處理層,它通常包含了對數(shù)據(jù)的增刪改查操作,本文給大家介紹了SpringBoot調(diào)用service層的三種方法,需要的朋友可以參考下
    2024-05-05
  • Spring Boot Async異步執(zhí)行任務(wù)過程詳解

    Spring Boot Async異步執(zhí)行任務(wù)過程詳解

    這篇文章主要介紹了Spring Boot Async異步執(zhí)行任務(wù)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-08-08
  • SpringBoot+Ajax+redis實現(xiàn)隱藏重要接口地址的方法

    SpringBoot+Ajax+redis實現(xiàn)隱藏重要接口地址的方法

    這篇文章主要介紹了SpringBoot+Ajax+redis實現(xiàn)隱藏重要接口地址,本篇文章主要講訴使用SpringBoot項目配合Ajax和redis實現(xiàn)隱藏重要接口地址,這里我以隱藏秒殺地址為例,需要的朋友可以參考下
    2024-03-03
  • 解析Mybatis的insert方法返回數(shù)字-2147482646的解決

    解析Mybatis的insert方法返回數(shù)字-2147482646的解決

    這篇文章主要介紹了解析Mybatis的insert方法返回數(shù)字-2147482646的解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Java中xxl-job實現(xiàn)分片廣播任務(wù)的示例

    Java中xxl-job實現(xiàn)分片廣播任務(wù)的示例

    本文主要介紹了Java中xxl-job實現(xiàn)分片廣播任務(wù)的示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • java 如何使用org.w3c.dom操作XML文件

    java 如何使用org.w3c.dom操作XML文件

    這篇文章主要介紹了java 如何使用org.w3c.dom操作XML文件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • 詳解Java中綴表達(dá)式的實現(xiàn)

    詳解Java中綴表達(dá)式的實現(xiàn)

    中綴表達(dá)式是一個通用的算術(shù)或邏輯公式表示方法。,中綴表達(dá)式不容易被計算機解析,但仍被許多程序語言使用,因為它符合人們的普遍用法。本文介紹了實現(xiàn)中綴表達(dá)式的方法,需要的可以參考一下
    2022-07-07
  • 解決引入spring-cloud-starter-openfeign后部分類找不到的問題

    解決引入spring-cloud-starter-openfeign后部分類找不到的問題

    這篇文章主要介紹了解決引入spring-cloud-starter-openfeign后部分類找不到的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • SpringBoot接收參數(shù)使用的注解實例講解

    SpringBoot接收參數(shù)使用的注解實例講解

    這篇文章主要介紹了詳解SpringBoot接收參數(shù)使用的幾種常用注解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • java多線程編程之捕獲子線程異常示例

    java多線程編程之捕獲子線程異常示例

    java多線程程序中所有線程都不允許拋出未捕獲的checked exception,也就是說各個線程需要自己把自己的checked exception處理掉。但是無法避免的是unchecked exception,也就是RuntimeException,當(dāng)拋出異常時子線程會結(jié)束,但不會影響主線程
    2014-02-02

最新評論