日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java性能调优笔记

發布時間:2025/3/17 java 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java性能调优笔记 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

調優步驟:衡量系統現狀、設定調優目標、尋找性能瓶頸、性能調優、衡量是否到達目標(如果未到達目標,需重新尋找性能瓶頸)、性能調優結束。



尋找性能瓶頸

性能瓶頸的表象:資源消耗過多、外部處理系統的性能不足、資源消耗不多但程序的響應速度卻仍達不到要求。


資源消耗:CPU、文件IO、網絡IO、內存。

外部處理系統的性能不足:所調用的其他系統提供的功能或數據庫操作的響應速度不夠。

資源消耗不多但程序的響應速度卻仍達不到要求:程序代碼運行效率不夠高、未充分使用資源、程序結構不合理。



CPU消耗分析

CPU主要用于中斷、內核、用戶進程的任務處理,優先級為中斷>內核>用戶進程。


上下文切換:

每個線程分配一定的執行時間,當到達執行時間、線程中有IO阻塞或高優先級線程要執行時,將切換執行的線程。在切換時要存儲目前線程的執行狀態,并恢復要執行的線程的狀態。

對于Java應用,典型的是在進行文件IO操作、網絡IO操作、鎖等待、線程Sleep時,當前線程會進入阻塞或休眠狀態,從而觸發上下文切換,上下文切換過多會造成內核占據較多的CPU的使用。


運行隊列:

每個CPU核都維護一個可運行的線程隊列。系統的load主要由CPU的運行隊列來決定。

運行隊列值越大,就意味著線程會要消耗越長的時間才能執行完成。


利用率:

CPU在用戶進程、內核、中斷處理、IO等待、空閑,這五個部分使用百分比。



文件IO消耗分析

Linux在操作文件時,將數據放入文件緩存區,直到內存不夠或系統要釋放內存給用戶進程使用。所以通常情況下只有寫文件和第一次讀取文件時會產生真正的文件IO。

對于Java應用,造成文件IO消耗高主要是多個線程需要進行大量內容寫入(例如頻繁的日志寫入)的動作、磁盤設備本身的處理速度慢、文件系統慢、操作的文件本身已經很大。



網絡IO消耗分析

對于分布式Java應用,網卡中斷是不是均衡分配到各CPU(cat/proc/interrupts查看)。



內存消耗分析(-Xms和-Xmx設為相同的值,避免運行期JVM堆內存要不斷申請內存)

對于Java應用,內存的消耗主要在Java堆內存上,只有創建線程和使用Direct ByteBuffer才會操作JVM堆外的內存。

JVM內存消耗過多會導致GC執行頻繁,CPU消耗增加,應用線程的執行速度嚴重下降,甚至造成OutOfMemoryError,最終導致Java進程退出。


JVM堆外的內存

swap的消耗、物理內存的消耗、JVM內存的消耗。

?

?

程序執行慢原因分析

鎖競爭激烈:很多線程競爭互斥資源,但資源有限, 造成其他線程都處于等待狀態。

未充分使用硬件資源:線程操作被串行化。

數據量增長:單表數據量太大(如1個億)造成數據庫讀寫速度大幅下降(操作此表)。


調優

?

JVM調優(最關鍵參數為:-Xms -Xmx -Xmn -XX:SurvivorRatio -XX:MaxTenuringThreshold)

?

代大小調優:避免新生代大小設置過小、避免新生代大小設置過大、避免Survivor設置過小或過大、合理設置新生代存活周期。

-Xmn 調整新生代大小,新生代越大通常也意味著更多對象會在minor GC階段被回收,但可能有可能造成舊生代大小,造成頻繁觸發Full GC,甚至是OutOfMemoryError。

-XX:SurvivorRatio調整Eden區與Survivor區的大小,Eden 區越大通常也意味著minor GC發生頻率越低,但可能有可能造成Survivor區太小,導致對象minor GC后就直接進入舊生代,從而更頻繁觸發Full GC。

?

GC策略的調優:CMS GC多數動作是和應用并發進行的,確實可以減小GC動作給應用造成的暫停時間。對于Web應用非常需要一個對應用造成暫停時間短的GC,再加上Web應用 的瓶頸都不在CPU上,在G1還不夠成熟的情況下,CMS GC是不錯的選擇。

(如果系統不是CPU密集型,且從新生代進入舊生代的大部分對象是可以回收的,那么采用CMS GC可以更好地在舊生代滿之前完成對象的回收,更大程度降低Full GC發生的可能)

?

在調整了內存管理方面的參數后應通過-XX:PrintGCDetails、-XX:+PrintGCTimeStamps、 -XX:+PrintGCApplicationStoppedTime以及jstat或visualvm等方式觀察調整后的GC狀況。

出內存管理以外的其他方面的調優參數:-XX:CompileThreshold、-XX:+UseFastAccessorMethods、 -XX:+UseBaiasedLocking。

?

程序調優

?

CPU消耗嚴重的解決方法

?

CPU us高的解決方法:

CPU us 高的原因主要是執行線程不需要任何掛起動作,且一直執行,導致CPU 沒有機會去調度執行其他的線程。

調優方案: 增加Thread.sleep,以釋放CPU 的執行權,降低CPU 的消耗。以損失單次執行性能為代價的,但由于其降低了CPU 的消耗,對于多線程的應用而言,反而提高了總體的平均性能。

(在實際的Java應用中類似場景, 對于這種場景最佳方式是改為采用wait/notify機制)

對于其他類似循環次數過多、正則、計算等造成CPU us過高的狀況, 則需要結合業務調優。

對于GC頻繁,則需要通過JVM調優或程序調優,降低GC的執行次數。

?

CPU sy高的解決方法:

CPU sy 高的原因主要是線程的運行狀態要經常切換,對于這種情況,常見的一種優化方法是減少線程數。

調優方案: 將線程數降低

這種調優過后有可能會造成CPU us過高,所以合理設置線程數非常關鍵。

?

對于Java分布式應用,還有一種典型現象是應用中有較多的網絡IO操作和確實需要一些鎖競爭機制(如數據庫連接池),但為了能夠支撐搞得并發量,可采用協程(Coroutine)來支撐更高的并發量,避免并發量上漲后造成CPU sy消耗嚴重、系統load迅速上漲和系統性能下降。

在Java中實現協程的框架有Kilim,Kilim執行一項任務創建Task,使用Task的暫停機制,而不是Thread,Kilim承擔了線程調度以及上下切換動作,Task相對于原生Thread而言就輕量級多了,且能更好利用CPU。Kilim帶來的是線程使用率的提升,但同時由于要在JVM堆中保存Task上下文信息,因此在采用Kilim的情況下要消耗更多的內存。(目前JDK 7中也有一個支持協程方式的實現,另外基于JVM的Scala的Actor也可用于在Java使用協程)

?

文件IO消耗嚴重的解決方法

從程序的角度而言,造成文件IO消耗嚴重的原因主要是多個線程在寫進行大量的數據到同一文件,導致文件很快變得很大,從而寫入速度越來越慢,并造成各線程激烈爭搶文件鎖。

?

常用調優方法:

異步寫文件

批量讀寫

限流

限制文件大小

?

網絡IO消耗嚴重的解決方法

從程序的角度而言,造成網絡IO消耗嚴重的原因主要是同時需要發送或接收的包太多。

?

常用調優方法:

限流,限流通常是限制發送packet的頻率,從而在網絡IO消耗可接受的情況下來發送packget。

?

?

內存消耗嚴重的解決方法

釋放不必要的引用:代碼持有了不需要的對象引用,造成這些對象無法被GC,從而占據了JVM堆內存。(使用ThreadLocal:注意在線程內動作執行完畢時,需執行ThreadLocal.set把對象清除,避免持有不必要的對象引用)

使用對象緩存池:創建對象要消耗一定的CPU以及內存,使用對象緩存池一定程度上可降低JVM堆內存的使用。

采用合理的緩存失效算法:如果放入太多對象在緩存池中,反而會造成內存的嚴重消耗, 同時由于緩存池一直對這些對象持有引用,從而造成Full GC增多,對于這種狀況要合理控制緩存池的大小,避免緩存池的對象數量無限上漲。(經典的緩存失效算法來清除緩存池中的對象:FIFO、LRU、LFU等)

合理使用SoftReference和WeekReference:SoftReference的對象會在內存不夠用的時候回收,WeekReference的對象會在Full GC的時候回收。

?

資源消耗不多但程序執行慢的情況的解決方法

?

降低鎖競爭: 多線多了,鎖競爭的狀況會比較明顯,這時候線程很容易處于等待鎖的狀況,從而導致性能下降以及CPU sy上升。

使用并發包中的類:大多數采用了lock-free、nonblocking算法。

使用Treiber算法:基于CAS以及AtomicReference。

使用Michael-Scott非阻塞隊列算法:基于CAS以及AtomicReference,典型ConcurrentLindkedQueue。

(基于CAS和AtomicReference來實現無阻塞是不錯的選擇,但值得注意的是,lock-free算法需不斷的循環比較來保證資源的一致性的,對于沖突較多的應用場景而言,會帶來更高的CPU消耗,因此不一定采用CAS實現無阻塞的就一定比采用lock方式的性能好。 還有一些無阻塞算法的改進:MCAS、WSTM等)

盡可能少用鎖:盡可能只對需要控制的資源做加鎖操作(通常沒有必要對整個方法加鎖,盡可能讓鎖最小化,只對互斥及原子操作的地方加鎖,加鎖時盡可能以保護資源的最小化粒度為單位--如只對需要保護的資源加鎖而不是this)。

拆分鎖:獨占鎖拆分為多把鎖(讀寫鎖拆分、類似ConcurrentHashMap中默認拆分為16把鎖),很多程度上能提高讀寫的性能,但需要注意在采用拆分鎖后,全局性質的操作會變得比較復雜(如ConcurrentHashMap中size操作)。(拆分鎖太多也會造成副作用,如CPU消耗明顯增加)

去除讀寫操作的互斥:在修改時加鎖,并復制對象進行修改,修改完畢后切換對象的引用,從而讀取時則不加鎖。這種稱為CopyOnWrite,CopyOnWriteArrayList是典型實現,好處是可以明顯提升讀的性能,適合讀多寫少的場景, 但由于寫操作每次都要復制一份對象,會消耗更多的內存。

?

充分利用硬件資源(CPU和內存):

?

充分利用CPU

在能并行處理的場景中未使用足夠的線程(線程增加:CPU資源消耗可接受且不會帶來激烈競爭鎖的場景下), 例如單線程的計算,可以拆分為多個線程分別計算,最后將結果合并,JDK 7中的fork-join框架。

Amdahl定律公式:1/(F+(1-F)/N)。

?

充分利用內存

數據的緩存、耗時資源的緩存(數據庫連接創建、網絡連接的創建等)、頁面片段的緩存。

畢竟內存的讀取肯定遠快于硬盤、網絡的讀取, 在內存消耗可接受、GC頻率、以及系統結構(例如集群環境可能會帶來緩存的同步)可接受情況下,應充分利用內存來緩存數據,提升系統的性能。

?

總結:

好的調優策略是收益比(調優后提升的效果/調優改動所需付出的代價)最高的,通常來說簡單的系統調優比較好做,因此盡量保持單機上應用的純粹性, 這是大型系統的基本架構原則。

調優的三大有效原則:充分而不過分使用硬件資源、合理調整JVM、合理使用JDK包。

?

?

學習參考資料:

《分布式Java應用:基礎與實踐》

?

補充《分布式Java應用:基礎與實踐》一些代碼樣例:

?

cpu-----------------------------------

?

