⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 performancetester.java

📁 这是孙卫琴在"Java与面向对象编程"一书的源代码。
💻 JAVA
字号:
import java.util.*;
public class PerformanceTester{
  private static final int TIMES=100000;

  public static abstract class Tester{
    private String operation;
    public Tester(String operation){this.operation=operation;}
    public abstract void test(List<String> list);
    public String getOperation(){return operation;}
  }

  static Tester iterateTester=new Tester("iterate"){
      public void test(List<String> list){  //迭代操作
       for(int i=0;i<10;i++){
          Iterator<String> it=list.iterator();
          while(it.hasNext()){
            it.next();
          }
        }
      }
  };

  static Tester getTester=new Tester("get"){
      public void test(List<String> list){  //随机访问操作
         for(int i=0;i<list.size();i++)
           for(int j=0;j<10;j++)
              list.get(j);
      }
  };

  static Tester insertTester=new Tester("insert"){
    public void test(List<String> list){  //插入操作
      ListIterator<String> it=list.listIterator(list.size()/2);  //从列表的中间开始
      for(int i=0;i<TIMES/2;i++)
        it.add("hello");
    }
  };

  static Tester removeTester=new Tester("remove"){
    public void test(List<String> list){   //删除操作
      ListIterator<String> it=list.listIterator();
      while(it.hasNext()){
        it.next();
        it.remove();
      }
    }
  };

  static public void testJavaArray(List<String> list){
     Tester[] testers={iterateTester,getTester};
     test(testers,list);
  }
  static public void testList(List<String> list){
    Tester[] testers={insertTester,iterateTester,getTester,removeTester};
    test(testers,list);
  }
  static public void test(Tester[] testers,List<String> list){
    for(int i=0;i<testers.length;i++){
      System.out.print(testers[i].getOperation()+"操作:");
      long t1=System.currentTimeMillis();
      testers[i].test(list);
      long t2=System.currentTimeMillis();
      System.out.print(t2-t1+" ms");
      System.out.println();
    }
  }
  public static void main(String args[]){
    List<String> list=null;

    //测试Java数组
    System.out.println("----测试Java数组----");
    String[] ss=new String[TIMES];
    Arrays.fill(ss,"hello");
    list=Arrays.asList(ss);
    testJavaArray(list);

    ss=new String[TIMES/2];
    Collection<String> col=Arrays.asList(ss);

    //测试Vector
    System.out.println("----测试Vector----");
    list=new Vector<String>();
    list.addAll(col);
    testList(list);

    //测试LinkedList
    System.out.println("----测试LinkedList----");
    list=new LinkedList<String>();
    list.addAll(col); 
    testList(list);

    //测试ArrayList
    System.out.println("----测试ArrayList----");
    list=new ArrayList<String>();
    list.addAll(col);
    testList(list);
  }
}


/****************************************************
 * 作者:孙卫琴                                     *
 * 来源:<<Java面向对象编程>>                       *
 * 技术支持网址:www.javathinker.org                *
 ***************************************************/

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -