亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? performancetest.java

?? Apache的通用池Jar包
?? JAVA
字號:
/*
 * Copyright 1999-2004 The Apache Software Foundation.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.apache.commons.pool.performance;

import org.apache.commons.pool.impl.GenericObjectPool;

/**
 * Multi-thread performance test
 * 
 * @author Dirk Verbeeck
 * @version $Revision: 1.5 $ $Date: 2004/02/28 12:16:21 $ 
 */
public class PerformanceTest {
    private int logLevel = 0;
    private int nrIterations = 5;
    private int nrThreads = 100;

    private GenericObjectPool pool;
    private boolean start = false;
    private volatile int waiting = 0;
    private volatile int complete = 0;
    private volatile long totalBorrowTime = 0;
    private volatile long totalReturnTime = 0;
    private volatile int nrSamples = 0; 

    public void setLogLevel(int i) {
        logLevel = i;
    }
    
    private void init() {
        start = false;
        waiting = 0;
        complete = 0;
        totalBorrowTime = 0;
        totalReturnTime = 0;
        nrSamples = 0;     
    }

    class MyThread implements Runnable {
        long borrowTime;
        long returnTime;

        public void runOnce() {
            try {
                waiting++;
                if (logLevel >= 5) {
                    String name = "thread" + Thread.currentThread().getName();
                    System.out.println(name + "   waiting: " + waiting + "   complete: " + complete);
                }
                long bbegin = System.currentTimeMillis();
                Object o = pool.borrowObject();
                long bend = System.currentTimeMillis();
                waiting--;
                do {
                    Thread.yield();
                }
                while (!start);

                if (logLevel >= 3) {
                    String name = "thread" + Thread.currentThread().getName();
                    System.out.println(name + "    waiting: " + waiting + "   complete: " + complete);
                }
                                 
                long rbegin = System.currentTimeMillis();
                pool.returnObject(o);
                long rend = System.currentTimeMillis();
                Thread.yield();
                complete++;
                borrowTime = (bend-bbegin);
                returnTime = (rend-rbegin);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }

        public void run() {
            runOnce(); // warmup
            for (int i = 0; i<nrIterations; i++) {
                runOnce();
                totalBorrowTime += borrowTime;
                totalReturnTime += returnTime;
                nrSamples++;
                if (logLevel >= 2) {
                    String name = "thread" + Thread.currentThread().getName();
                    System.out.println(
                        "result " + nrSamples + "\t" + name 
                        + "\t" + "borrow time: " + borrowTime + "\t" + "return time: " + returnTime
                        + "\t" + "waiting: " + waiting + "\t" + "complete: " + complete);
                }
            }
        }
    }