CpuNotUseEffectiveDemo


/**?

?* ?

?*/ ?

package tune.program.cpu; ?

import java.util.ArrayList; ?

import java.util.List; ?

import java.util.Random; ?

/**?

?* 未充分利用CPU:在能并行處理的場景中未使用足夠的線程(線程增加:CPU資源消耗可接受且不會帶來激烈競爭鎖的場景下)?

?* ?

?* @author yangwm Aug 25, 2010 9:54:50 AM?

?*/ ?

public class CpuNotUseEffectiveDemo { ?

? ? ??

? ? private static int executeTimes = 10; ?

? ? private static int taskCount = 200; ?

? ? ??

? ? public static void main(String[] args) throws Exception { ?

? ? ? ? Task task = new Task(); ?

? ? ? ? for (int i = 0; i < taskCount; i++) { ?

? ? ? ? ? ? task.addTask(Integer.toString(i)); ?

? ? ? ? } ?

? ? ? ? ??

? ? ? ? long beginTime = System.currentTimeMillis(); ?

? ? ? ? for (int i = 0; i < executeTimes; i++) { ?

? ? ? ? ? ? System.out.println("Round: " + (i + 1)); ?

? ? ? ? ? ? Thread thread = new Thread(task); ?

? ? ? ? ? ? thread.start(); ?

? ? ? ? ? ? thread.join(); ?

? ? ? ? } ?

? ? ? ? long endTime = System.currentTimeMillis(); ?

? ? ? ? System.out.println("Execute summary: Round( " + executeTimes + " ) TaskCount Per Round( " + taskCount ??

? ? ? ? ? ? ? ? + " ) Execute Time ( " + (endTime - beginTime) + " ) ms"); ?

? ? } ?

? ? ??

? ? static class Task implements Runnable { ?

? ? ? ? List<String> tasks = new ArrayList<String>(); ?

? ? ? ? Random random = new Random(); ?

? ? ? ? boolean exitFlag = false; ?

? ? ? ? ??

? ? ? ? public void addTask(String task) { ?

? ? ? ? ? ? List<String> copyTasks = new ArrayList<String>(tasks); ?

? ? ? ? ? ? copyTasks.add(task); ?

? ? ? ? ? ? ??

? ? ? ? ? ? tasks = copyTasks; ?

? ? ? ? } ?

? ? ? ? @Override ?

? ? ? ? public void run() { ?

? ? ? ? ? ? List<String> runTasks = tasks; ?

? ? ? ? ? ? List<String> removeTasks = new ArrayList<String>(); ?

? ? ? ? ? ? for (String task : runTasks) { ?

? ? ? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? ? ? Thread.sleep(random.nextInt(10)); ?

? ? ? ? ? ? ? ? } catch (Exception e) { ?

? ? ? ? ? ? ? ? ? ? e.printStackTrace(); ?

? ? ? ? ? ? ? ? } ?

? ? ? ? ? ? ? ? ??

? ? ? ? ? ? ? ? removeTasks.add(task); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? ??

? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? Thread.sleep(10); ?

? ? ? ? ? ? } catch (Exception e) { ?

? ? ? ? ? ? ? ? e.printStackTrace(); ?

? ? ? ? ? ? } ?

? ? ? ? } ?

? ? ? ? ??

? ? } ?

? ? ??

} ?

/*?

Round: 1?

......?

Round: 10?

Execute summary: Round( 10 ) TaskCount Per Round( 200 ) Execute Time ( 10687 ) ms?

*/ ?



?

CpuUseEffectiveDemo


/**?

?* ?

?*/ ?

package tune.program.cpu; ?

import java.util.ArrayList; ?

import java.util.List; ?

import java.util.Random; ?

import java.util.concurrent.CountDownLatch; ?

??

/**?

?* 充分利用CPU:在能并行處理的場景中使用足夠的線程(線程增加:CPU資源消耗可接受且不會帶來激烈競爭鎖的場景下)?

?* ?

?* @author yangwm Aug 25, 2010 9:54:50 AM?

?*/ ?

public class CpuUseEffectiveDemo { ?

? ? ??

? ? private static int executeTimes = 10; ?

? ? private static int taskCount = 200; ?

? ? private static final int TASK_THREADCOUNT = 16; ?

? ? private static CountDownLatch latch; ?

? ? ??

? ? public static void main(String[] args) throws Exception { ?

? ? ? ? Task[] tasks = new Task[TASK_THREADCOUNT]; ?

? ? ? ? for (int i = 0; i < TASK_THREADCOUNT; i++) { ?

? ? ? ? ? ? tasks[i] = new Task(); ?

? ? ? ? } ?

? ? ? ? for (int i = 0; i < taskCount; i++) { ?

? ? ? ? ? ? int mod = i % TASK_THREADCOUNT; ?

? ? ? ? ? ? tasks[mod].addTask(Integer.toString(i)); ?

? ? ? ? } ?

? ? ? ? ??

? ? ? ? long beginTime = System.currentTimeMillis(); ?

? ? ? ? for (int i = 0; i < executeTimes; i++) { ?

? ? ? ? ? ? System.out.println("Round: " + (i + 1)); ?

? ? ? ? ? ? latch = new CountDownLatch(TASK_THREADCOUNT); ?

? ? ? ? ? ? for (int j = 0; j < TASK_THREADCOUNT; j++) { ?

? ? ? ? ? ? ? ? Thread thread = new Thread(tasks[j]); ?

? ? ? ? ? ? ? ? thread.start(); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? latch.await(); ?

? ? ? ? } ?

? ? ? ? long endTime = System.currentTimeMillis(); ?

? ? ? ? System.out.println("Execute summary: Round( " + executeTimes + " ) TaskCount Per Round( " + taskCount ??

? ? ? ? ? ? ? ? + " ) Execute Time ( " + (endTime - beginTime) + " ) ms"); ?

? ? } ?

? ? ??

? ? static class Task implements Runnable { ?

? ? ? ? List<String> tasks = new ArrayList<String>(); ?

? ? ? ? Random random = new Random(); ?

? ? ? ? boolean exitFlag = false; ?

? ? ? ? ??

? ? ? ? public void addTask(String task) { ?

? ? ? ? ? ? List<String> copyTasks = new ArrayList<String>(tasks); ?

? ? ? ? ? ? copyTasks.add(task); ?

? ? ? ? ? ? ??

? ? ? ? ? ? tasks = copyTasks; ?

? ? ? ? } ?

? ? ? ? @Override ?

? ? ? ? public void run() { ?

? ? ? ? ? ? List<String> runTasks = tasks; ?

? ? ? ? ? ? List<String> removeTasks = new ArrayList<String>(); ?

? ? ? ? ? ? for (String task : runTasks) { ?

? ? ? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? ? ? Thread.sleep(random.nextInt(10)); ?

? ? ? ? ? ? ? ? } catch (Exception e) { ?

? ? ? ? ? ? ? ? ? ? e.printStackTrace(); ?

? ? ? ? ? ? ? ? } ?

? ? ? ? ? ? ? ? ??

? ? ? ? ? ? ? ? removeTasks.add(task); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? ??

? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? Thread.sleep(10); ?

? ? ? ? ? ? } catch (Exception e) { ?

? ? ? ? ? ? ? ? e.printStackTrace(); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? latch.countDown(); ?

? ? ? ? } ?

? ? ? ? ??

? ? } ?

? ? ??

} ?

/*?

Round: 1?

......?

Round: 10?

Execute summary: Round( 10 ) TaskCount Per Round( 200 ) Execute Time ( 938 ) ms?

*/ ?


?

?

fileio-------------------------------------------------------------------

?

IOWaitHighDemo


/**?

?* ?

?*/ ?

package tune.program.fileio; ?

import java.io.BufferedWriter; ?

import java.io.File; ?

import java.io.FileWriter; ?

import java.util.Random; ?

/**?

?* 文件IO消耗嚴重的原因主要是多個線程在寫進行大量的數據到同一文件,?

?* 導致文件很快變得很大,從而寫入速度越來越慢,并造成各線程激烈爭搶文件鎖。?

?* ?

?* @author yangwm Aug 21, 2010 9:48:34 PM?

?*/ ?

public class IOWaitHighDemo { ?

? ? private String fileName = "iowait.log"; ?

? ? ??

? ? private static int threadCount = Runtime.getRuntime().availableProcessors(); ?

? ? ??

? ? private Random random = new Random(); ?

? ? ??

? ? public static void main(String[] args) throws Exception { ?

? ? ? ? if (args.length == 1) { ?

? ? ? ? ? ? threadCount = Integer.parseInt(args[1]); ?

? ? ? ? } ?

? ? ? ? ??

? ? ? ? IOWaitHighDemo demo = new IOWaitHighDemo(); ?

? ? ? ? demo.runTest(); ?

? ? } ?

? ? ??

? ? private void runTest() throws Exception { ?

? ? ? ? File file = new File(fileName); ?

? ? ? ? file.createNewFile(); ?

? ? ? ? ??

? ? ? ? for (int i = 0; i < threadCount; i++) { ?

? ? ? ? ? ? new Thread(new Task()).start(); ?

? ? ? ? } ?

? ? ? ? ??

? ? } ?

? ? ??

? ? class Task implements Runnable { ?

? ? ? ? @Override ?

? ? ? ? public void run() { ?

? ? ? ? ? ? while (true) { ?

? ? ? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? ? ? StringBuilder strBuilder = new StringBuilder("====begin====/n"); ?

? ? ? ? ? ? ? ? ? ? String threadName = Thread.currentThread().getName(); ?

? ? ? ? ? ? ? ? ? ? for (int i = 0; i < 100000; i++) { ?

? ? ? ? ? ? ? ? ? ? ? ? strBuilder.append(threadName); ?

? ? ? ? ? ? ? ? ? ? ? ? strBuilder.append("/n"); ?

? ? ? ? ? ? ? ? ? ? } ?

? ? ? ? ? ? ? ? ? ? strBuilder.append("====end====/n"); ?

? ? ? ? ? ? ? ? ? ? ??

? ? ? ? ? ? ? ? ? ? BufferedWriter writer = new BufferedWriter(new FileWriter(fileName, true)); ?

? ? ? ? ? ? ? ? ? ? writer.write(strBuilder.toString()); ?

? ? ? ? ? ? ? ? ? ? writer.close(); ?

? ? ? ? ? ? ? ? ? ? Thread.sleep(random.nextInt(10)); ?

? ? ? ? ? ? ? ? } catch (Exception e) { ?

? ? ? ? ? ? ? ? ? ? ??

? ? ? ? ? ? ? ? } ?

? ? ? ? ? ? } ?

? ? ? ? } ?

? ? ? ? ??

? ? } ?

? ? ??

} ?

