在java面试宝典看到这样一题,看到答案真蛋疼,看了半天才明白,可能每个人的想法不一样!答案也不知道是那位前辈写的,让人理解起来太费精了!老饶弯子,以下是本人自已整理的,去面试如果真有这么一题,应该不成问题了。。。。。。。如有不是的地方还望指点
package accp.readWriterFile;
import java.io.File;import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
public class MainClass{
public static void main(String[] args) throws Exception{
//读 参数1:文件名, 参数1:我要扫照什么格式进行拆分
String[] aWord=MainClass.read("a.txt", " ");
String[] bWord=MainClass.read("b.txt"," ");
//ab文件的组合数组
String [] ab=new String[aWord.length+bWord.length];
//得到最大的那个数组长度
int ii=0;
int coutn =(ii=aWord.length)>bWord.length?ii:bWord.length;
//开始组合数组 到一个新的数组 就是你一个我一个交差组合
int j=0;
for(int i=0;i<coutn;i++){
//如果数组索引比i大就说明还有数据
if(aWord.length>i){
ab[j]=aWord[i]+"\n"; //加回车
j++;
}
//如果数组索引比i大就说明还有数据
if(bWord.length>i){
ab[j]=bWord[i]+"\n"; //加空格或回车
j++;
}
}
//写入到c.txt文件中
FileWriter c= new FileWriter("c.txt");
MainClass.writers(c, ab);
c.close();
}
//读
public static String[] read(String filename, String regex) throws IOException{
File f = new File(filename);
FileReader reader = new FileReader(f);
char[] buf =new char[(int)f.length()];
reader.read(buf); //读取所有的字符到buf数组里
String results = new String(buf);//转换在字符串
return results.split(regex);//拆分并反回附合需求的字符串组数
}
//写
public static void writers(FileWriter c,String[] words){
for(int i=0;i<words.length;i++){
try {
c.write(words[i]+" ");
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}