    private void run(int nrIterations, int nrThreads, int maxActive, int maxIdle) {
        this.nrIterations = nrIterations;
        this.nrThreads = nrThreads;
        init();
        
        SleepingObjectFactory factory = new SleepingObjectFactory();
        if (logLevel >= 4) { factory.setDebug(true); } 
        pool = new GenericObjectPool(factory);
        pool.setMaxActive(maxActive);
        pool.setMaxIdle(maxIdle);
        pool.setTestOnBorrow(true);

        Thread[] threads = new Thread[nrThreads];
        for (int i = 0; i < threads.length; i++) {
            threads[i]= new Thread(new MyThread(), Integer.toString(i));
            Thread.yield();
        }
        if (logLevel >= 1) { System.out.println("created"); } 
        Thread.yield();

        for (int i = 0; i < threads.length; i++) {
            threads[i].start();
            Thread.yield();
        }
        if (logLevel >= 1) { System.out.println("started"); }
        Thread.yield();

        start = true;
        if (logLevel >= 1) { System.out.println("go"); }
        Thread.yield();

        for (int i = 0; i < threads.length; i++) {
            try {
                threads[i].join();
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
        if (logLevel >= 1) { System.out.println("finish"); }
        System.out.println("-----------------------------------------");
        System.out.println("nrIterations: " + nrIterations);
        System.out.println("nrThreads: " + nrThreads);
        System.out.println("maxActive: " + maxActive);
        System.out.println("maxIdle: " + maxIdle);
        System.out.println("nrSamples: " + nrSamples);
        System.out.println("totalBorrowTime: " + totalBorrowTime);
        System.out.println("totalReturnTime: " + totalReturnTime);
        System.out.println("avg BorrowTime: " + totalBorrowTime/nrSamples);
        System.out.println("avg ReturnTime: " + totalReturnTime/nrSamples);
    }

    public static void main(String[] args) {
        PerformanceTest test = new PerformanceTest();
        test.setLogLevel(0);
        System.out.println("Increase threads");
        test.run(1,  50,  5,  5);
        test.run(1, 100,  5,  5);
        test.run(1, 200,  5,  5);
        test.run(1, 400,  5,  5);

        System.out.println("Increase threads & poolsize");
        test.run(1,  50,  5,  5);
        test.run(1, 100, 10, 10);
        test.run(1, 200, 20, 20);
        test.run(1, 400, 40, 40);

        System.out.println("Increase maxIdle");
        test.run(1, 400, 40,  5);
        test.run(1, 400, 40, 40);


//      System.out.println("Show creation/destruction of objects");
//      test.setLogLevel(4);
//      test.run(1, 400, 40,  5);
    }

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲地区一二三色| 91丨国产丨九色丨pron| 国产高清在线精品| 成人av网站免费观看| 欧美日韩亚洲综合一区二区三区| 日韩三级电影网址| 亚洲免费三区一区二区| 精品一区二区免费看| 欧美亚日韩国产aⅴ精品中极品| 精品国产亚洲在线| 亚洲国产精品久久一线不卡| 岛国一区二区在线观看| 91精品国产综合久久福利| 国产精品污网站| 激情综合五月婷婷| 欧美精品18+| 伊人夜夜躁av伊人久久| 成人一级黄色片| 日韩免费电影一区| 午夜精品福利一区二区三区av| 成人高清在线视频| 国产拍揄自揄精品视频麻豆| 男人的天堂久久精品| 欧美体内she精高潮| 日韩码欧中文字| 高清不卡一二三区| 久久久久高清精品| 狠狠色2019综合网| 欧美成人a∨高清免费观看| 性做久久久久久久免费看| 色综合一个色综合| 国产喂奶挤奶一区二区三区| 亚洲高清一区二区三区| 色婷婷久久综合| 18成人在线观看| 成人性生交大片| 国产亚洲综合色| 国产麻豆精品在线| 国产人成亚洲第一网站在线播放| 韩国女主播成人在线观看| 欧美一级生活片| 久久精品99国产精品| 欧美成人video| 国产乱人伦偷精品视频免下载 | 中文字幕亚洲精品在线观看 | 91蜜桃网址入口| 最新不卡av在线| 色综合亚洲欧洲| 午夜a成v人精品| 91精品一区二区三区久久久久久 | 日韩限制级电影在线观看| 蜜臀av一区二区在线观看| 精品国产第一区二区三区观看体验 | 精品久久久久久久久久久久久久久 | 国产91丝袜在线播放| 久久综合九色综合欧美就去吻| 蜜桃av噜噜一区| 色国产精品一区在线观看| 亚洲精品成人天堂一二三| 色综合天天视频在线观看| 国产精品免费看片| 91视频免费看| 亚洲图片欧美一区| 精品视频免费看| 日韩成人免费看| 日韩免费高清av| 成人亚洲精品久久久久软件| 国产精品美女视频| 91精品1区2区| 亚洲成人免费av| 欧美一卡二卡三卡| 老司机精品视频导航| 国产清纯在线一区二区www| 99久久久国产精品免费蜜臀| 一区二区免费看| 日韩女优制服丝袜电影| aa级大片欧美| 蜜臀精品久久久久久蜜臀| 久久久久久久久99精品| 99国产欧美另类久久久精品| 亚洲韩国一区二区三区| 欧美日韩精品福利| 91在线小视频| 日本欧美一区二区三区乱码| 国产亚洲欧美在线| 在线观看免费一区| 国内精品视频一区二区三区八戒 | 久久69国产一区二区蜜臀| 国产欧美日韩另类一区| 色综合久久久久综合99| 免费在线看成人av| 亚洲欧洲精品一区二区三区 | 成人sese在线| 午夜不卡在线视频| 日韩午夜电影av| 欧美日韩中文一区| 成人性生交大片免费| 日韩**一区毛片| 国产精品的网站| 日韩免费看的电影| 欧美色精品在线视频| 国产成人在线色| 男女视频一区二区| 中文乱码免费一区二区| 久久影音资源网| 欧美丰满一区二区免费视频 | 亚洲视频在线一区观看| 欧美在线视频你懂得| 粉嫩蜜臀av国产精品网站| 日韩国产欧美在线播放| 国产精品久久久久久久久免费相片 | 激情综合一区二区三区| 亚洲成av人影院在线观看网| 国产精品国产三级国产普通话三级| 制服.丝袜.亚洲.另类.中文| 色噜噜狠狠一区二区三区果冻| 国产精品66部| 老司机午夜精品| 亚洲www啪成人一区二区麻豆| 亚洲国产综合91精品麻豆| 国产精品久久久久久久第一福利| 久久免费的精品国产v∧| 91精品国产日韩91久久久久久| 99精品视频在线观看| 懂色av中文字幕一区二区三区| 麻豆国产精品一区二区三区| 亚洲h动漫在线| 亚洲电影欧美电影有声小说| 亚洲精品菠萝久久久久久久| 中文字幕一区二| 夜夜嗨av一区二区三区网页 | 国产精品久久久久桃色tv| 久久久五月婷婷| 精品国产一区二区三区久久影院 | 亚洲激情一二三区| 亚洲卡通欧美制服中文| 亚洲免费观看视频| 亚洲综合丁香婷婷六月香| 亚洲另类色综合网站| 亚洲国产综合在线| 日韩中文字幕一区二区三区| 亚洲一二三区不卡| 视频一区二区三区中文字幕| 日本不卡一二三| 国产一区二区精品在线观看| 国产福利一区在线观看| 国产91精品露脸国语对白| 国产经典欧美精品| 欧洲亚洲精品在线| 日韩一卡二卡三卡国产欧美| 欧美成人精品高清在线播放| 国产清纯美女被跳蛋高潮一区二区久久w| 欧美高清在线精品一区| 亚洲色图在线播放| 午夜精彩视频在线观看不卡| 日本欧美一区二区三区乱码| 粉嫩av一区二区三区| 91高清在线观看| 欧美日韩成人高清| 久久久久久一级片| 国产精品色一区二区三区| 一区二区欧美视频| 久久91精品国产91久久小草| 激情六月婷婷久久| 99视频热这里只有精品免费| 欧美视频在线观看一区二区| 7777精品伊人久久久大香线蕉 | 久久精品一区蜜桃臀影院| 亚洲另类春色国产| 久久综合综合久久综合| 色综合天天综合网国产成人综合天| 欧美乱妇20p| 久久久精品tv| 亚洲电影欧美电影有声小说| 韩国午夜理伦三级不卡影院| 一本久道久久综合中文字幕| 欧美精品一二三四| 中文字幕一区二区三区在线观看| 午夜精品福利视频网站| 国产精品一二二区| 欧美综合一区二区三区| xf在线a精品一区二区视频网站| 最新热久久免费视频| 蜜桃传媒麻豆第一区在线观看| 色噜噜狠狠成人网p站| 26uuu国产电影一区二区| 亚洲国产三级在线| 成人黄色电影在线| 欧美日韩激情在线| 亚洲午夜视频在线| 成人app在线观看| 欧美一级二级在线观看| 一区二区三区欧美激情| 国产精品系列在线观看| 日韩一区二区在线看片| 亚洲一区二区三区四区五区中文| 国产成+人+日韩+欧美+亚洲| 欧美精品国产精品| 日韩电影免费在线看| 欧美亚州韩日在线看免费版国语版|