易截截图软件、单文件、免安装、纯绿色、仅160KB

Java搜索算法测试

任何项目开发中,在一个集合或数组中循环查找,搜索目标数据,是经常用到的。如果搜索的数据范围比较小,那么不管什么算法,对于今天的计算机来说,性能上基本差别不大,但是如果数据量达到几百万,甚至更大,那么算法的选择和优化就显得比较重要。有空之余测试了下顺序搜索和二分搜索的性能,竟然发现效率差异在1500倍左右。当然,这2种比较的前提是,集合中的数据已经进行了排序处理。
下边是测试代码:
 /**
 * 搜索算法测试,主要是比较二分搜索和顺序搜索的效率
 * @author 百里乐
 */
public class SearchTest
{
 /** 被搜索数据的大小*/
 private static final int size = 5000000;
 /**
  * 启动方法
  * @param args
  */
 public static void main(String[] args)
 {
  long[] data = new long[size];
  
  //添加测试数据
  for(int k =0 ;k<data.length;k++)
  {
   data[k] = k;
  }
  
  // 要查找的数据
  long target = 4980002;
  binaryFindTest(data,target);
  orderFindTest(data,target);
 }
 /**
  * 二分搜索测试
  * @param data 数据集合
  * @param target 搜索的数据
  */
 public static void binaryFindTest(long[] data, long target)
 {
  long start = System.nanoTime();
  int result = binaryFind(data,target);
  long end = System.nanoTime();
  System.out.println("binary search position:" + result);
  System.out.println("binary search time:" + (end-start));
 }
 /**
  * 顺序搜索测试
  * @param data 数据集合
  * @param target 搜索的数据
  */
 public static void orderFindTest(long[] data, long target)
 {
  long start = System.nanoTime();
  int result = orderFind(data,target);
  long end = System.nanoTime();
  System.out.println("order search position:" + result);
  System.out.println("order search time:" + (e


相关文档:

Java NIO API详解

 
Java NIO API详解
在JDK
1.4以前,Java的IO操作集中在java.io这个包中,是基于流的阻塞(blocking)API。对于大多数应用来说,这样的API使用很方
便,然而,一些对性能要求较高的应用,尤其是服务端应用,往往需要一个更为有效的方式来处理IO。从JDK 1.4起,NIO
API作为一个基于缓冲区,并能提供非阻塞(non-blo ......

由一道题来看java初始化顺序

今天看到一道题目,是这样的:(我在里面打印了一些语句,先注释掉了)
class Singleton {
private static Singleton obj= new Singleton();
public static int counter1;
public static int counter2 = 2;
private Singleton() {
counter1++;
counter2++;
// System.out.println("Singleton counter1:" ......

Java中JAVA_HOME与CLASSPATH的解析


Java中JAVA_HOME与CLASSPATH的解析 


Java中JAVA_HOME与CLASSPATH的解析
   
很多人在初学Java的时候经常会被书中介绍的一堆环境变量的设置搞得头昏脑胀,很多书中都会在初装JDK的时候让他大家设置JAVA_HOME环境变
量,在开发程序 ......

Java I/O常用流示例

package io;
import java.io.*;
/**
* @author 高枕吴忧
* 利用缓冲区原理,BufferedInputStream,
* 实现的文件字节流读取功能示范
*
*/
public class BufferedInOutputStream {
public BufferedInOutputStream() {
ioTest2();
}
public void ioTest2() {
FileInputStream in = null ;
Buffered ......

轻量级java snmp设备网管软件开发技术

Java技术,在网络管理系统中的应用已经比较普遍。网管软件的分类有很多种,有侧重于业务应用的,有侧重于管理设备的,有侧重于网络的,有侧重于桌面管
理的,每种网管软件虽然外在的具体表现形式都不同,但其实内部的技术都大同小异。这其中的设备网管软件就是一个最典型的技术代表,一个全面的设备网管软件
基本上要包含 ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号