/*?

C:/Documents and Settings/yangwm>jstack 2656?

2010-08-21 23:24:17?

Full thread dump Java HotSpot(TM) Client VM (17.0-b05 mixed mode):?

"DestroyJavaVM" prio=6 tid=0x00868c00 nid=0xde0 waiting on condition [0x00000000]?

? ?java.lang.Thread.State: RUNNABLE?

"Thread-1" prio=6 tid=0x0ab9dc00 nid=0xb7c runnable [0x0b0bf000]?

? ?java.lang.Thread.State: RUNNABLE?

? ? ? ? at java.io.FileOutputStream.close0(Native Method)?

? ? ? ? at java.io.FileOutputStream.close(FileOutputStream.java:336)?

? ? ? ? at sun.nio.cs.StreamEncoder.implClose(StreamEncoder.java:320)?

? ? ? ? at sun.nio.cs.StreamEncoder.close(StreamEncoder.java:149)?

? ? ? ? - locked <0x034dd268> (a java.io.FileWriter)?

? ? ? ? at java.io.OutputStreamWriter.close(OutputStreamWriter.java:233)?

? ? ? ? at java.io.BufferedWriter.close(BufferedWriter.java:265)?

? ? ? ? - locked <0x034dd268> (a java.io.FileWriter)?

? ? ? ? at tune.IOWaitHighDemo$Task.run(IOWaitHighDemo.java:58)?

? ? ? ? at java.lang.Thread.run(Thread.java:717)?

"Thread-0" prio=6 tid=0x0ab9d400 nid=0x80c runnable [0x0b06f000]?

? ?java.lang.Thread.State: RUNNABLE?

? ? ? ? at java.io.FileOutputStream.writeBytes(Native Method)?

? ? ? ? at java.io.FileOutputStream.write(FileOutputStream.java:292)?

? ? ? ? at sun.nio.cs.StreamEncoder.writeBytes(StreamEncoder.java:221)?

? ? ? ? at sun.nio.cs.StreamEncoder.implWrite(StreamEncoder.java:282)?

? ? ? ? at sun.nio.cs.StreamEncoder.write(StreamEncoder.java:125)?

? ? ? ? - locked <0x034e1290> (a java.io.FileWriter)?

? ? ? ? at java.io.OutputStreamWriter.write(OutputStreamWriter.java:207)?

? ? ? ? at java.io.BufferedWriter.flushBuffer(BufferedWriter.java:128)?

? ? ? ? - locked <0x034e1290> (a java.io.FileWriter)?

? ? ? ? at java.io.BufferedWriter.write(BufferedWriter.java:229)?

? ? ? ? - locked <0x034e1290> (a java.io.FileWriter)?

? ? ? ? at java.io.Writer.write(Writer.java:157)?

? ? ? ? at tune.IOWaitHighDemo$Task.run(IOWaitHighDemo.java:57)?

? ? ? ? at java.lang.Thread.run(Thread.java:717)?

"Low Memory Detector" daemon prio=6 tid=0x0ab6f800 nid=0xfb0 runnable [0x00000000]?

? ?java.lang.Thread.State: RUNNABLE?

"CompilerThread0" daemon prio=10 tid=0x0ab6c800 nid=0x5fc waiting on condition [0x00000000]?

? ?java.lang.Thread.State: RUNNABLE?

"Attach Listener" daemon prio=10 tid=0x0ab67800 nid=0x6fc waiting on condition [0x00000000]?

? ?java.lang.Thread.State: RUNNABLE?

"Signal Dispatcher" daemon prio=10 tid=0x0ab66800 nid=0x5a0 runnable [0x00000000]?

? ?java.lang.Thread.State: RUNNABLE?

"Finalizer" daemon prio=8 tid=0x0ab54000 nid=0xe74 in Object.wait() [0x0ac8f000]?

? ?java.lang.Thread.State: WAITING (on object monitor)?

? ? ? ? at java.lang.Object.wait(Native Method)?

? ? ? ? - waiting on <0x02f15d90> (a java.lang.ref.ReferenceQueue$Lock)?

? ? ? ? at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:135)?

? ? ? ? - locked <0x02f15d90> (a java.lang.ref.ReferenceQueue$Lock)?

? ? ? ? at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:151)?

? ? ? ? at java.lang.ref.Finalizer$FinalizerThread.run(Finalizer.java:177)?

"Reference Handler" daemon prio=10 tid=0x0ab4f800 nid=0x8a4 in Object.wait() [0x0ac3f000]?

? ?java.lang.Thread.State: WAITING (on object monitor)?

? ? ? ? at java.lang.Object.wait(Native Method)?

? ? ? ? - waiting on <0x02f15af8> (a java.lang.ref.Reference$Lock)?

? ? ? ? at java.lang.Object.wait(Object.java:502)?

? ? ? ? at java.lang.ref.Reference$ReferenceHandler.run(Reference.java:133)?

? ? ? ? - locked <0x02f15af8> (a java.lang.ref.Reference$Lock)?

"VM Thread" prio=10 tid=0x0ab4a800 nid=0x1d0 runnable?

"VM Periodic Task Thread" prio=10 tid=0x0ab7d400 nid=0x464 waiting on condition?

JNI global references: 693?

?

C:/Documents and Settings/yangwm>?

*/ ?


?

?

LogControl


/**?

?* ?

?*/ ?

package tune.program.fileio; ?

import java.util.concurrent.atomic.AtomicInteger; ?

/**?

?* 日志控制:采用簡單策略為統計一段時間內日志輸出頻率, 當超出這個頻率時,一段時間內不再寫log ?

?* ?

?* @author yangwm Aug 24, 2010 10:41:43 AM?

?*/ ?

