关于Java中writeObject方法

先说一下这个writeObject的使用方法。我们有时候需要把一个类的很多对象的信息写入文件中,方便二次读取,但是如果一个对象中所包含的属性太多,将这些属性信息依次写入文件所需要的代码比较繁杂,为了图省事可以用writeObject方法直接写入对象。读出来的时候可以用readObject方法直接读出来。但是需要注意的是,你用writeObject所写入的类必须要实现serilizebal接口,否则会报错:java.io.NotSerializableException:…Unknow Source。实现方法如下:

JFileChooser jfc=new JFileChooser("D:\\");//新建一个文件选择器的窗体,运行时将先打开D盘
	    jfc.setFileSelectionMode(JFileChooser.FILES_AND_DIRECTORIES );//选择窗体中文件类型
	    int result= jfc.showSaveDialog(jfc);
	    if (result == JFileChooser.APPROVE_OPTION)
	    {
	    	String path = jfc.getSelectedFile().getAbsolutePath();//获取用户选择路径
	    	File savefile = new File(path);
			try {
				FileOutputStream fos = new FileOutputStream(path);//新建一个文件输出流
				ObjectOutputStream oos = new ObjectOutputStream(fos);//在文件输出流上套一个对象输出流
				for(Student a:DBS.dbs) {
					oos.writeObject(a);//写入对象
				}
				oos.writeObject(null);
				oos.close();
				JOptionPane.showMessageDialog(null, "保存成功!保存路径:"+path);
			} catch (FileNotFoundException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} catch (IOException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}        
    }

读取

JFileChooser jfc=new JFileChooser("D:\\");
	    jfc.setFileSelectionMode(JFileChooser.FILES_AND_DIRECTORIES );
	    int result= jfc.showOpenDialog(jfc);
	    if (result == JFileChooser.APPROVE_OPTION)
	    {
	    	String path = jfc.getSelectedFile().getAbsolutePath();
	    	DBS.dbs.clear();
	    	FileInputStream fis;
			try {
				fis = new FileInputStream(path);
				ObjectInputStream ooi = new ObjectInputStream(fis);
				Object temp;
				while((temp=ooi.readObject())!=null) {
					DBS.dbs.add((Student)temp);//读取
				}
				DBS.i = DBS.dbs.size()-1;
				JOptionPane.showMessageDialog(null, "打开成功!");
			} catch (FileNotFoundException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} catch (IOException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			} catch (ClassNotFoundException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
  • 12
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ArrayList实现了Serializable接口,这意味着ArrayList类可以将其对象序列化成字节流,以便于将其存储到文件或在网络上传输。 writeObject方法ObjectOutputStream类的一个方法,它将Java对象写入输出流以进行序列化。当ArrayList被序列化时,writeObject方法将被调用以将ArrayList对象写入输出流。这个方法将遍历ArrayList对象并将其元素写入输出流。由于ArrayList的元素可以是任何Java对象,因此这些对象也需要实现Serializable接口才能被序列化。在反序列化时,readObject方法将被调用以从输入流读取数据并重新构造ArrayList对象及其元素。 因此,ArrayList重写writeObject方法是为了控制序列化ArrayList对象时的行为,例如序列化特定的属性,以及为序列化ArrayList的元素提供额外的安全检查。 ### 回答2: ArrayList重写writeObject方法的原因是因为在默认情况下,ArrayList的元素会使用序列化对象的方式进行存储,即将每个元素逐个写入输出流。但是ArrayList本身不是实现了Serializable接口的类,所以在序列化时会抛出NotSerializableException异常。 为了解决这个问题,ArrayList重写了writeObject方法,实现了自己的序列化方式。在writeObject方法,ArrayList会将其内部的元素转换为一个数组,然后将该数组进行序列化存储。这样就避免了直接序列化ArrayList本身的问题。 通过重写writeObject方法,ArrayList能够在序列化和反序列化的过程实现对元素的正确处理,确保ArrayList对象能够被正确地序列化和反序列化。这样,即使ArrayList本身不是一个可序列化的类,也能够正常地进行序列化和反序列化操作。 ### 回答3: ArrayList类重写writeObject方法的原因主要有两个方面: 首先,ArrayList类是实现了Serializable接口的,意味着它可以被序列化成字节序列,以便在网络上传输或者保存到磁盘等。而writeObject方法是在序列化过程被调用的方法,它的作用是将对象的状态转换成字节序列的形式。ArrayList类重写writeObject方法主要是为了自定义ArrayList对象的序列化过程。默认情况下,ArrayList对象会按照元素的顺序依次将元素序列化,但是在某些情况下,我们可能希望以其他方式将ArrayList对象转换成字节序列。通过重写writeObject方法,我们可以自定义ArrayList的序列化方式,例如只序列化部分元素或者特定条件下序列化元素等。 其次,ArrayList类是一个动态数组,它可以根据需要自动扩容和收缩。在默认的序列化过程writeObject方法会将ArrayList的容量也一同进行序列化,这就意味着在反序列化时需要还原ArrayList的容量设置。然而,在某些情况下,我们可能不希望容量信息也被序列化,因为容量信息并不代表实际元素的数量,它只是ArrayList内部用于优化性能的一个指示值。通过重写writeObject方法,我们可以忽略容量信息的序列化,从而简化反序列化的过程。 总之,ArrayList重写writeObject方法主要是为了自定义序列化过程,包括对元素的序列化顺序和容量信息的处理。这样可以更灵活地控制ArrayList对象在序列化和反序列化过程的行为。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值