
一般只要代码格式、注释规范,长一点并不会影响可读性。倒是滑销不好的业务逻辑会影响执行的性能。
以下一个拆分txt的Util类
import java.io.Fileimport java.io.FileInputStream
import java.io.FileNotFoundException
import java.io.FileOutputStream
import java.io.IOException
import java.io.InputStream
import java.io.OutputStream
public class FileCutter {
/**
*
*sourceFile:源文件的路径
*targetDirectory:保存文件的目录(例:'C:\\')
*prefix:是分割后文件的前缀(例:'2015-09-09')
*size:是分隔后单一文件的大小单位是2kb的倍数,size传10,分割后单一文件就是20K。传100,文件就是2M一个。
*
**/
public static void cutToMoreFile(String sourceFile, String targetDirectory, String prefix, int size)
{
//加载源文件
卖拆 File source = new File(sourceFile)
InputStream in = null
帆搏OutputStream out = null
int len = 0
int fileIndex = 1
//设置一次加载的大小
byte[] buffer = new byte[2048]
try
{
//把源文件读到InputStream中
in = new FileInputStream(source)
//循环
while(true)
{
//分割后的文件流
out = new FileOutputStream(targetDirectory + File.separator + prefix + fileIndex++ + ".txt")
for(int i = 0 i < size i++)
{
//如果文件读取完就退回方法。
if((len = in.read(buffer)) != -1)
{
//写入分割后的文件
out.write(buffer, 0, len)
}else
{
//执行finally内容后,退出方法
return
}
}
}
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
中轿枣 e.printStackTrace()
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace()
}finally
{
try {
//关系流
in.close()
out.close()
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace()
}
}
}
}
以上,详细请看注释
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)