public class LogControl { ?

? ? ??

? ? public static void main(String[] args) { ?

? ? ? ? for (int i = 1; i <= 1000; i++) { ?

? ? ? ? ? ? if (LogControl.isLog()) { ?

? ? ? ? ? ? ? ? //logger.error(errorInfo, throwable); ?

? ? ? ? ? ? ? ? System.out.println("errorInfo " + i); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? ??

? ? ? ? ? ? // ? ?

? ? ? ? ? ? if (i % 100 == 0) { ?

? ? ? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? ? ? Thread.sleep(1000); ?

? ? ? ? ? ? ? ? } catch (InterruptedException e) { ?

? ? ? ? ? ? ? ? ? ? e.printStackTrace(); ?

? ? ? ? ? ? ? ? } ?

? ? ? ? ? ? } ?

? ? ? ? } ?

? ? } ?

? ? ??

? ? ??

? ? private static final long INTERVAL = 1000; ?

? ? private static final long PUNISH_TIME = 5000; ?

? ? private static final int ERROR_THRESHOLD = 100; ?

? ? private static AtomicInteger count = new AtomicInteger(0); ?

? ? private static long beginTime; ?

? ? private static long punishTimeEnd; ?

? ? ??

? ? // 由于控制不用非常精確, 因此忽略此處的并發問題 ?

? ? public static boolean isLog() { ?

? ? ? ? //System.out.println(count.get() + ", " + beginTime + ", " + punishTimeEnd + ", " + System.currentTimeMillis()); ?

? ? ? ? ??

? ? ? ? // 不寫日志階段 ??

? ? ? ? if (punishTimeEnd > 0 && punishTimeEnd > System.currentTimeMillis()) { ?

? ? ? ? ? ? return false; ?

? ? ? ? } ?

? ? ? ? ??

? ? ? ? // 重新計數 ?

? ? ? ? if (count.getAndIncrement() == 0) { ?

? ? ? ? ? ? beginTime = System.currentTimeMillis(); ?

? ? ? ? ? ? return true; ?

? ? ? ? } else { // 已在計數 ?

? ? ? ? ? ? // 超過閥門值, 設置count為0并設置一段時間內不寫日志 ?

? ? ? ? ? ? if (count.get() > ERROR_THRESHOLD) { ?

? ? ? ? ? ? ? ? count.set(0); ?

? ? ? ? ? ? ? ? punishTimeEnd = PUNISH_TIME + System.currentTimeMillis(); ?

? ? ? ? ? ? ? ? return false; ?

? ? ? ? ? ? } ??

? ? ? ? ? ? // 沒超過閥門值, 且當前時間已超過計數周期,則重新計算 ??

? ? ? ? ? ? else if (System.currentTimeMillis() > (beginTime + INTERVAL)) { ?

? ? ? ? ? ? ? ? count.set(0); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? ??

? ? ? ? ? ? return true; ?

? ? ? ? } ?

? ? } ?

? ? ??

} ?

/*?

errorInfo 1?

errorInfo 2?

......?

errorInfo 99?

errorInfo 100?

errorInfo 601?

errorInfo 602?

......?

errorInfo 699?

errorInfo 700?

*/ ??


?

?

memory-------------------------------------------------------------------

?

MemoryHighDemo


/**?

?* ?

?*/ ?

package tune.program.memory; ?

import java.nio.ByteBuffer; ?

/**?

?* direct bytebuffer消耗的是jvm堆外的內存,但同樣是基于GC方式來釋放的。?

?* ?

?* @author yangwm Aug 21, 2010 9:40:18 PM?

?*/ ?

public class MemoryHighDemo { ?

? ? ??

? ? public static void main(String[] args) throws Exception{ ?

? ? ? ? Thread.sleep(20000); ?

? ? ? ? System.out.println("read to create bytes,so jvm heap will be used"); ?

? ? ? ? byte[] bytes=new byte[128*1000*1000]; ?

? ? ? ? bytes[0]=1; ?

? ? ? ? bytes[1]=2; ?

? ? ? ? Thread.sleep(10000); ?

? ? ? ? System.out.println("read to allocate & put direct bytebuffer,no jvm heap should be used"); ?

? ? ? ? ByteBuffer buffer=ByteBuffer.allocateDirect(128*1024*1024); ?

? ? ? ? buffer.put(bytes); ?

? ? ? ? buffer.flip(); ?

? ? ? ? Thread.sleep(10000); ?

? ? ? ? System.out.println("ready to gc,jvm heap will be freed"); ?

? ? ? ? bytes=null; ?

? ? ? ? System.gc(); ?

? ? ? ? Thread.sleep(10000); ?

? ? ? ? System.out.println("read to get bytes,then jvm heap will be used"); ?

? ? ? ? byte[] resultbytes=new byte[128*1000*1000]; ?

? ? ? ? buffer.get(resultbytes); ?

? ? ? ? System.out.println("resultbytes[1] is: "+resultbytes[1]); ?

? ? ? ? Thread.sleep(10000); ?

? ? ? ? System.out.println("read to gc all"); ?

? ? ? ? buffer=null; ?

? ? ? ? resultbytes=null; ?

? ? ? ? System.gc(); ?

? ? ? ? Thread.sleep(10000); ?

? ? } ?

? ? ??

} ?

/*?

D:/study/tempProject/JavaLearn/classes>java -Xms140M -Xmx140M tune.MemoryHighDemo?

read to create bytes,so jvm heap will be used?

read to allocate & put direct bytebuffer,no jvm heap should be used?

ready to gc,jvm heap will be freed?

read to get bytes,then jvm heap will be used?

resultbytes[1] is: 2?

read to gc all?

*/ ?


?

ObjectCachePool


/**?

?* ?

?*/ ?

package tune.program.memory; ?

import java.util.LinkedHashMap; ?

import java.util.Map; ?

import java.util.Set; ?

/**?

?* 采用合理的緩存失效算法: FIFO、LRU、LFU等 ?

?* ?

?* @author yangwm Aug 24, 2010 6:06:48 PM?

?*/ ?

public class ObjectCachePool<K, V> { ?

? ? public static void main(String[] args) { ?

? ? ? ? // FIFO_POLICY ?

? ? ? ? int size = 10; ?

? ? ? ? int policy = 1; ?

? ? ? ? ObjectCachePool<Integer, Integer> objectCachePool = new ObjectCachePool<Integer, Integer>(size, policy); ?

? ? ? ? for (int i = 1; i <= 15; i++) { ?

? ? ? ? ? ? objectCachePool.put(i, i); ?

? ? ? ? } ?

? ? ? ? for (int i = 15; i >= 1; i--) { ?

? ? ? ? ? ? objectCachePool.put(i, i); ?

? ? ? ? } ?

? ? ? ? System.out.println("size(" + size + "), policy(" + policy + ") FIFO "); ?

? ? ? ? for (Map.Entry<Integer, Integer> entry : objectCachePool.entrySet()) { ?

? ? ? ? ? ? System.out.println(entry.getKey() + ", " + entry.getValue()); ?

? ? ? ? } ?

? ? ? ? ??

? ? ? ? // LRU_POLICY ?

? ? ? ? size = 10; ?

? ? ? ? policy = 2; ?

? ? ? ? objectCachePool = new ObjectCachePool<Integer, Integer>(size, policy); ?

? ? ? ? for (int i = 1; i <= 15; i++) { ?

? ? ? ? ? ? objectCachePool.put(i, i); ?

? ? ? ? } ?

? ? ? ? for (int i = 15; i >= 1; i--) { ?

? ? ? ? ? ? objectCachePool.put(i, i); ?

? ? ? ? } ?

? ? ? ? System.out.println("size(" + size + "), policy(" + policy + ") LRU "); ?

? ? ? ? for (Map.Entry<Integer, Integer> entry : objectCachePool.entrySet()) { ?

? ? ? ? ? ? System.out.println(entry.getKey() + ", " + entry.getValue()); ?

? ? ? ? } ?

? ? } ?

? ? private static final int FIFO_POLICY = 1; ?

? ? private static final int LRU_POLICY = 2; ?

? ? private static final int DEFAULT_SIZE = 10; ?

? ? private Map<K, V> cacheObjects; ?

? ? public ObjectCachePool() { ?

? ? ? ? this(DEFAULT_SIZE); ?

? ? } ?

? ? public ObjectCachePool(int size) { ?

? ? ? ? this(size, FIFO_POLICY); ?

? ? } ?

? ? public ObjectCachePool(final int size, final int policy) { ?

? ? ? ? switch (policy) { ?

? ? ? ? ??

? ? ? ? case FIFO_POLICY: ?

? ? ? ? ? ? cacheObjects = new LinkedHashMap<K, V>(size) { ?

? ? ? ? ? ? ? ? /**?

? ? ? ? ? ? ? ? ?* ?

? ? ? ? ? ? ? ? ?*/ ?

? ? ? ? ? ? ? ? private static final long serialVersionUID = 1L; ?

? ? ? ? ? ? ? ? protected boolean removeEldestEntry(Map.Entry<K, V> eldest) { ?

? ? ? ? ? ? ? ? ? ? return size() > size; ?

? ? ? ? ? ? ? ? } ?

? ? ? ? ? ? }; ?

? ? ? ? ? ? break; ?

? ? ? ? case LRU_POLICY: ?

? ? ? ? ? ? cacheObjects = new LinkedHashMap<K, V>(size, 0.75f, true) { ?

? ? ? ? ? ? ? ? /**?

? ? ? ? ? ? ? ? ?* ?

? ? ? ? ? ? ? ? ?*/ ?

? ? ? ? ? ? ? ? private static final long serialVersionUID = 1L; ?

? ? ? ? ? ? ? ? protected boolean removeEldestEntry(Map.Entry<K, V> eldest) { ?

? ? ? ? ? ? ? ? ? ? return size() > size; ?

? ? ? ? ? ? ? ? } ?

? ? ? ? ? ? }; ?

? ? ? ? ? ? break; ?

? ? ? ? default: ?

? ? ? ? ? ? throw new IllegalArgumentException("Unknown policy: " + policy); ?

? ? ? ? } ?

? ? } ?

? ? public void put(K key, V value) { ?

? ? ? ? cacheObjects.put(key, value); ?

? ? } ?

? ? public void get(K key) { ?

? ? ? ? cacheObjects.get(key); ?

? ? } ?

? ? public void remove(K key) { ?

? ? ? ? cacheObjects.remove(key); ?

? ? } ?

? ? public void clear() { ?

? ? ? ? cacheObjects.clear(); ?

? ? } ?

? ? ??

? ? public Set<Map.Entry<K, V>> entrySet() { ?

? ? ? ? return cacheObjects.entrySet(); ?

? ? } ?

} ?

/*?

size(10), policy(1) FIFO ?

11, 11?

12, 12?

13, 13?

14, 14?

15, 15?

5, 5?

4, 4?

3, 3?

2, 2?

1, 1?

size(10), policy(2) LRU ?

10, 10?

9, 9?

8, 8?

7, 7?

6, 6?

5, 5?

4, 4?

3, 3?

2, 2?

1, 1?

*/ ?


?

?

ObjectPoolDemo


/**?

?* ?

?*/ ?

package tune.program.memory; ?

import java.util.HashMap; ?

import java.util.Map; ?

import java.util.concurrent.CountDownLatch; ?

/**?

?* 使用對象緩存池:創建對象要消耗一定的CPU以及內存,使用對象緩存池一定程度上可降低JVM堆內存的使用。?

?* ?

?* @author yangwm Aug 24, 2010 4:34:47 PM?

?*/ ?

public class ObjectPoolDemo { ?

? ? private static int executeTimes = 10; ?

? ? private static int maxFactor = 10; ?

? ? private static int threadCount = 100; ?

? ? private static final int NOTUSE_OBJECTPOOL = 1; ?

? ? private static final int USE_OBJECTPOOL = 2; ?

? ? private static int runMode = ?NOTUSE_OBJECTPOOL; ?

? ? private static CountDownLatch latch = null; ?

? ? public static void main(String[] args) throws Exception { ?

? ? ? ? Task task = new Task(); ?

? ? ? ? long beginTime = System.currentTimeMillis(); ?

? ? ? ? for (int i = 0; i < executeTimes; i++) { ?

? ? ? ? ? ? System.out.println("Round: " + (i + 1)); ?

? ? ? ? ? ? latch = new CountDownLatch(threadCount); ?

? ? ? ? ? ? for (int j = 0; j < threadCount; j++) { ?

? ? ? ? ? ? ? ? new Thread(task).start(); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? latch.await(); ?

? ? ? ? } ?

? ? ? ? long endTime = System.currentTimeMillis(); ?

? ? ? ? System.out.println("Execute summary: Round( " + executeTimes + " ) Thread Per Round( " + threadCount ??

? ? ? ? ? ? ? ? + " ) Object Factor ( " + maxFactor + " ) Execute Time ( " + (endTime - beginTime) + " ) ms"); ?

? ? } ?

? ? ??

? ? static class Task implements Runnable { ?

? ? ? ? @Override ?

? ? ? ? public void run() { ?

? ? ? ? ? ? for (int j = 0; j < maxFactor; j++) { ?

? ? ? ? ? ? ? ? if (runMode == USE_OBJECTPOOL) { ?

? ? ? ? ? ? ? ? ? ? BigObjectPool.getInstance().getBigObject(j); ?

? ? ? ? ? ? ? ? } else { ?

? ? ? ? ? ? ? ? ? ? new BigObject(j); ?

? ? ? ? ? ? ? ? } ?

? ? ? ? ? ? } ?

? ? ? ? ? ? latch.countDown(); ?

? ? ? ? } ?

? ? ? ? ??

? ? } ?

? ? ??

? ? static class BigObjectPool { ?

? ? ? ? private static final BigObjectPool self = new BigObjectPool(); ?

? ? ? ? private final Map<Integer, BigObject> cacheObjects = new HashMap<Integer, BigObject>(); ?

? ? ? ? private BigObjectPool() { ?

? ? ? ? ? ? ??

? ? ? ? } ?

? ? ? ? public static BigObjectPool getInstance() { ?

? ? ? ? ? ? return self; ?

? ? ? ? } ?

? ? ? ? public BigObject getBigObject(int factor) { ?

? ? ? ? ? ? if (cacheObjects.containsKey(factor)) { ?

? ? ? ? ? ? ? ? return cacheObjects.get(factor); ?

? ? ? ? ? ? } else { ?

? ? ? ? ? ? ? ? BigObject object = new BigObject(factor); ?

? ? ? ? ? ? ? ? cacheObjects.put(factor, object); ?

? ? ? ? ? ? ? ? return object; ?

? ? ? ? ? ? } ?

? ? ? ? } ?

? ? } ?

? ? ??

? ? static class BigObject { ?

? ? ? ? private byte[] bytes = null; ?

? ? ? ? public BigObject(int factor) { ?

? ? ? ? ? ? bytes = new byte[(factor + 1) * 1024 * 1024]; ?

? ? ? ? } ?

? ? ? ? public byte[] getBytes() { ?

? ? ? ? ? ? return bytes; ?

? ? ? ? } ?

? ? } ?

? ? ??

} ?

/*?

-Xms128M -Xmx128M -Xmn64M , runMode is NOTUSE_OBJECTPOOL:?

Round: 1?

......?

Execute summary: Round( 10 ) Thread Per Round( 100 ) Object Factor ( 10 ) Execute Time ( 50672 ) ms?

-Xms128M -Xmx128M -Xmn64M , runMode is USE_OBJECTPOOL:?

Round: 1?

......?

Execute summary: Round( 10 ) Thread Per Round( 100 ) Object Factor ( 10 ) Execute Time ( 344 ) ms?

*/ ?


?

ThreadLocalDemo


/**?

?* ?

?*/ ?

package tune.program.memory; ?

import java.util.concurrent.ExecutorService; ?

import java.util.concurrent.Executors; ?

/**?

?* 釋放不必要的引用:代碼持有了不需要的對象引用,造成這些對象無法被GC,從而占據了JVM堆內存。?

?* (使用ThreadLocal:注意在線程內動作執行完畢時,需執行 ThreadLocal.set把對象清除,避免持有不必要的對象引用)?

?* ?

?* @author yangwm Aug 24, 2010 11:29:59 AM?

?*/ ?

public class ThreadLocalDemo { ?

? ? ??

? ? public static void main(String[] args) { ?

? ? ? ? ThreadLocalDemo demo = new ThreadLocalDemo(); ?

? ? ? ? demo.run(); ?

? ? } ?

? ? ??

? ? public void run() { ?

? ? ? ? ExecutorService executor = Executors.newFixedThreadPool(1); ?

? ? ? ? executor.execute(new Task()); ?

? ? ? ? System.gc(); ?

? ? } ?

? ? ??

? ? class Task implements Runnable { ?

? ? ? ? @Override ?

? ? ? ? public void run() { ?

? ? ? ? ? ? ThreadLocal<byte[]> localString = new ThreadLocal<byte[]>(); ?

? ? ? ? ? ? localString.set(new byte[1024 * 1024 * 30]); ?

? ? ? ? ? ? ??

? ? ? ? ? ? // 業務邏輯 ??

? ? ? ? ? ? ??

? ? ? ? ? ? //localString.set(null); // 釋放不必要的引用 ??

? ? ? ? } ?

? ? } ?

} ?


?

?

concurrent-----------------------------------------------------------------------

?

LockHotDemo

/**?

?* ?

?*/ ?

package tune.program.concurrent; ?

import java.util.Random; ?

import java.util.concurrent.CountDownLatch; ?

import java.util.concurrent.locks.Lock; ?

import java.util.concurrent.locks.ReentrantLock; ?

/**?

?* 鎖競爭的狀況會比較明顯,這時候線程很容易處于等待鎖的狀況,從而導致性能下降以及CPU sy上升?

?* ?

?* @author yangwm Aug 24, 2010 11:59:35 PM?

?*/ ?

public class LockHotDemo { ?

? ? private static int executeTimes = 10; ?

? ? private static int threadCount = Runtime.getRuntime().availableProcessors() * 100; ?

? ? private static CountDownLatch latch = null; ?

? ? ??

? ? public static void main(String[] args) throws Exception { ?

? ? ? ? HandleTask task = new HandleTask(); ?

? ? ? ? long beginTime = System.currentTimeMillis(); ?

? ? ? ? for (int i = 0; i < executeTimes; i++) { ?

? ? ? ? ? ? System.out.println("Round: " + (i + 1)); ?

? ? ? ? ? ? latch = new CountDownLatch(threadCount); ?

? ? ? ? ? ? for (int j = 0; j < threadCount; j++) { ?

? ? ? ? ? ? ? ? new Thread(task).start(); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? latch.await(); ?

? ? ? ? } ?

? ? ? ? long endTime = System.currentTimeMillis(); ?

? ? ? ? System.out.println("Execute summary: Round( " + executeTimes + " ) Thread Per Round( " + threadCount ??

? ? ? ? ? ? ? ? + " ) Execute Time ( " + (endTime - beginTime) + " ) ms"); ?

? ? } ?

? ? ??

? ? static class HandleTask implements Runnable { ?

? ? ? ? private final Random random = new Random(); ?

? ? ? ? @Override ?

? ? ? ? public void run() { ?

? ? ? ? ? ? Handler.getInstance().handle(random.nextInt(10000)); ?

? ? ? ? ? ? latch.countDown(); ?

? ? ? ? } ?

? ? ? ? ??

? ? } ?

? ? ??

? ? static class Handler { ?

? ? ? ? private static final Handler self = new Handler(); ?

? ? ? ? private final Random random = new Random(); ?

? ? ? ? private final Lock lock = new ReentrantLock(); ?

? ? ? ? private Handler() { ?

? ? ? ? ? ? ??

? ? ? ? } ?

? ? ? ? public static Handler getInstance() { ?

? ? ? ? ? ? return self; ?

? ? ? ? } ?

? ? ? ? public void handle(int id) { ?

? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? lock.lock(); ?

? ? ? ? ? ? ? ? ??

? ? ? ? ? ? ? ? // execute sth ?

? ? ? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? ? ? Thread.sleep(random.nextInt(10)); ?

? ? ? ? ? ? ? ? } catch (Exception e) { ?

? ? ? ? ? ? ? ? ? ? e.printStackTrace(); ?

? ? ? ? ? ? ? ? } ?

? ? ? ? ? ? } finally { ?

? ? ? ? ? ? ? ? lock.unlock(); ?

? ? ? ? ? ? } ?

? ? ? ? } ?

? ? } ?

} ?

/*?

Round: 1?

......?

Round: 10?

Execute summary: Round( 10 ) Thread Per Round( 200 ) Execute Time ( 10625 ) ms?

*/ ?


?

ReduceLockHotDemo

/**?

?* ?

?*/ ?

package tune.program.concurrent; ?

import java.util.Random; ?

import java.util.concurrent.CountDownLatch; ?

import java.util.concurrent.locks.Lock; ?

import java.util.concurrent.locks.ReentrantLock; ?

/**?

?* 盡可能少用鎖:盡可能只對需要控制的資源做加鎖操作?

?* ?

?* @author yangwm Aug 24, 2010 11:59:35 PM?

?*/ ?

public class ReduceLockHotDemo { ?

? ? private static int executeTimes = 10; ?

? ? private static int threadCount = Runtime.getRuntime().availableProcessors() * 100; ?

? ? private static CountDownLatch latch = null; ?

? ? ??

? ? public static void main(String[] args) throws Exception { ?

? ? ? ? HandleTask task = new HandleTask(); ?

? ? ? ? long beginTime = System.currentTimeMillis(); ?

? ? ? ? for (int i = 0; i < executeTimes; i++) { ?

? ? ? ? ? ? System.out.println("Round: " + (i + 1)); ?

? ? ? ? ? ? latch = new CountDownLatch(threadCount); ?

? ? ? ? ? ? for (int j = 0; j < threadCount; j++) { ?

? ? ? ? ? ? ? ? new Thread(task).start(); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? latch.await(); ?

? ? ? ? } ?

? ? ? ? long endTime = System.currentTimeMillis(); ?

? ? ? ? System.out.println("Execute summary: Round( " + executeTimes + " ) Thread Per Round( " + threadCount ??

? ? ? ? ? ? ? ? + " ) Execute Time ( " + (endTime - beginTime) + " ) ms"); ?

? ? } ?

? ? ??

? ? static class HandleTask implements Runnable { ?

? ? ? ? private final Random random = new Random(); ?

? ? ? ? @Override ?

? ? ? ? public void run() { ?

? ? ? ? ? ? Handler.getInstance().handle(random.nextInt(10000)); ?

? ? ? ? ? ? latch.countDown(); ?

? ? ? ? } ?

? ? ? ? ??

? ? } ?

? ? ??

? ? static class Handler { ?

? ? ? ? private static final Handler self = new Handler(); ?

? ? ? ? private final Random random = new Random(); ?

? ? ? ? private final Lock lock = new ReentrantLock(); ?

? ? ? ? private Handler() { ?

? ? ? ? ? ? ??

? ? ? ? } ?

? ? ? ? public static Handler getInstance() { ?

? ? ? ? ? ? return self; ?

? ? ? ? } ?

? ? ? ? public void handle(int id) { ?

? ? ? ? ? ? // execute sth don't need lock ?

? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? Thread.sleep(random.nextInt(5)); ?

? ? ? ? ? ? } catch (Exception e) { ?

? ? ? ? ? ? ? ? e.printStackTrace(); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? ??

? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? lock.lock(); ?

? ? ? ? ? ? ? ? ??

? ? ? ? ? ? ? ? // execute sth ?

? ? ? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? ? ? Thread.sleep(random.nextInt(5)); ?

? ? ? ? ? ? ? ? } catch (Exception e) { ?

? ? ? ? ? ? ? ? ? ? e.printStackTrace(); ?

? ? ? ? ? ? ? ? } ?

? ? ? ? ? ? } finally { ?

? ? ? ? ? ? ? ? lock.unlock(); ?

? ? ? ? ? ? } ?

? ? ? ? } ?

? ? } ?

} ?

/*?

Round: 1?

......?

Round: 10?

Execute summary: Round( 10 ) Thread Per Round( 200 ) Execute Time ( 5547 ) ms?

*/ ?


?

SplitReduceLockHotDemo

/**?

?* ?

?*/ ?

package tune.program.concurrent; ?

import java.util.Random; ?

import java.util.concurrent.CountDownLatch; ?

import java.util.concurrent.locks.Lock; ?

import java.util.concurrent.locks.ReentrantLock; ?

/**?

?* 盡可能少用鎖:盡可能只對需要控制的資源做加鎖操作?

?* 拆分鎖:獨占鎖拆分為多把鎖(讀寫鎖拆分、類似ConcurrentHashMap中默認拆分為16把鎖)?

?* ?

?* @author yangwm Aug 24, 2010 11:59:35 PM?

?*/ ?

public class SplitReduceLockHotDemo { ?

? ? private static int executeTimes = 10; ?

? ? private static int threadCount = Runtime.getRuntime().availableProcessors() * 100; ?

? ? private static CountDownLatch latch = null; ?

? ? ??

? ? public static void main(String[] args) throws Exception { ?

? ? ? ? HandleTask task = new HandleTask(); ?

? ? ? ? long beginTime = System.currentTimeMillis(); ?

? ? ? ? for (int i = 0; i < executeTimes; i++) { ?

? ? ? ? ? ? System.out.println("Round: " + (i + 1)); ?

? ? ? ? ? ? latch = new CountDownLatch(threadCount); ?

? ? ? ? ? ? for (int j = 0; j < threadCount; j++) { ?

? ? ? ? ? ? ? ? new Thread(task).start(); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? latch.await(); ?

? ? ? ? } ?

? ? ? ? long endTime = System.currentTimeMillis(); ?

? ? ? ? System.out.println("Execute summary: Round( " + executeTimes + " ) Thread Per Round( " + threadCount ??

? ? ? ? ? ? ? ? + " ) Execute Time ( " + (endTime - beginTime) + " ) ms"); ?

? ? } ?

? ? ??

? ? static class HandleTask implements Runnable { ?

? ? ? ? private final Random random = new Random(); ?

? ? ? ? @Override ?

? ? ? ? public void run() { ?

? ? ? ? ? ? Handler.getInstance().handle(random.nextInt(10000)); ?

? ? ? ? ? ? latch.countDown(); ?

? ? ? ? } ?

? ? ? ? ??

? ? } ?

? ? ??

? ? static class Handler { ?

? ? ? ? private static final Handler self = new Handler(); ?

? ? ? ? private final Random random = new Random(); ?

? ? ? ? private int lockCount = 10; ?

? ? ? ? private Lock[] locks = new Lock[lockCount]; ?

? ? ? ? private Handler() { ?

? ? ? ? ? ? for (int i = 0; i < lockCount; i++) { ?

? ? ? ? ? ? ? ? locks[i] = new ReentrantLock(); ?

? ? ? ? ? ? } ?

? ? ? ? } ?

? ? ? ? public static Handler getInstance() { ?

? ? ? ? ? ? return self; ?

? ? ? ? } ?

? ? ? ? public void handle(int id) { ?

? ? ? ? ? ? // execute sth don't need lock ?

? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? Thread.sleep(random.nextInt(5)); ?

? ? ? ? ? ? } catch (Exception e) { ?

? ? ? ? ? ? ? ? e.printStackTrace(); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? ??

? ? ? ? ? ? int mod = id % lockCount; ?

? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? locks[mod].lock(); ?

? ? ? ? ? ? ? ? ??

? ? ? ? ? ? ? ? // execute sth ?

? ? ? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? ? ? Thread.sleep(random.nextInt(5)); ?

? ? ? ? ? ? ? ? } catch (Exception e) { ?

? ? ? ? ? ? ? ? ? ? e.printStackTrace(); ?

? ? ? ? ? ? ? ? } ?

? ? ? ? ? ? } finally { ?

? ? ? ? ? ? ? ? locks[mod].unlock(); ?

? ? ? ? ? ? } ?

? ? ? ? } ?

? ? } ?

} ?

/*?

Round: 1?

......?

Round: 10?

Execute summary: Round( 10 ) Thread Per Round( 200 ) Execute Time ( 843 ) ms?

*/ ?


?

?

ConcurrentStack和StackBenchmark

/**?

?* ?

?*/ ?

package tune.program.concurrent; ?

import java.util.concurrent.atomic.AtomicReference; ?

/**?

?* 使用Treiber算法實現Stack:基于CAS以及AtomicReference。?

?* ?

?* @author yangwm Aug 25, 2010 10:50:17 AM?

?*/ ?

public class ConcurrentStack<E> { ?

? ? ??

? ? AtomicReference<Node<E>> head = new AtomicReference<Node<E>>(); ?

? ? public void push(E item) { ?

? ? ? ? Node<E> newHead = new Node<E>(item); ?

? ? ? ? Node<E> oldHead; ?

? ? ? ? do { ?

? ? ? ? ? ? oldHead = head.get(); ?

? ? ? ? ? ? newHead.next = oldHead; ?

? ? ? ? } while (!head.compareAndSet(oldHead, newHead)); ?

? ? } ?

? ? ??

? ? public E pop() { ?

? ? ? ? Node<E> oldHead; ?

? ? ? ? Node<E> newHead; ?

? ? ? ? do { ?

? ? ? ? ? ? oldHead = head.get(); ?

? ? ? ? ? ? if (oldHead == null) { ?

? ? ? ? ? ? ? ? return null; ?

? ? ? ? ? ? } ?

? ? ? ? ? ? newHead = oldHead.next; ?

? ? ? ? } while (!head.compareAndSet(oldHead, newHead)); ?

? ? ? ? return oldHead.item; ?

? ? } ?

? ? ??

? ? static class Node<E> { ?

? ? ? ? final E item; ?

? ? ? ? Node<E> next; ?

? ? ? ? public Node(E item) { ?

? ? ? ? ? ? this.item = item; ?

? ? ? ? } ?

? ? } ?

} ?

