1.使用RandomAccessFile实现文件合成。
2.使用java中的串行化技术实现对象图(100只猫Cat集合,但是Cat的owner不需要串行化)的深度复制。
3.阐述串行化的过程,应用场景,串行ID的用途。
1.
package com.it18zhang;
/**
* 将分割的文件进行合成
*/
import java.io.File;
import java.io.FileInputStream;
import java.io.RandomAccessFile;
public class App {
public static void main(String[] args) throws Exception {
// 定义分割的小文件类
File[] srcFile = new File[3];
// 合成文件路径
File desFile = new File("d:/file.txt");
RandomAccessFile raf = new RandomAccessFile(desFile, "rw");
for (int i = 0; i < 3; i++) {
srcFile[i] = new File("d:/bb.txt" + "_" + i);
FileInputStream fis = new FileInputStream(srcFile[i]);
byte[] buf = new byte[2];
int len = 0;
while ((len = fis.read(buf)) != -1) {
raf.write(buf, 0, len);
}
fis.close();
}
raf.close();
System.out.println("over");
}
}
package com.it18zhang;
/**
* 文件分割器
*/
import java.io.File;
import java.io.FileOutputStream;
import java.io.RandomAccessFile;
public class FileSplitter {
public static void main(String[] args) throws Exception {
// 源文件
File srcFile = new File("D:\\bb.txt");
// 随机访问
RandomAccessFile raf = new RandomAccessFile(srcFile, "r");
// 文件总长度
long totalLength = srcFile.length();
// 文件份数
int number = 3;
// 计算平均每个文件的长度,最后一份
int fileLength = (int) totalLength / number;
// 循环份数,读写文件
for (int i = 0; i < number; i++) {
System.out.println("循环 : " + i);
// 开始指针
int startIndex = i * fileLength;
// 处理结束指针
int endIndex = 0;
if (i == (number - 1)) {// 最后一份
endIndex = (int) totalLength - 1;
} else {
endIndex = ((i + 1) * fileLength) - 1;
}
// 创建文件输出流
FileOutputStream fos = new FileOutputStream(srcFile.getAbsolutePath() + "_" + i);
raf.seek(startIndex);
// 定义缓冲区
byte[] buf = new byte[2];
while (true) {
// 得到当前文件指针
int currPointer = (int) raf.getFilePointer();
int remain = endIndex - currPointer + 1;
if (remain >= buf.length) {
raf.read(buf);
fos.write(buf);
} else {
raf.read(buf, 0, remain);
fos.write(buf, 0, remain);
}
if (raf.getFilePointer() > endIndex) {
break;
}
}
fos.close();
System.out.println("结束");
}
raf.close();
}
}
2.
package com.it18zhang.deepcopy;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.util.ArrayList;
import java.util.List;
public class AppCatList {
public static void main(String[] args) throws Exception {
List<Cat> list = new ArrayList<Cat>();
for(int i = 0; i<100; i++){
list.add(new Cat("tom"+i,i+2,i));
}
//写入(串行化)
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("d:/cats.dat"));
oos.writeObject(list);
oos.close();
//读取(反串行化)
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("d:/cats.dat"));
list = (List<Cat>)ois.readObject();
ois.close();
for(Cat c : list){
System.out.println(c.getName()+"-"+c.getAge()+"-"+c.getXx());
}
}
}
package com.it18zhang.deepcopy;
import java.io.Serializable;
public class Cat implements Serializable{
private static final long serialVersionUID = 2781643003919236664L;
private String name;
private int age;
private String color;
private int xx;
public Cat(String name, int age, int xx) {
super();
this.name = name;
this.age = age;
this.xx = xx;
}
//临时的
private transient Person owner;
private Dog neibor;
public Dog getNeibor() {
return neibor;
}
public void setNeibor(Dog neibor) {
this.neibor = neibor;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getColor() {
return color;
}
public void setColor(String color) {
this.color = color;
}
public int getXx() {
return xx;
}
public void setXx(int xx) {
this.xx = xx;
}
}
package com.it18zhang.deepcopy;
import java.io.Serializable;
public class Person implements Serializable{
private static final long serialVersionUID = 1513592729849839686L;
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
package com.it18zhang.deepcopy;
import java.io.Serializable;
public class Dog implements Serializable{
private static final long serialVersionUID = -6027249953977477940L;
private String name;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
3.阐述串行化的过程,应用场景,串行ID的用途。
串行化(Serialization)是计算机科学中的一个概念,它是指将对象存储到介质(如文件、内存缓冲区等)中或是以二进制方式通过网络传输。之后可以通过反串行化从这些连续的字节(byte)数据重新构建一个与原始对象状态相同的对象,因此在特定情况下也可以说是得到一个副本,但并不是所有情况都这样。
1、该对象的类必须实现Serializable接口。
2、该对象的串行化成员必须是非静态成员变量,即不能保存任何的成员方法和静态的成员变量,而且串行化保存的只是变量的值,对于变量的任何修饰符,都不能保存。
3、要串行化一个对象,必须与一定的对象输入/输出流联系起来,通过对象输出流将对象状态保存下来,再通过对象输入流将对象状态恢复。
对象序列化功能非常简单、强大,在RMI、Socket、JMS、EJB都有应用。对象序列化问题在网络编程中并不是最激动人心的课题,但却相当重要,具有许多实用意义。