Java工程师高薪训练营

Posted 求索

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java工程师高薪训练营相关的知识,希望对你有一定的参考价值。

download:Java工程师高薪训练营

*

  • To change this license header, choose License Headers in Project Properties.
  • To change this template file, choose Tools | Templates
  • and open the template in the editor.
    */

package datei.steuern;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.RandomAccessFile;
import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
import java.util.logging.Level;
import java.util.logging.Logger;

/**
*

  • @author s.watson
    */

public class FileTools {

public FileTools() {

}

/**

  • formatPath 转义文件目录
    *
  • @param path
  • @return
    */

public static String formatPath(String path) {

return path.replaceAll("\\\\\\\\", "/");

}

/**

  • combainPath文件路径合并
    *
  • @param eins
  • @param zwei
  • @return
    */

private static String combainPath(String eins, String zwei) {

String dori = "";
eins = null == eins ? "" : formatPath(eins);
zwei = null == zwei ? "" : formatPath(zwei);
if (!eins.endsWith("/") && zwei.indexOf("/") != 0) {
  dori = eins + "/" + zwei;
} else {
  dori = (eins + zwei).replaceAll("//", "/");
}
return dori;

}

/**

  • list2Array 列表转换数组
    *
  • @param list
  • @return
    */

private static String[] list2Array(List list) {

String array[] = (String[]) list.toArray(new String[list.size()]);
return array;

}

/**

  • cp 复制文件
    *
  • @param source
  • @param destination
  • @param loop
  • @return
    */

public static List<File> cp(String source, String destination, boolean loop) {

List<File> list = new ArrayList();
try {
  File srcFile = new File(source);
  File desFile = new File(destination);
  list.addAll(cp(srcFile, desFile, loop));
} catch (Exception ex) {
  j2log(null, null, ex);
}
return list;

}

/**

  • cp 复制文件
    *
  • @param source
  • @param destination
  • @param loop
  • @return
    */

public static List<File> cp(File source, File destination, boolean loop) {

List<File> list = new ArrayList();
try {
  if (!source.exists() || source.isDirectory()) {
    throw new FileNotFoundException();
  }
  list.add(cp(source, destination));
  if (loop) {
    String[] subFile = source.list();
    for (String subPath : subFile) {
      String src = combainPath(source.getPath(), subPath);//子文件原文件路径
      String des = combainPath(destination.getPath(), subPath);//子文件目标路径
      File subfile = new File(src);
      if (subfile.isFile()) {
        list.add(cp(src, des));
      } else if (subfile.isDirectory() && loop) {
        list.addAll(cp(src, des, loop));
      }
    }
  }
} catch (Exception ex) {
  j2log(null, null, ex);
}
return list;

}

/**

  • cp 单文件复制文件
    *
  • @param source
  • @param destination
  • @return
    */

public static File cp(String source, String destination) {

File desFile = null;
try {
  File srcFile = new File(source);
  desFile = new File(destination);
  desFile = cp(srcFile, desFile);
} catch (Exception ex) {
  j2log(null, null, ex);
}
return desFile;

}

/**

  • cp 单文件复制文件
    *
  • @param source
  • @param destination
  • @return
    */

public static File cp(File source, File destination) {

FileInputStream in = null;
FileOutputStream out = null;
FileChannel inc = null;
FileChannel outc = null;
try {
  if (!source.exists() || source.isDirectory()) {
    throw new FileNotFoundException();
  }
  if (source.getPath().equals(destination.getPath())) {
    return source;
  }
  long allbytes = du(source, false);
  if (!destination.exists()) {
    destination.createNewFile();
  }
  in = new FileInputStream(source.getPath());
  out = new FileOutputStream(destination);
  inc = in.getChannel();
  outc = out.getChannel();
  ByteBuffer byteBuffer = null;
  long length = 2097152;//基本大小,默认2M
  long _2M = 2097152;
  while (inc.position() < inc.size()) {
    if (allbytes > (64 * length)) {//如果文件大小大于128M 缓存改为64M
      length = 32 * _2M;
    } else if (allbytes > (32 * length)) {//如果文件大小大于64M 缓存改为32M
      length = 16 * _2M;
    } else if (allbytes > (16 * length)) {//如果文件大小大于32M 缓存改为16M
      length = 8 * _2M;
    } else if (allbytes > (8 * length)) {//如果文件大小大于16M 缓存改为8M
      length = 4 * _2M;
    } else if (allbytes > (4 * length)) {//如果文件大小大于8M 缓存改为4M
      length = 2 * _2M;
    } else if (allbytes > (2 * length)) {//如果文件大小大于4M 缓存改为2M
      length = _2M;
    } else if (allbytes > (length)) {//如果文件大小大于2M 缓存改为1M
      length = _2M / 2;
    } else if (allbytes < length) {//如果文件小于基本大小,直接输出
      length = allbytes;
    }
    allbytes = inc.size() - inc.position();
    byteBuffer = ByteBuffer.allocateDirect((int) length);
    inc.read(byteBuffer);
    byteBuffer.flip();
    outc.write(byteBuffer);
    outc.force(false);
  }
} catch (Exception ex) {
  j2log(null, null, ex);
} finally {
  try {
    if (null != inc) {
      inc.close();
    }
    if (null != outc) {
      outc.close();
    }
    if (null != in) {
      in.close();
    }
    if (null != out) {
      out.close();
    }
  } catch (Exception ex) {
    j2log(null, null, ex);
  }
}
return destination;

}

/**

  • rename 文件重命名
    *
  • @param filePath
  • @param from
  • @param to
  • @return
    */

public static File rename(String filePath, String from, String to) {

File newFile = null;
try {
  File oldFile = new File(combainPath(filePath, from));
  newFile = new File(combainPath(filePath, to));
  rename(newFile, oldFile);
} catch (Exception ex) {
  j2log(null, null, ex);
}
return newFile;

}

/**

  • rename 文件重命名
    *
  • @param to
  • @param from
  • @return
    */

public static File rename(File from, File to) {

try {
  String newPath = to.getPath();
  String oldPath = from.getPath();
  if (!oldPath.equals(newPath)) {
    if (!to.exists()) {
      from.renameTo(to);
    }
  }
} catch (Exception ex) {
  j2log(null, null, ex);
}
return to;

}

/**

  • mv 移动文件
    *
  • @param fileName
  • @param source
  • @param destination
  • @param cover
    */

public static void mv(String fileName, String source, String destination, boolean cover) {

try {
  if (!source.equals(destination)) {
    File oldFile = new File(combainPath(source, fileName));
    File newFile = new File(combainPath(destination, fileName));
    mv(oldFile, newFile, cover);
  }
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • mv 移动文件
    *
  • @param source
  • @param destination
  • @param cover
    */

public static void mv(String source, String destination, boolean cover) {

try {
  if (!source.equals(destination)) {
    File oldFile = new File(source);
    File newFile = new File(destination);
    mv(oldFile, newFile, cover);
  }
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • mv 移动文件
    *
  • @param source
  • @param destination
  • @param cover
    */

public static void mv(File source, File destination, boolean cover) {

try {
  if (!source.exists()) {
    throw new FileNotFoundException();
  }
  StringBuilder fileName = new StringBuilder(source.getName());
  if (!cover && source.getPath().equals(destination.getPath())) {
    if (fileName.indexOf(".") > 0) {
      fileName.insert(fileName.lastIndexOf("."), "_副本");
    } else {
      fileName.append("_副本");
    }
    cp(source, new File(combainPath(source.getParent(), fileName.toString())));
  } else {
    source.renameTo(destination);
  }
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • extensions 获取文件扩展名信息
    *
  • @param filePath
  • @param fileName
  • @return
    */

private static String[] extensions(String filePath, String fileName) {

String[] extension = {};
try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  extensions(file);
} catch (Exception ex) {
  j2log(null, null, ex);
}
return extension;

}

/**

  • extensions 获取文件扩展名信息
    *
  • @param fullPath
  • @return
    */

private static String[] extensions(String fullPath) {

String[] extension = {};
try {
  File file = new File(fullPath);
  extensions(file);
} catch (Exception ex) {
  j2log(null, null, ex);
}
return extension;

}

/**

  • extensions 获取文件扩展名信息
    *
  • @param file
  • @return
    */

private static String[] extensions(File file) {

String[] extension = {};
try {
  if (file.isFile()) {
    String fileName = file.getName();
    if (fileName.lastIndexOf(".") >= 0) {
      int lastIndex = fileName.lastIndexOf(".");
      extension[0] = String.valueOf(lastIndex);//扩展名的“.”的索引
      extension[1] = fileName.substring(lastIndex + 1);//扩展名
      extension[2] = fileName.substring(0, lastIndex);//文件名
    }
  }
} catch (Exception ex) {
  j2log(null, null, ex);
}
return extension;

}

/**

  • ls 遍历文件
    *
  • @param filePath
  • @param loop
  • @return
    */

public static List<File> ls(String filePath, boolean loop) {

List<File> list = new ArrayList();
try {
  File file = new File(filePath);
  list.addAll(ls(file, loop));
} catch (Exception ex) {
  j2log(null, null, ex);
}
return list;

}

/**

  • ls 遍历文件
    *
  • @param file
  • @param loop
  • @return
    */

public static List<File> ls(File file, boolean loop) {

List<File> list = new ArrayList();
try {
  list.add(file);
  if (!file.isDirectory()) {
    list.add(file);
  } else if (file.isDirectory()) {
    File[] subList = file.listFiles();
    subList = filesSort(subList, true);
    for (File subFile : subList) {
      if (subFile.isDirectory() && loop) {
        list.addAll(ls(subFile.getPath(), loop));
      } else {
        list.add(subFile);
      }
    }
  }
} catch (Exception ex) {
  j2log(null, null, ex);
}
return list;

}

/**

  • filesSort 文件排序(默认升序)
    *
  • @param parentPath
  • @param subList
  • @return
    */

private static File[] filesSort(File[] inFiles, boolean asc) {

List<String> files = new ArrayList();
List<String> dirs = new ArrayList();
for (File subFile : inFiles) {
  if (subFile.isDirectory()) {
    dirs.add(subFile.getPath());
  } else if (subFile.isFile()) {
    files.add(subFile.getPath());
  }
}
String[] fileArray = {};
if (files.size() > 0) {
  fileArray = list2Array(files);
  Arrays.sort(fileArray);
  if (!asc) {
    Arrays.sort(fileArray, Collections.reverseOrder());
  }
}
String[] dirArray = {};
if (dirs.size() > 0) {
  dirArray = list2Array(dirs);
  Arrays.sort(dirArray);
  if (!asc) {
    Arrays.sort(dirArray, Collections.reverseOrder());
  }
}
return concat2FileArray(fileArray, dirArray);

}

/**

  • concat2FileArray 合并文件数组
    *
  • @param old1
  • @param old2
  • @return
    */

private static File[] concat2FileArray(String[] old1, String[] old2) {

File[] newArray = new File[old1.length + old2.length];
for (int i = 0, n = old1.length; i < n; i++) {
  newArray[i] = new File(old1[i]);
}
for (int i = 0, j = old1.length, n = (old1.length + old2.length); j < n; i++, j++) {
  newArray[j] = new File(old2[i]);
}
return newArray;

}

/**

  • read 读取文本文件
    *
  • @param filePath
  • @param fileName
  • @param charset
  • @return
    */

public static StringBuilder read(String filePath, String fileName, String charset) {

StringBuilder sb = new StringBuilder();
try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  sb.append(FileTools.tail(file, false, 0, charset));
} catch (Exception ex) {
  j2log(null, null, ex);
}
return sb;

}

/**

  • read 读取文本文件
    *
  • @param fullPath
  • @param charset
  • @return
    */

public static StringBuilder read(String fullPath, String charset) {

StringBuilder sb = new StringBuilder();
try {
  File file = new File(fullPath);
  sb.append(FileTools.tail(file, false, 0, charset));
} catch (Exception ex) {
  j2log(null, null, ex);
}
return sb;

}

/**

  • read 读取文本文件
    *
  • @param file
  • @param charset
  • @return
    */

public static StringBuilder read(File file, String charset) {

StringBuilder sb = new StringBuilder();
try {
  sb.append(FileTools.tail(file, false, 0, charset));
} catch (Exception ex) {
  j2log(null, null, ex);
}
return sb;

}

/**

  • find 读取文本文件指定行
    *
  • @param filePath
  • @param fileName
  • @param line
  • @param charset
  • @return
    */

public static StringBuilder find(String filePath, String fileName, int line, String charset) {

StringBuilder sb = new StringBuilder();
try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  sb.append(FileTools.tail(file, true, line, charset));
} catch (Exception ex) {
  j2log(null, null, ex);
}
return sb;

}

/**

  • find 读取文本文件指定行
    *
  • @param fullPath
  • @param line
  • @param charset
  • @return
    */

public static StringBuilder find(String fullPath, int line, String charset) {

StringBuilder sb = new StringBuilder();
try {
  File file = new File(fullPath);
  sb.append(FileTools.tail(file, true, line, charset));
} catch (Exception ex) {
  j2log(null, null, ex);
}
return sb;

}

/**

  • find 读取文本文件指定行
    *
  • @param file
  • @param line
  • @param charset
  • @return
    */

public static StringBuilder find(File file, int line, String charset) {

StringBuilder sb = new StringBuilder();
try {
  sb.append(FileTools.tail(file, true, line, charset));
} catch (Exception ex) {
  j2log(null, null, ex);
}
return sb;

}

/**

  • tail 读取文本文件
    *
  • @param filePath
  • @param fileName
  • @param charset
  • @param find
  • @param line
  • @return
    */

public static StringBuilder tail(String filePath, String fileName, boolean find, int line, String charset) {

StringBuilder sb = new StringBuilder();
try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  sb.append(FileTools.tail(file, find, line, charset));
} catch (Exception ex) {
  j2log(null, null, ex);
}
return sb;

}

/**

  • tail 读取文本文件
    *
  • @param fullPath
  • @param charset
  • @param find
  • @param line
  • @return
    */

public static StringBuilder tail(String fullPath, boolean find, int line, String charset) {

StringBuilder sb = new StringBuilder();
try {
  File file = new File(fullPath);
  sb.append(FileTools.tail(file, find, line, charset));
} catch (Exception ex) {
  j2log(null, null, ex);
}
return sb;

}

/**

  • tail 读取文本文件
    *
  • @param file
  • @param charset
  • @param find
  • @param line
  • @return
    */

public static StringBuilder tail(File file, boolean find, int line, String charset) {

StringBuilder sb = new StringBuilder();
BufferedReader bufferReader = null;
if (null == charset || "".equals(charset)) {
  charset = "UTF-8";
}
try {
  if (!file.exists() || file.isDirectory()) {
    throw new FileNotFoundException();
  }
  String fullPath = file.getPath();
  bufferReader = new BufferedReader(new InputStreamReader(new FileInputStream(fullPath), charset));
  String temp;
  for (int i = 0; (temp = bufferReader.readLine()) != null; i++) {
    if (!find || line == i) {
      sb.append(temp);
    }
  }
} catch (Exception ex) {
  j2log(null, null, ex);
} finally {
  if (null != bufferReader) {
    try {
      bufferReader.close();
    } catch (IOException ex) {
      j2log(null, null, ex);
    }
  }
}
return sb;

}

/**

  • sed 读取文本文件
    *
  • @param filePath
  • @param fileName
  • @param charset
  • @return
    */

public static List<String> sed(String filePath, String fileName, String charset) {

List<String> list = new ArrayList();
try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  list.addAll(FileTools.sed(file, charset));
} catch (Exception ex) {
  j2log(null, null, ex);
}
return list;

}

/**

  • sed 读取文本文件
    *
  • @param fullPath
  • @param charset
  • @return
    */

public static List<String> sed(String fullPath, String charset) {

List<String> list = new ArrayList();
try {
  File file = new File(fullPath);
  list.addAll(FileTools.sed(file, charset));
} catch (Exception ex) {
  j2log(null, null, ex);
}
return list;

}

/**

  • sed 读取文本文件
    *
  • @param file
  • @param charset
  • @return
    */

public static List<String> sed(File file, String charset) {

List<String> list = new ArrayList();
BufferedReader bufferReader = null;
if (null == charset || "".equals(charset)) {
  charset = "UTF-8";
}
try {
  if (!file.exists() || file.isDirectory()) {
    throw new FileNotFoundException();
  }
  String fullPath = file.getPath();
  bufferReader = new BufferedReader(new InputStreamReader(new FileInputStream(fullPath), charset));
  String temp;
  for (int i = 0; (temp = bufferReader.readLine()) != null; i++) {
    list.add(temp);
  }
} catch (Exception ex) {
  j2log(null, null, ex);
} finally {
  if (null != bufferReader) {
    try {
      bufferReader.close();
    } catch (IOException ex) {
      j2log(null, null, ex);
    }
  }
}
return list;

}

/**

  • cat 读取文本文件
    *
  • @param filePath
  • @param fileName
  • @return
    */

public static byte[] cat(String filePath, String fileName) {

byte[] output = {};
try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  output = FileTools.cat(file);
} catch (Exception ex) {
  j2log(null, null, ex);
}
return output;

}

/**

  • cat 读取文本文件
    *
  • @param fullPath
  • @return
    */

public static byte[] cat(String fullPath) {

byte[] output = {};
try {
  File file = new File(fullPath);
  output = FileTools.cat(file);
} catch (Exception ex) {
  j2log(null, null, ex);
}
return output;

}

/**

  • cat 读取文本文件
    *
  • @param file
  • @return
    */

public static byte[] cat(File file) {

InputStream in = null;
byte[] output = {};
try {
  if (!file.exists() || file.isDirectory()) {
    throw new FileNotFoundException();
  }
  String fullPath = file.getPath();
  long length = du(file, false);
  long _2M = 2097152;
  byte[] bytes = new byte[(int) length];
  in = new FileInputStream(fullPath);
  for (int count = 0; count != -1;) {
    if (length > 16 * _2M) {
      length = 4 * _2M;
    } else if (length > 8 * _2M) {
      length = 2 * _2M;
    } else if (length > 4 * _2M) {
      length = _2M;
    } else if (length > 2 * _2M) {
      length = _2M / 2;
    } else if (length > _2M) {
      length = _2M / 4;
    } else {
      length = 4096;
    }
    bytes = new byte[(int) length];
    count = in.read(bytes);
    output = concatArray(bytes, output);
    length = in.available();
  }
} catch (Exception ex) {
  j2log(null, null, ex);
} finally {
  if (null != in) {
    try {
      in.close();
    } catch (Exception ex) {
      j2log(null, null, ex);
    }
  }
}
return output;

}

/**

  • 合并数组
    *
  • @param old1
  • @param old2
  • @return
    */

private static byte[] concatArray(byte[] old1, byte[] old2) {

byte[] newArray = new byte[old1.length + old2.length];
System.arraycopy(old1, 0, newArray, 0, old1.length);
System.arraycopy(old2, 0, newArray, old1.length, old2.length);
return newArray;

}

/**

  • dd 写入文件fullPath内容content
    *
  • @param filePath
  • @param fileName
  • @param content
  • @param isAppend
    */

public static void dd(String filePath, String fileName, byte[] content, boolean isAppend) {

try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  FileTools.dd(file, content, isAppend);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • dd 写入文件fullPath内容content
    *
  • @param fullPath
  • @param content
  • @param isAppend
    */

public static void dd(String fullPath, byte[] content, boolean isAppend) {

try {
  File file = new File(fullPath);
  FileTools.dd(file, content, isAppend);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • dd 写入文件fullPath内容content
    *
  • @param file
  • @param content
  • @param isAppend
    */

public static void dd(File file, byte[] content, boolean isAppend) {

FileOutputStream fileOutputStream = null;
try {
  if (!file.exists()) {
    file.createNewFile();
  }
  fileOutputStream = new FileOutputStream(file, isAppend);
  fileOutputStream.write(content);
} catch (Exception ex) {
  j2log(null, null, ex);
} finally {
  try {
    if (null != fileOutputStream) {
      fileOutputStream.close();
    }
  } catch (IOException ex) {
    j2log(null, null, ex);
  }
}

}

/**

  • write 写文件内容content到文件fullPath
    *
  • @param filePath
  • @param fileName
  • @param content
    */

public static void write(String filePath, String fileName, String content) {

try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  FileTools.write(file, content, true);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • write 写文件内容content到文件fullPath
    *
  • @param fullPath
  • @param content
    */

public static void write(String fullPath, String content) {

try {
  File file = new File(fullPath);
  FileTools.write(file, content, true);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • write 写文件内容content到文件fullPath
    *
  • @param file
  • @param content
    */

public static void write(File file, String content) {

try {
  FileTools.write(file, content, true);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • write 写(追加)文件内容content到文件fullPath
    *
  • @param filePath
  • @param fileName
  • @param content
  • @param isAppend
    */

public static void write(String filePath, String fileName, String content, boolean isAppend) {

try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  FileTools.write(file, content, isAppend);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • write 写(追加)文件内容content到文件fullPath
    *
  • @param fullPath
  • @param content
  • @param isAppend
    */

public static void write(String fullPath, String content, boolean isAppend) {

try {
  File file = new File(fullPath);
  FileTools.write(file, content, isAppend);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • write 写(追加)文件内容content到文件fullPath
    *
  • @param file
  • @param content
  • @param isAppend
    */

public static void write(File file, String content, boolean isAppend) {

FileWriter fileWriter = null;
try {
  if (!file.exists()) {
    file.createNewFile();
  }
  fileWriter = new FileWriter(file.getPath(), isAppend);
  fileWriter.write(content);
} catch (Exception ex) {
  j2log(null, null, ex);
} finally {
  if (null != fileWriter) {
    try {
      fileWriter.close();
    } catch (IOException ex) {
      j2log(null, null, ex);
    }
  }
}

}

/**

  • tail 添加文件内容content到文件的index位置
    *
  • @param filePath
  • @param fileName
  • @param content
  • @param index
    */

public static void tail(String filePath, String fileName, String content, long index) {

try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  FileTools.tail(file, content, index);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • tail 添加文件内容content到文件的index位置
    *
  • @param fullPath
  • @param content
  • @param index
    */

public static void tail(String fullPath, String content, long index) {

try {
  File file = new File(fullPath);
  FileTools.tail(file, content, index);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • tail 添加文件内容content到文件的index位置
    *
  • @param file
  • @param content
  • @param index
    */

public static void tail(File file, String content, long index) {

RandomAccessFile randomAccessFile = null;
try {
  if (!file.exists()) {
    file.createNewFile();
  }
  randomAccessFile = new RandomAccessFile(file.getPath(), "rw");
  randomAccessFile.seek(index);
  randomAccessFile.writeBytes(content);
} catch (Exception ex) {
  j2log(null, null, ex);
} finally {
  if (null != randomAccessFile) {
    try {
      randomAccessFile.close();
    } catch (Exception ex) {
      j2log(null, null, ex);
    }
  }
}

}

/**

  • mkdir 创建目录
    *
  • @param filePath
  • @param fileName
  • @return
    */

public static File mkdir(String filePath, String fileName) {

File file = null;
try {
  String fullPath = combainPath(filePath, fileName);
  file = new File(fullPath);
  file = mkdir(file);
} catch (Exception ex) {
  j2log(null, null, ex);
}
return file;

}

/**

  • mkdir 创建目录
    *
  • @param fullPath
  • @return
    */

public static File mkdir(String fullPath) {

File file = null;
try {
  file = new File(fullPath);
  file = mkdir(file);
} catch (Exception ex) {
  j2log(null, null, ex);
}
return file;

}

/**

  • mkdir 创建目录
    *
  • @param file
  • @return
    */

public static File mkdir(File file) {

try {
  if (!file.exists()) {
    file.mkdir();//如果文件夹不存在则创建
  }
} catch (Exception ex) {
  j2log(null, null, ex);
}
return file;

}

/**

  • touch 创建文件
    *
  • @param filePath
  • @param fileName
    */

public static void touch(String filePath, String fileName) {

try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  touch(file);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • touch 创建文件
    *
  • @param fullPath
    */

public static void touch(String fullPath) {

try {
  File file = new File(fullPath);
  touch(file);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • touch 创建文件
    *
  • @param file
    */

public static void touch(File file) {

try {
  if (!file.exists()) {
    file.createNewFile();//如果文件不存在则创建
  }
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • rm 删除文件
    *
  • @param filePath
  • @param fileName
    */

public static void rm(String filePath, String fileName) {

try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  rm(file);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • rm 删除文件
    *
  • @param fullPath
    */

public static void rm(String fullPath) {

try {
  File file = new File(fullPath);
  rm(file);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • rm 删除文件
    *
  • @param file
    */

public static void rm(File file) {

try {
  if (!file.exists()) {
    throw new FileNotFoundException();
  }
  if (file.isFile()) {
    file.delete();
  }
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • rmdir 删除目录
    *
  • @param filePath
  • @param fileName
  • @param loop
    */

public static void rmdir(String filePath, String fileName, boolean loop) {

try {
  String fullPath = combainPath(filePath, fileName);
  File dir = new File(fullPath);
  rmdir(dir, loop);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • rmdir 删除目录
    *
  • @param fullPath
  • @param loop
    */

public static void rmdir(String fullPath, boolean loop) {

try {
  File dir = new File(fullPath);
  rmdir(dir, loop);
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • rmdir 删除目录
    *
  • @param dir
  • @param loop
    */

public static void rmdir(File dir, boolean loop) {

try {
  if (!dir.exists()) {
    throw new FileNotFoundException();
  }
  if (dir.isDirectory()) {
    File[] files = dir.listFiles();
    int length = files.length;
    for (int i = 0; i < length && loop; i++) {
      if (files[i].isDirectory()) {
        rmdir(files[i], loop);
      } else {
        rm(files[i]);
      }
    }
    if (loop || length == 0) {
      dir.delete();
    }
  }
} catch (Exception ex) {
  j2log(null, null, ex);
}

}

/**

  • du 获取文件实际大小
    *
  • @param filePath
  • @param fileName
  • @param loop
  • @return
    */

public static long du(String filePath, String fileName, boolean loop) {

long size = 0;
try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  size = du(file, loop);
} catch (Exception ex) {
  j2log(null, null, ex);
}
return size;

}

/**

  • du 获取文件实际大小
    *
  • @param filePath
  • @param fileName
  • @return
    */

public static long du(String filePath, String fileName) {

long size = 0;
try {
  String fullPath = combainPath(filePath, fileName);
  File file = new File(fullPath);
  size = du(file, false);
} catch (Exception ex) {
  j2log(null, null, ex);
}
return size;

}

/**

  • du 获取文件实际大小
    *
  • @param fullPath
  • @return
    */

public static long du(String fullPath) {

long size = 0;
try {
  File file = new File(fullPath);
  size = du(file, false);
} catch (Exception ex) {
  j2log(null, null, ex);
}
return size;

}

/**

  • du 获取文件实际大小
    *
  • @param file
  • @return
    */

public static long du(File file) {

long size = 0;
try {
  size = du(file, false);
} catch (Exception ex) {
  j2log(null, null, ex);
}
return size;

}

/**

  • du 获取文件实际大小
    *
  • @param fullPath
  • @param loop
  • @return
    */

public static long du(String fullPath, boolean loop) {

long size = 0;
try {
  File file = new File(fullPath);
  size = du(file, loop);
} catch (Exception ex) {
  j2log(null, null, ex);
}
return size;

}

/**

  • du 获取文件实际大小
    *
  • @param file
  • @param loop
  • @return
    */

public static long du(File file, boolean loop) {

FileChannel fileChannel = null;
long size = 0;
try {
  if (!file.exists()) {
    throw new FileNotFoundException();
  }
  if (file.isFile()) {
    FileInputStream fis = new FileInputStream(file);
    fileChannel = fis.getChannel();
    size = fileChannel.size();
  } else if (file.isDirectory()) {
    File[] files = file.listFiles();
    int length = files.length;
    for (int i = 0; i < length && loop; i++) {
      if (files[i].isDirectory()) {
        du(files[i], loop);
      } else {
        size += du(files[i], false);
      }
    }
  }
} catch (Exception ex) {
  j2log(null, null, ex);
} finally {
  if (null != fileChannel) {
    try {
      fileChannel.close();
    } catch (Exception ex) {
      j2log(null, null, ex);
    }
  }
}
return size;

}
}

以上是关于Java工程师高薪训练营的主要内容,如果未能解决你的问题,请参考以下文章

Java工程师高薪训练营

拉勾java高薪训练营

王道 2020 Java 就业薪资揭秘:超过七成月入过万?

高级Java工程师面试必备 掌握Spring高薪马上到手!

高薪项目推荐|Java后端开发工程师

Java工程师多少钱才算高薪