Package com.db4o.util.io.spikes

Source Code of com.db4o.util.io.spikes.SimpleIoBenchmark

/* This file is part of the db4o object database http://www.db4o.com

Copyright (C) 2004 - 2011  Versant Corporation http://www.versant.com

db4o is free software; you can redistribute it and/or modify it under
the terms of version 3 of the GNU General Public License as published
by the Free Software Foundation.

db4o is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
for more details.

You should have received a copy of the GNU General Public License along
with this program.  If not, see http://www.gnu.org/licenses/. */
package com.db4o.util.io.spikes;

import java.io.File;

import com.db4o.Db4o;
import com.db4o.ObjectContainer;
import com.db4o.ObjectSet;
import com.db4o.io.IoAdapter;
import com.db4o.util.io.NIOFileAdapter;
import com.db4o.util.io.win32.Win32IoAdapter;

/**
* @exclude
*/
public class SimpleIoBenchmark {
 
  private static final String DBFILENAME = "SimpleIoBenchmark.db4o";
  private static final int ITERATIONS = 10000;

  public static void main(String[] args) {
   
    for (int i=0; i<3; ++i) {
      System.out.println("*******************");
      test("Default IO adapter", null);
      test("NIOFileadapter", new NIOFileAdapter(1024*32, 16));
      test("Win32IoAdapter", new Win32IoAdapter());
    }
   
  }
 
  private static void test(String name, IoAdapter adapter) {
    if (null != adapter) {
      Db4o.configure().io(adapter);
    }
   
    long start = System.currentTimeMillis();
    store();
    query();
    long elapsed = System.currentTimeMillis() - start;
   
    // System.gc is necessary to circumvent
    //      http://bugs.sun.com/bugdatabase/view_bug.do;:YfiG?bug_id=4724038
    System.gc();

   
    System.out.println(name);
    System.out.println("\t" + elapsed + "ms");
    File file = new File(DBFILENAME);
    System.out.println("\tFile size is " + file.length() + " bytes.");
    System.out.println("\t" + file.length()/elapsed + " bytes/ms");
    if (!file.delete()) {
      System.err.println("Unable to delete '" + DBFILENAME + "'");
    }
  }
 

  private static void query() {
    ObjectContainer db = Db4o.openFile(DBFILENAME);
    try {
      ObjectSet set = db.queryByExample(TestDummy.class);
      if (ITERATIONS != set.size()) {
        System.err.println("Expected: " + ITERATIONS + ", actual: " + set.size());
      }
    } finally {
      db.close();
    }
  }

  private static void store() {
   
    ObjectContainer db = Db4o.openFile(DBFILENAME);
    try {
      for (int i=0; i<ITERATIONS; ++i) {
        db.store(new TestDummy("Dummy " + i));
        if (0 == i % 10) {
          db.commit();
        }
      }
    } finally {
      db.close();
    }
  }
}
TOP

Related Classes of com.db4o.util.io.spikes.SimpleIoBenchmark

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.