/**?

?* ?

?*/ ?

package tune.program.concurrent; ?

import java.util.Stack; ?

import java.util.concurrent.CountDownLatch; ?

import java.util.concurrent.CyclicBarrier; ?

/**?

?* 基準測試:Treiber算法實現Stack、同步實現的Stack ?

?* ?

?* @author yangwm Aug 25, 2010 11:36:14 AM?

?*/ ?

public class StackBenchmark { ?

? ? public static void main(String[] args) throws Exception { ?

? ? ? ? StackBenchmark stackBenchmark = new StackBenchmark(); ?

? ? ? ? stackBenchmark.run(); ?

? ? } ?

? ? ??

? ? ??

? ? private Stack<String> stack = new Stack<String>(); ?

? ? private ConcurrentStack<String> concurrentStack = new ConcurrentStack<String>(); ?

? ? private static final int THREAD_COUNT = 300; ?

? ? private CountDownLatch latch = new CountDownLatch(THREAD_COUNT); ?

? ? private CyclicBarrier barrier = new CyclicBarrier(THREAD_COUNT); ?

? ? ??

? ? public void run() throws Exception { ?

? ? ? ? StackTask stackTask = new StackTask(); ?

? ? ? ? long beginTime = System.currentTimeMillis(); ?

? ? ? ? for (int i = 0; i < THREAD_COUNT; i++) { ?

? ? ? ? ? ? new Thread(stackTask).start(); ?

? ? ? ? } ?

? ? ? ? latch.await(); ?

? ? ? ? long endTime = System.currentTimeMillis(); ?

? ? ? ? System.out.println("Stack consume Time: ?" + (endTime - beginTime) + " ms"); ?

? ? ? ? ??

? ? ? ? latch = new CountDownLatch(THREAD_COUNT); ?

? ? ? ? barrier = new CyclicBarrier(THREAD_COUNT); ?

? ? ? ? ConcurrentStackTask concurrentStackTask = new ConcurrentStackTask(); ?

? ? ? ? beginTime = System.currentTimeMillis(); ?

? ? ? ? for (int i = 0; i < THREAD_COUNT; i++) { ?

? ? ? ? ? ? new Thread(concurrentStackTask).start(); ?

? ? ? ? } ?

? ? ? ? latch.await(); ?

? ? ? ? endTime = System.currentTimeMillis(); ?

? ? ? ? System.out.println("ConcurrentStack consume Time: ?" + (endTime - beginTime) + " ms"); ?

? ? } ?

? ? ??

? ? class StackTask implements Runnable { ?

? ? ? ? ??

? ? ? ? @Override ?

? ? ? ? public void run() { ?

? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? barrier.await(); ?

? ? ? ? ? ? } catch (Exception e) { ?

? ? ? ? ? ? ? ? e.printStackTrace(); ?

? ? ? ? ? ? } ?

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

? ? ? ? ? ? ? ? stack.push(Thread.currentThread().getName()); ?

? ? ? ? ? ? ? ? stack.pop(); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? latch.countDown(); ?

? ? ? ? } ?

? ? ? ? ??

? ? } ?

? ? class ConcurrentStackTask implements Runnable { ?

? ? ? ? ??

? ? ? ? @Override ?

? ? ? ? public void run() { ?

? ? ? ? ? ? try { ?

? ? ? ? ? ? ? ? barrier.await(); ?

? ? ? ? ? ? } catch (Exception e) { ?

? ? ? ? ? ? ? ? e.printStackTrace(); ?

? ? ? ? ? ? } ?

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

? ? ? ? ? ? ? ? concurrentStack.push(Thread.currentThread().getName()); ?

? ? ? ? ? ? ? ? concurrentStack.pop(); ?

? ? ? ? ? ? } ?

? ? ? ? ? ? latch.countDown(); ?

? ? ? ? } ?

? ? ? ? ??

? ? } ?

? ? ??

} ?

/*?

Stack consume Time: ?94 ms?

ConcurrentStack consume Time: ?63 ms?

Stack consume Time: ?78 ms?

ConcurrentStack consume Time: ?62 ms?

*/ ?


轉載于:https://blog.51cto.com/332532/1770754

總結

以上是生活随笔為你收集整理的Java性能调优笔记的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

