正文
我們提供的服務(wù)有:網(wǎng)站設(shè)計(jì)、成都網(wǎng)站設(shè)計(jì)、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、敘永ssl等。為上千多家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的敘永網(wǎng)站制作公司并發(fā)環(huán)境下進(jìn)行編程時(shí),需要使用鎖機(jī)制來同步多線程間的操作,保證共享資源的互斥訪問。加鎖會帶來性能上的損壞,似乎是眾所周知的事情。然而,加鎖本身不會帶來多少的性能消耗,性能主要是在線程的獲取鎖的過程。如果只有一個(gè)線程競爭鎖,此時(shí)并不存在多線程競爭的情況,那么JVM會進(jìn)行優(yōu)化,那么這時(shí)加鎖帶來的性能消耗基本可以忽略。因此,規(guī)范加鎖的操作,優(yōu)化鎖的使用方法,避免不必要的線程競爭,不僅可以提高程序性能,也能避免不規(guī)范加鎖可能造成線程死鎖問題,提高程序健壯性。下面闡述幾種鎖優(yōu)化的思路。
一、盡量不要鎖住方法
在普通成員函數(shù)上加鎖時(shí),線程獲得的是該方法所在對象的對象鎖。此時(shí)整個(gè)對象都會被鎖住。這也意味著,如果這個(gè)對象提供的多個(gè)同步方法是針對不同業(yè)務(wù)的,那么由于整個(gè)對象被鎖住,一個(gè)業(yè)務(wù)業(yè)務(wù)在處理時(shí),其他不相關(guān)的業(yè)務(wù)線程也必須wait。下面的例子展示了這種情況:
LockMethod類包含兩個(gè)同步方法,分別在兩種業(yè)務(wù)處理中被調(diào)用:
public class LockMethod { public synchronized void busiA() { for (int i = 0; i < 10000; i++) { System.out.println(Thread.currentThread().getName() + "deal with bussiness A:"+i); } } public synchronized void busiB() { for (int i = 0; i < 10000; i++) { System.out.println(Thread.currentThread().getName() + "deal with bussiness B:"+i); } } }