java 快速查找100G的文件

java 快速查找100G的文件,第1张

有一个100G大小的文件里存的全是数字,而且每一个数字见用逗号隔开。如今在这一大堆数字中找出100个最大的数出来。

使用Files类将文件的所有内容读入字节数组。Files类还有一个方法可以读取所有行到字符串列表。Files类是在Java 7中引入的,如果想加载所有文件内容,使用这个类是比较适合的。

只有在处理小文件并且需要加载所有文件内容到内存中时才应使用此方法。

java实现文件搜索主要使用file类和正则表达式,如下示例:

package com.kiritor.util

import java.io.File

import java.io.FileFilter

import java.util.Arrays

import java.util.Collections

import java.util.List

/**

 * 文件的相关 *** 作类

 * 

 * @author Kiritor

 */

public class FileOperation {

private static String contentPath

private static String filePath

private static File[] fileList = null// 保存文件列表,过滤掉目录

public FileOperation() {

}

/** 构造函数的参数是一个目录 */

public FileOperation(String path) {

File file = new File(path)

if (file.isDirectory())

this.contentPath = path

else

this.filePath = path

}

    /**获取文件列表*/

public static File[] getFiles() {

if (contentPath == null) {

File file = new File(filePath)

fileList = new File[1]

fileList[0] = file

return fileList

}

fileList = new File(contentPath).listFiles(new FileFilter() {

/**使用过滤器过滤掉目录*/

@Override

public boolean accept(File pathname) {

if(pathname.isDirectory())

{

return false

}else

return true

}

})

return fileList

}

/** 对当前目录下的所有文件进行排序 */

public static File[] sort() {

getFiles()

Arrays.sort(fileList, new FileComparator())

return fileList

}

public static void tree(File f, int level) {

String preStr = ""

for(int i=0 i<level i++) {

preStr += "    "

}

File[] childs = f.listFiles()

//返回一个抽象路径名数组,这些路径名表示此抽象路径名表示的目录中的文件。

for(int i=0 i<childs.length i++) {

System.out.println(preStr + childs[i].getName())

if(childs[i].isDirectory()) {

tree(childs[i], level + 1)

}

}

}

// 提供一个"比较器"

static class FileComparator implements java.util.Comparator<File> {

@Override

public int compare(File o1, File o2) {

// 按照文件名的字典顺序进行比较

return o1.getName().compareTo(o2.getName())

}

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11473280.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-16
下一篇 2023-05-16

发表评论

登录后才能评论

评论列表(0条)

保存