国产亚洲人成网站在线观看 | 正在播放国产精品 | 国产中文在线观看 | 91在线麻豆 | 婷婷婷国产在线视频 | 中文字幕一二三区 | 在线看成人 | 久久99深爱久久99精品 | 911久久香蕉国产线看观看 | 免费看的黄色 | 免费看色网站 | 日韩一区二区在线免费观看 | 日韩三级不卡 | av国产网站 | 色综合久久精品 | 在线色亚洲 | 精品国产一区二区三区四区vr | 精品国产免费一区二区三区五区 | 国产一区二区在线免费播放 | 国产人成免费视频 | 国产中文字幕视频在线 | 国产精品久久久久9999吃药 | 狠狠操狠狠干2017 | 国产亚洲午夜高清国产拍精品 | 91视频a| 精品久久国产 | 91麻豆精品国产91久久久久久久久 | 97天堂| 999电影免费在线观看 | 婷婷中文在线 | 成人黄色免费观看 | 欧美精品久久久久久久久老牛影院 | 色天天综合久久久久综合片 | 爱色婷婷 | 麻豆91在线播放 | 美国人与动物xxxx | 精品自拍网 | 在线国产片 | 久久视频免费看 | 国产亚洲精品久久久久久久久久 | 麻豆成人精品 | 五月婷丁香网 | 人人射人人爽 | 黄网站色视频 | 中文字幕高清视频 | 毛片二区| 国产精品福利一区 | 成人av电影在线播放 | 超碰97免费 | 成人av.com| 久久中文字幕在线视频 | www.com久久| 超碰在线观看97 | 久久久久久久久久久网 | 91精品系列 | 999久久久国产精品 高清av免费观看 | 亚洲国产中文字幕在线观看 | 曰韩在线 | 国产97碰免费视频 | 亚洲黄色在线观看 | 一区免费在线 | 五月婷婷久久丁香 | 国产中文字幕视频在线观看 | 91视频在线观看免费 | 欧美午夜剧场 | 亚洲影院国产 | 久久久久久黄色 | 高清不卡一区二区三区 | 黄色app网站在线观看 | 园产精品久久久久久久7电影 | 毛片888 | 国产黄色成人av | 婷婷在线看 | 亚洲精品成人在线 | 夜夜躁狠狠躁日日躁视频黑人 | 五月婷婷综合网 | 国内精品视频在线播放 | 在线视频国产区 | 国产一区二区三区久久久 | 日韩3区 | 亚洲国产精品推荐 | 日韩动态视频 | 欧美激情精品久久久久久变态 | 日韩精品免费在线观看视频 | 久久不见久久见免费影院 | 午夜精品久久久久久99热明星 | 日韩一区二区免费视频 | 久久中文字幕在线视频 | 亚洲精品成人av在线 | 久久精品免费看 | 国产精品久久久久婷婷二区次 | 美女网站在线观看 | 免费日韩视 | 国产精品一区二区av日韩在线 | 又爽又黄又无遮挡网站动态图 | 九九九九九精品 | 亚洲理论在线观看电影 | 亚洲成a人片77777kkkk1在线观看 | 九七在线视频 | 久久九九影院 | 三级黄色免费片 | av免费在线观 | 狠狠色网 | 麻豆视频免费入口 | 一区二区三区四区五区在线 | 精品久久久久久国产偷窥 | 国产精品美女在线观看 | 亚洲精品久久久久久久蜜桃 | 蜜臀久久99精品久久久无需会员 | 国产成人免费高清 | 亚洲专区中文字幕 | 免费观看的av网站 | 人人爽夜夜爽 | 欧美色图亚洲图片 | 久香蕉 | 成人97视频 | 欧美综合色 | 国产精品久久久久999 | 伊香蕉大综综综合久久啪 | av在线之家电影网站 | 日韩在线 | 久久精品亚洲综合专区 | 日本中文字幕视频 | 免费91麻豆精品国产自产在线观看 | 爱爱av在线| 一区二区欧美激情 | 国产99精品在线观看 | 日韩在线免费观看视频 | 五月婷在线视频 | 一级黄色片在线免费观看 | 天海冀一区二区三区 | 日本公妇在线观看 | 碰超在线 | av青草 | 国产高清精 | 国产一区二区不卡视频 | 亚洲精品在线网站 | 日本高清xxxx | 最新91在线视频 | 免费福利视频导航 | 色婷婷国产在线 | 中文字幕中文字幕 | 亚洲日本欧美在线 | 久草在线资源视频 | 国产一级精品视频 | 中文字幕在线国产精品 | 五月天电影免费在线观看一区 | 日本在线视频一区二区三区 | 五月婷影院| 色婷久久| 亚洲成人999 | 成人欧美一区二区三区黑人麻豆 | 国产精品美女久久久久久 | 国产一区二区三精品久久久无广告 | 成人黄色免费在线观看 | 免费看国产一级片 | 毛片网站在线观看 | 精品中文字幕在线播放 | 人人干在线观看 | 国产精品原创av片国产免费 | 久久精品视频3 | 国产精品12| 国产欧美久久久精品影院 | 久久成人18免费网站 | 国内视频 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 国产精品爽爽爽 | 香蕉视频在线免费看 | 国产精品久久久久久五月尺 | www.久久久.com | 天天爽夜夜爽精品视频婷婷 | 国产色婷婷 | 国产精品久久久99 | 99精品一区 | 日韩大陆欧美高清视频区 | 免费观看全黄做爰大片国产 | 久草免费在线视频 | 又爽又黄在线观看 | 99精品国产99久久久久久福利 | 国产成人精品亚洲精品 | 韩国av一区二区三区在线观看 | 狂野欧美激情性xxxx欧美 | 国产亚洲精品久久19p | 最新国产精品视频 | 美女免费av | 99久久综合国产精品二区 | 手机在线黄色网址 | 在线观看日韩中文字幕 | 天堂黄色片 | 久久久久久久久久久福利 | 国产99久久久久久免费看 | 在线免费黄色片 | 国产精品区免费视频 | 国产精品黑丝在线观看 | 欧美日韩一级久久久久久免费看 | freejavvideo日本免费 | 精品国产一区二区三区噜噜噜 | 国产在线精品一区二区不卡了 | 狠狠干免费| 中文字幕在线观看视频一区二区三区 | 天天摸天天干天天操天天射 | 婷色在线| 国产小视频免费在线网址 | 69性欧美| 99视频在线免费播放 | 日本精品中文字幕在线观看 | 亚洲国产中文字幕在线观看 | 九九久久精品 | 国产精品ⅴa有声小说 | 欧美激情精品久久久久久免费 | 日韩成人av在线 | 国产精品mm| av免费在线免费观看 | 久久久久久久久久久成人 | 国产精品18p| 婷婷伊人综合 | 久久精品中文字幕少妇 | 日韩欧美一区二区在线播放 | 欧美天天综合 | 在线国产一区二区三区 | 亚洲精品国产自产拍在线观看 | 国产精品美女免费看 | 99久久综合国产精品二区 | 96久久欧美麻豆网站 | 免费国产在线观看 | 久久草精品 | 麻豆精品传媒视频 | 亚洲午夜精品福利 | 精品久久久久久综合日本 | 日韩女同av | 最近中文字幕免费 | 中文字幕人成不卡一区 | 日本中文字幕免费观看 | 中文字幕专区高清在线观看 | 亚洲视频一区二区三区在线观看 | 日本精品一区二区三区在线播放视频 | 中文字幕在线影院 | 国产电影黄色av | 国产精品视频最多的网站 | 久操综合| 日韩av电影手机在线观看 | 国产精品久久久久久久久久 | 天天插伊人| 91在线精品秘密一区二区 | 国产成年人av | 超碰在线97观看 | www久久九 | 麻豆久久精品 | 国产精品久久久久久久久久直播 | 正在播放五月婷婷狠狠干 | 国产精品久久99 | 特级大胆西西4444www | 久久99久久精品 | 三级视频日韩 | 亚洲五月婷 | 国产a高清 | 黄色aaaaa| 狠狠色综合网站久久久久久久 | 国产视频精品久久 | 日日夜夜婷婷 | 久操视频在线 | 超级碰碰碰碰 | 免费男女羞羞的视频网站中文字幕 | 99r在线视频| 国产极品尤物在线 | av在线播放观看 | 婷婷视频在线观看 | 美女黄视频免费看 | 亚洲欧美成人综合 | 久久午夜电影 | 精品国产成人在线影院 | 中文字幕色网站 | www.狠狠操 | 色资源在线 | 日本视频精品 | 久久久午夜精品福利内容 | 精品久久网 | 天天搞天天干天天色 | 欧美精品一区二区免费 | 91视频免费观看 | 久久成 | 欧美日韩视频一区二区三区 | 中文字幕精 | 国产亚洲小视频 | 国产伦精品一区二区三区照片91 | 欧美一区二区伦理片 | 久久久免费毛片 | 久久综合色一综合色88 | 国产91欧美 | 成人免费ⅴa | 国产精品久久久久久久免费 | 西西44人体做爰大胆视频 | 欧美一二三视频 | 国产专区精品视频 | 亚洲精品日韩av | 午夜精品一区二区三区可下载 | 成人亚洲精品久久久久 | 久久久精品小视频 | 亚州精品天堂中文字幕 | www.xxx.性狂虐 | 天天天插| 精品久久久影院 | 亚洲影视九九影院在线观看 | 五月花婷婷 | 日本视频高清 | 97在线观看免费高清完整版在线观看 | 97超碰伊人| 成年人毛片在线观看 | 17videosex性欧美 | 欧洲在线免费视频 | 很黄很黄的网站免费的 | 久草久视频| 五月天婷婷在线播放 | 久久精精品视频 | 色婷婷88av视频一二三区 | 免费合欢视频成人app | 久久中文视频 | 久久国产视屏 | 国产视频高清 | 日韩中文字幕a | 国产999精品久久久久久麻豆 | 精品一二三区 | 人九九精品 | 日韩一区二区三区不卡 | 亚洲精品影视在线观看 | 五月综合色 | 91精品免费在线观看 | 在线色亚洲| 欧美午夜剧场 | 精品少妇一区二区三区在线 | 国产精品视频99 | 亚洲女欲精品久久久久久久18 | 久久91久久久久麻豆精品 | 在线播放第一页 | 成人一级在线观看 | 久草视频免费播放 | 国产一区二区在线免费播放 | 国产精品视频全国免费观看 | 开心色停停 | 日韩欧美网址 | 日韩黄色免费 | 最新日韩在线观看视频 | 麻花豆传媒mv在线观看网站 | 欧日韩在线视频 | 中文字幕在线看视频 | 国产视频不卡一区 | 欧美极品少妇xbxb性爽爽视频 | 中文一区在线观看 | 免费日p视频 | 日日操夜| 激情综合网色播五月 | 国产一区二三区好的 | 欧美日韩午夜爽爽 | 日韩小视频网站 | 91精品久久久久久久久 | 久久成人毛片 | 成人蜜桃 | 日韩美视频 | 在线观看不卡视频 | 久草在在线视频 | 日本久久综合网 | 国产精品第7页 | 成年人视频在线 | 激情婷婷亚洲 | 欧美贵妇性狂欢 | 国产精品成人免费精品自在线观看 | 中文字幕高清视频 | 亚洲视频1区2区 | 久草a在线 | 日韩免费大片 | 国产精品成人一区二区三区 | 色免费在线 | 91高清免费观看 | 激情偷乱人伦小说视频在线观看 | 精品久久影院 | 91探花在线 | 久久精品视频免费观看 | h动漫中文字幕 | 美女国产 | 人人模人人爽 | 不卡的av电影 | 亚洲一区二区精品3399 | 亚洲精品在线一区二区 | 中文字幕一区二区在线播放 | 日韩精品免费专区 | 日韩偷拍精品 | 91视频久久久久 | 91污在线观看 | av日韩av| 青青草国产成人99久久 | 天天翘av| 久久久午夜精品理论片中文字幕 | 看全黄大色黄大片 | 一区二区久久久久 | 久久久久久片 | 亚洲视频在线免费看 | 视频在线观看91 | 色资源网在线观看 | 中文字幕在线中文 | 免费色视频在线 | 中文字幕在线观看91 | 国产视频观看 | 99精品视频一区 | 97人人澡人人爽人人模亚洲 | 五月亚洲综合 | 夜夜骑天天操 | 日韩欧美精选 | 狠狠操导航 | 天天干人人 | 狠狠色丁香婷婷综合久小说久 | av观看在线观看 | 久久a v视频 | 成人精品一区二区三区电影免费 | 精品福利网 | 国产精品婷婷 | 99爱视频在线观看 | 在线观看视频国产 | 亚洲精品久久久蜜臀下载官网 | 亚洲精品久久久久久久不卡四虎 | 久久综合色8888 | 国内揄拍国产精品 | 亚洲精品自拍视频在线观看 | www.91国产| 天天操天天添天天吹 | 成人网444ppp | 国产精品美女免费看 | 久久99精品一区二区三区三区 | 欧美va电影 | 在线成人免费 | 中文字幕在线观看第二页 | 国产一区欧美一区 | 久久久久久久久久电影 | 日本精品久久久一区二区三区 | 精品v亚洲v欧美v高清v | 精品在线观看一区二区 | 狠狠狠色丁香综合久久天下网 | 日韩欧美在线高清 | 国产麻豆剧果冻传媒视频播放量 | 亚洲天堂精品 | 成人在线免费观看视视频 | 91成人免费看 | 成人亚洲欧美 | 欧美人体xx | 一区二区三区免费看 | av线上看| 狠狠的日日 | 国产又粗又硬又爽视频 | 狠狠狠狠狠狠天天爱 | 懂色av懂色av粉嫩av分享吧 | 婷婷电影在线观看 | 日韩午夜精品福利 | 久久久久久久久影院 | 丁香网婷婷 | 51久久夜色精品国产麻豆 | 91免费试看| 99在线热播精品免费99热 | 有码视频在线观看 | 爱爱av网 | 国产精品久久久久久久久岛 | 日韩av午夜在线观看 | 色综合激情网 | 美女网站黄免费 | 日韩色区 | 91大神视频网站 | 91亚洲精品国偷拍自产在线观看 | 国产91在线免费视频 | 午夜色影院 | 在线观看视频色 | av在线成人 | 黄色小网站在线观看 | 在线视频一二三 | 日韩69视频 | 国产精品女人久久久久久 | av夜夜操 | 九草在线观看 | 香蕉在线观看视频 | 免费观看www7722午夜电影 | 日韩电影一区二区三区 | 99久久精品一区二区成人 | 美女黄视频免费 | 精品久久久久久电影 | 欧美日韩亚洲国产一区 | 麻豆精品传媒视频 | 日日爱av| 久久国产高清视频 | www夜夜操 | 日本三级全黄少妇三2023 | 久久久麻豆 | 中文字幕一区2区3区 | 免费观看性生活大片 | 特及黄色片 | av在线中文| av色图天堂网 | 国产精品资源在线 | 国产精品观看 | 日韩精品一区二区三区在线视频 | 中文字幕国产精品一区二区 | 在线视频一区二区 | 香蕉影院在线播放 | 久久香蕉国产 | 97超碰在线资源 | 免费特级黄毛片 | 久久高清片 | 在线99视频 | 一级免费黄色 | 亚洲国产资源 | 91在线观看欧美日韩 | av动态图片 | av免费网页| 久九视频 | 99在线免费观看视频 | 美国av片在线观看 | 日韩欧美精选 | 久久9精品 | 97超在线 | 456成人精品影院 | 中文字幕久久亚洲 | 久久久久成人免费 | 国产精品久久一 | 亚洲精品88欧美一区二区 | 在线视频你懂 | 中文字幕日本在线观看 | 久久热亚洲 | 黄色在线免费观看网址 | 国产日韩精品一区二区在线观看播放 | 国产精品久久久久久999 | 亚洲欧洲一级 | 久久成人福利 | 91麻豆精品国产91久久久使用方法 | 亚洲国产精品va在线 | 蜜桃久久久 | a天堂中文在线 | 国产高清在线a视频大全 | 日本夜夜草视频网站 | 丁香影院在线 | 综合中文字幕 | 亚洲激情在线视频 | 欧美精品一区二区三区一线天视频 | 亚洲国产成人精品在线 | 免费看三级黄色片 | 亚洲v欧美v国产v在线观看 | 亚洲第一伊人 | 欧美日韩不卡在线 | 在线导航福利 | 色噜噜日韩精品一区二区三区视频 | 成人a免费| 国内久久精品 | 91亚洲狠狠婷婷综合久久久 | 午夜三级在线 | 毛片区| 伊人网av | 成人免费观看完整版电影 | 欧美日本在线视频 | 四月婷婷在线观看 | 亚洲精品视频大全 | 日日夜夜91 | 亚洲精品国产品国语在线 | 亚洲另类视频在线 | 国产在线国偷精品产拍免费yy | a亚洲视频 | 欧美在线观看视频一区二区三区 | 成人中文字幕av | 日韩欧美高清一区二区三区 | 99久久99久久精品国产片 | 国产资源av | 天天摸夜夜添 | 国产精品久久久久久久久久三级 | 国产精品二区在线 | 二区视频在线观看 | 国产无套视频 | 激情电影影院 | 手机成人av | 国产精品亚州 | 99热这里只有精品国产首页 | 久久97久久 | 岛国一区在线 | 91天堂在线观看 | 国产一区二区三区在线 | 国产精品美女久久久久久久 | 精品国产亚洲在线 | 国产自产高清不卡 | 涩涩网站在线播放 | 国产精品自产拍在线观看桃花 | 国际精品久久久久 | 国产精品一区二区久久久 | 在线不卡的av | 亚洲免费精品视频 | 精品视频在线视频 | 国产三级精品三级在线观看 | 日韩免费一级a毛片在线播放一级 | 在线视频 91 | 色综合久久五月 | 久草手机视频 | 欧美激情视频在线免费观看 | 99中文字幕视频 | 中文在线字幕免费观 | 超碰在线网 | 午夜精品久久久久久99热明星 | 成人av在线直播 | 91成年人视频 | 中字幕视频在线永久在线观看免费 | 日日添夜夜添 | 久精品视频在线 | 日韩精品视频第一页 | 狠狠干中文字幕 | 波多野结衣电影一区二区三区 | 国产黄色播放 | 黄色成人小视频 | 国内外成人在线 | 色免费在线 | 色开心 | 精品成人久久 | 婷婷性综合 | 99久久99久久综合 | 人人操日日干 | 免费黄色网址大全 | 日韩av片无码一区二区不卡电影 | 久久国产区 | 99在线观看视频网站 | 99在线国产 | 伊人五月天 | 亚洲精品裸体 | 国产成人av一区二区三区在线观看 | 成人免费视频观看 | 四虎影视成人精品国库在线观看 | 激情婷婷亚洲 | 欧美国产精品久久久久久免费 | 69视频国产 | 人人超碰免费 | 在线亚洲天堂网 | 日韩在线色视频 | 中文字幕乱码视频 | 狠狠干夜夜 | 欧美另类一二三四区 | 区一区二在线 | 五月激情丁香 | 亚洲 在线 | 亚洲成人网在线 | 亚洲国产精品传媒在线观看 | 久久在线免费观看视频 | 亚洲成人蜜桃 | 国产精品扒开做爽爽的视频 | 久草免费新视频 | 91视频免费网站 | 日日夜夜精品网站 | 精品夜夜嗨av一区二区三区 | 欧美一级在线观看视频 | 欧美精品亚洲精品日韩精品 | 在线观看岛国av | 国内精品久久久久久久影视简单 | 亚洲精品国偷拍自产在线观看蜜桃 | 亚洲一二区精品 | 国内精品中文字幕 | 国产999在线| 九色91福利 | 500部大龄熟乱视频 欧美日本三级 | 天天射天天色天天干 | 精品一区二区免费在线观看 | 天天干天天综合 | 久草在线免费在线观看 | 99福利影院 | 日本精品一 | 九九色网| 中文字幕一区二区在线播放 | 国产.精品.日韩.另类.中文.在线.播放 | 亚洲日本va午夜在线电影 | 丰满少妇高潮在线观看 | 欧洲av不卡| 不卡的av中文字幕 | 综合在线色 | 97在线播放 | 中文在线字幕免费观 | 中文av在线免费观看 | 岛国精品一区二区 | 中文字幕精品视频 | 成人午夜电影在线播放 | 五月天激情综合 | 91私密视频 | 久久精品久久精品 | 国产高清黄 | av网站免费线看精品 | 又爽又黄在线观看 | 亚洲精品一区二区精华 | 一级理论片在线观看 | 99免在线观看免费视频高清 | 四虎成人网 | 999ZYZ玖玖资源站永久 | 最新日韩中文字幕 | 精品人妖videos欧美人妖 | 精品久久国产 | 成人91视频| 中文字幕免费看 | 中文视频在线看 | 国内精品视频在线 | 日韩久久精品一区二区 | 久久99国产综合精品 | 日韩最新在线 | 日本中文字幕网 | 成人综合婷婷国产精品久久免费 | 成av在线 | 五月天激情综合网 | 国产精品免费一区二区三区 | 久久精品99国产精品日本 | 特级毛片网站 | 久久综合色天天久久综合图片 | 久久精品亚洲 | 一区二区视频播放 | 婷婷在线五月 | 波多野结衣在线观看一区二区三区 | www.狠狠操 | 亚洲干| 婷婷激情久久 | 在线激情av电影 | 国内精品在线一区 | 国产精品一区二区三区在线 | 成人黄色毛片视频 | 日韩欧美视频二区 | 最近中文字幕免费观看 | 亚洲va天堂va欧美ⅴa在线 | 国产成人av电影在线 | 久久视频免费在线 | 激情综合婷婷 | 91成品人影院 | 国产美腿白丝袜足在线av | 亚洲精品乱码久久久久 | av.com在线| 国产成人在线网站 | 国产成人综合在线观看 | 97电影院在线观看 | 九九免费在线观看视频 | japanesexxx乱女另类 | 午夜电影中文字幕 | 综合网天天射 | 久久久久亚洲最大xxxx | 国产黄色片一级三级 | 亚洲精品美女免费 | 欧美久久久一区二区三区 | 欧美另类v | 一区二区三区免费在线 | 亚洲午夜久久久久久久久久久 | 免费观看mv大片高清 | 精品国产一区二区三区在线 | wwwwwww色| 美女黄视频免费看 | 亚洲电影一级黄 | 日韩在线观看一区二区 | 日b黄色片 | 91中文字幕在线观看 | www.69xx | www.com.日本一级 | 99热这里只有精品1 av中文字幕日韩 | 香蕉网在线观看 | 亚洲精品午夜一区人人爽 | 黄色大片视频网站 | 日韩电影一区二区三区在线观看 | 国产亚洲精品女人久久久久久 | 96精品高清视频在线观看软件特色 | www色婷婷com| 日韩激情视频在线观看 | 日韩在线视频看看 | 激情欧美一区二区三区免费看 | 午夜精品久久一牛影视 | 菠萝菠萝在线精品视频 | 波多野结衣视频一区二区 | 国产精品久久久久久久久搜平片 | 亚洲精品视频在线观看视频 | zzijzzij亚洲日本少妇熟睡 | 久久人人爽人人爽人人片av免费 | 四虎www. | 国产成人不卡 | 美女福利视频一区二区 | 国产99久久久久 | 97超视频在线观看 | 久草在线视频首页 | 国产精品久久久久婷婷二区次 | 日韩精品极品视频 | 日韩精品不卡在线 | 久色小说 | 日韩免费| 国产原厂视频在线观看 | 在线精品观看国产 | 18做爰免费视频网站 | 久久精品草 | 国产高清不卡一区二区三区 | 嫩草伊人久久精品少妇av | 懂色av一区二区三区蜜臀 | 在线观看免费版高清版 | 亚洲第一香蕉视频 | 成人性生交大片免费观看网站 | 亚洲欧洲精品在线 | 亚洲精品乱码久久久久久写真 | 在线视频18在线视频4k | 日韩成人在线免费观看 | 九九免费在线观看视频 | 亚洲精品大全 | 欧美了一区在线观看 | 色综合天天 | 在线视频 你懂得 | 欧美亚洲国产一卡 | 深夜福利视频在线观看 | 欧美日韩精品国产 | 婷婷在线免费 | 国产 在线 高清 精品 | 久久久天堂 | 国产一区二区中文字幕 | 麻豆精品在线视频 | 高清不卡一区二区在线 | 一区二区在线电影 | 欧美精品在线视频观看 | 激情开心 | 国产精品mv在线观看 | 色噜噜色噜噜 | 天天色综合1| 精品久久免费看 | 91精品国产三级a在线观看 | 国产伦精品一区二区三区高清 | 色婷婷电影| 精品欧美一区二区三区久久久 | av在线播放国产 | 成人免费xxxxxx视频 | 欧美性色综合网站 | 97综合视频 | 亚洲精品小区久久久久久 | 在线中文字幕网站 | 久久免费福利 | 亚洲视频第一页 | 中文字幕文字幕一区二区 | 国产免费亚洲高清 | 日韩手机在线观看 | 国产一级二级视频 | 久久a久久 | 久久视频热 | 亚洲激情视频在线观看 | 日韩视频中文 | 在线视频成人 | 亚洲成人蜜桃 | 国产在线看 | 亚洲国产一区二区精品专区 | 日韩精品在线视频免费观看 | 国产精品一区二区在线播放 | 夜夜操夜夜干 | 久草精品在线观看 | 精品福利国产 | 网址你懂的在线观看 | 亚洲精品www.| 国产精品手机播放 | 久草视频在线免费看 | 亚洲高清资源 | 国产欧美精品在线观看 | 亚洲三级在线 | 国产福利精品在线观看 | 亚洲精品乱码久久久久v最新版 | 成年人在线观看免费视频 | 中文字幕在线免费播放 | 亚洲成 人精品 | 久久 一区 | 天堂av在线中文在线 | 日本在线观看一区 | 成人在线免费观看视视频 | 91精品国产成人观看 | 久久精品日本啪啪涩涩 | 999电影免费在线观看2020 | 国产精品美女久久久免费 | 99久久精品日本一区二区免费 | 免费看的毛片 | 黄色毛片视频免费观看中文 | 午夜一级免费电影 | 欧美一级专区免费大片 | 久草视频首页 | www黄| 亚洲人人爱 | 婷婷丁香在线视频 | 欧美激情另类文学 | 麻豆传媒视频在线播放 | 四虎欧美 | 成人小视频在线免费观看 | 国产色婷婷精品综合在线手机播放 | 美女激情影院 | 日韩精品首页 | 天天操月月操 | 亚洲乱码久久久 | 成人在线视频在线观看 | 黄色av电影 | 在线网站黄 | 欧美日本一二三 | 亚洲区视频在线观看 | 99在线热播精品免费99热 | 激情久久五月 | 日韩免费一区二区在线观看 | 久久污视频 | 天天狠狠干 | 欧美日韩在线观看不卡 | a级片韩国| 国产99久久九九精品 | 中文字幕在线观看第一区 | 丁香花在线观看视频在线 | 人交video另类hd | 美女国产精品 | 日韩高清在线不卡 | 久久久人人爽 | 黄色av一区二区三区 | 少妇精品久久久一区二区免费 | 国产精品99蜜臀久久不卡二区 | 成人黄大片 | 国产黑丝一区二区三区 | 在线a视频免费观看 | 在线黄av | 高清精品在线 | 99久久精品国产亚洲 | 精品黄色在线观看 | 午夜精品久久久久久久99水蜜桃 | 亚洲美女在线一区 | 天堂av免费 | 欧美-第1页-屁屁影院 | 欧美-第1页-屁屁影院 | 国产免费亚洲高清 | 日本久久91| 久久特级毛片 | 伊人婷婷在线 | 久久亚洲日本 | 日韩高清www | 久久不卡日韩美女 | av免费电影在线观看 | 日本aaa在线观看 | 久久精品韩国 | 超碰在线公开免费 | 久久综合九色99 | 99久久综合狠狠综合久久 | 国内精品中文字幕 | 一区二区视频在线看 | av看片网址 | 日韩欧美国产视频 | 日日麻批40分钟视频免费观看 | 性色大片在线观看 | 久久er99热精品一区二区 | 国产精品免费小视频 | 国产亚洲精品久久久久久 | 一本一道久久a久久精品 | 不卡的av在线 | 91精品国产乱码 | 日韩欧美一区二区三区在线 | 中文在线字幕免费观看 | 国产亚洲精品免费 | 91成人短视频在线观看 | 国产一区私人高清影院 | 国产精品12 | 91免费看黄 | 国产高清av | 一区二区三区在线播放 | 97av精品 | 免费大片av| 国产福利一区二区三区视频 | 97免费在线观看视频 | 在线观看久久久久久 | 青青草国产成人99久久 | 中文字幕 国产精品 | 特级大胆西西4444www | 亚洲jizzjizz日本少妇 | 欧美夫妻生活视频 | 激情网五月婷婷 | 视频在线播放国产 | 不卡的av电影在线观看 | 国产91精品一区二区麻豆网站 | 免费不卡中文字幕视频 | 麻豆国产电影 | 亚洲欧美偷拍另类 | 五月婷婷,六月丁香 | 欧美精品久久人人躁人人爽 | av中文字幕在线电影 | 美女av免费 | 天天草天天草 | 精品一二三区视频 | av丁香| 91精品国产网站 | 超碰97人人爱 | 可以免费观看的av片 | 色综合久久久久 | 亚洲精品乱码久久久久v最新版 | 在线视频婷婷 | 久草在线免费新视频 | 五月婷婷综合在线视频 | 91成人短视频在线观看 | 少妇bbb搡bbbb搡bbbb | 精品视频一区在线观看 | 久久激情五月激情 | 91精品91| 欧美成人精品欧美一级乱 | 精品久久亚洲 | 亚洲精品在线观看av | 久久美女精品 | 亚洲精品在线观看视频 | 在线观看一区二区精品 | 黄色av一区二区三区 | 精品国产中文字幕 | 五月婷婷开心中文字幕 | 精品人人爽 | 亚洲码国产日韩欧美高潮在线播放 | 国产精品美女久久久久久久久 |